pax_global_header00006660000000000000000000000064126550677370014534gustar00rootroot0000000000000052 comment=c80c8b9225139c112d202c1ee4071bc76e2b71d3 eztrace-1.1-2/000077500000000000000000000000001265506773700131715ustar00rootroot00000000000000eztrace-1.1-2/AUTHORS000066400000000000000000000011761265506773700142460ustar00rootroot00000000000000main contributors: François Trahay -- Project Leader Mathieu Faverge -- external plugins, collaboration with ViTE François Rue -- Development and External Relations Damien Martin-Guillerez -- pptrace maintainer, MAC OS X tester Roman Iakymchuk Matias Hastaran occasional/former contributors: Jérôme Clet-Ortega (INRIA Bordeaux) Charles Aulagnon (INRIA Bordeaux) Paul-Emile Sublet (Telecom SudParis) Herve Loeffel (Telecom SudParis) Julien Pedron (INRIA Bordeaux) eztrace-1.1-2/COPYING000066400000000000000000000035071265506773700142310ustar00rootroot00000000000000Copyright CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis 2014 François Trahay Mathieu Faverge François Rue Damien Martin-Guillerez Roman Iakymchuk Matias Hastaran EZTrace is a computer program whose purpose is to analyze the performance of parallel applications. This software is governed by the CeCILL-B license under French law and abiding by the rules of distribution of free software. You can use, modify and/ or redistribute the software under the terms of the CeCILL-B license as circulated by CEA, CNRS and INRIA at the following URL "http://www.cecill.info". As a counterpart to the access to the source code and rights to copy, modify and redistribute granted by the license, users are provided only with a limited warranty and the software's author, the holder of the economic rights, and the successive licensors have only limited liability. In this respect, the user's attention is drawn to the risks associated with loading, using, modifying and/or developing or reproducing the software by the user in light of its specific status of free software, that may mean that it is complicated to manipulate, and that also therefore means that it is reserved for developers and experienced professionals having in-depth computer knowledge. Users are therefore encouraged to load and test the software's suitability as regards their requirements in conditions enabling the security of their systems and/or data to be ensured and, more generally, to use and operate it in the same conditions as regards security. The fact that you are presently reading this means that you have had knowledge of the CeCILL-B license and that you accept its terms. eztrace-1.1-2/ChangeLog000066400000000000000000000065551265506773700147560ustar00rootroot00000000000000Version 1.1 ----------- * Add a StarPU module Version 1.0 ----------- * Add support for CUDA applications * Add a script that generates an EZTrace plugin directly from an executable program * EZTrace now relies on LiTL (instead of FxT) for recording events * EZTrace can now track the CPU on which a thread run * Add a sampling interface that allows to call a function every x ms * EZTrace is now under the CeCILL-B license Version 0.9 ----------- * Add support for MPI Communicators in collective communications * Add support for non-blocking collective communications * Add options in eztrace and eztrace.old to manipulate various environment variable (EZTRACE_TRACE, EZTRACE_OUTPUT_DIR, etc.) Version 0.8 ----------- * EZTrace now relies on Opari2. Thus, OpenMP 3.0 programs can be analyzed * EZTrace provides two trace flush policies: the trace is written to disk only at the end of the program (thus, some events may be lost, but there is no overhead) or when the event buffer is full (thus, no event lost, but there's an overhead when the trace is being written to disk) * EZTrace now implements a trace synchronisation mechanism * EZTrace can now instrument functions located inside the application or in a statically-linked library(it does not require to be dynamically linked anymore) Version 0.7 ----------- * EZTrace can now use PAPI (Performance Application Programming Interface) for extracting hardware counters * Update the OpenMP module. It can now use Opari for instrumenting OpenMP program and extract precise informations * Fix the generation of OTF traces * Improve statistics on MPI messages Version 0.6 ----------- * Add a module for standard IO primitives (read, write, select, ...) * Add a module for tracking memory consumption (malloc, free, ...) * Add a source-to-source compiler (eztrace_create) for converting simple scripts into eztrace plugins * FxT and GTG (with OTF support) are now included in eztrace. Thus, you don't need to download/install them separately. Version 0.5 ----------- * EZTrace now relies on modules (plugins). * EZTrace now supports user-defined plugins. * EZTrace now works on Mac OS X. However, since mac os pthread interface is limited compared to the linux one, the pthread module is not available on macos. * The Coreblas module has been removed. It is now part of the Plasma project. * eztrace_stats is now available. Instead of merging traces, it computes statistics on the traces (number of events, average size of MPI messages, etc.) * Fix various bugs in PThread and MPI modules. Version 0.4 ----------- * EZTrace now uses GTG for converting traces. You can now generate OTF traces Version 0.3 ----------- * Add full support for MPI communication operations (for both C and Fortran bindings) * Add support for OpenMP scheduling strategies (static, dynamic, guided and runtime) * Fix various bugs in PThread, OpenMP and MPI modules Version 0.2 ----------- * Add support for Fortran MPI programs * Add support for MPI collective communications * Add support for non-blocking MPI communications Version 0.1.1 ----------- * Fix a bug regarding pthread_cond_signal and pthread_cond_broadcast Version 0.1 ----------- * This first release supports: * Threads state (blocked/working) * OpenMP parallel sections for C or Fortran programs (merely tested) * sem_post/sem_wait are shown as Events and Links in the Paje trace * Basic MPI support eztrace-1.1-2/INSTALL000066400000000000000000000366101265506773700142300ustar00rootroot00000000000000Installation Instructions ************************* Copyright (C) 1994-1996, 1999-2002, 2004-2013 Free Software Foundation, Inc. Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright notice and this notice are preserved. This file is offered as-is, without warranty of any kind. Basic Installation ================== Briefly, the shell command `./configure && make && make install' should configure, build, and install this package. The following more-detailed instructions are generic; see the `README' file for instructions specific to this package. Some packages provide this `INSTALL' file but do not implement all of the features documented below. The lack of an optional feature in a given package is not necessarily a bug. More recommendations for GNU packages can be found in *note Makefile Conventions: (standards)Makefile Conventions. The `configure' shell script attempts to guess correct values for various system-dependent variables used during compilation. It uses those values to create a `Makefile' in each directory of the package. It may also create one or more `.h' files containing system-dependent definitions. Finally, it creates a shell script `config.status' that you can run in the future to recreate the current configuration, and a file `config.log' containing compiler output (useful mainly for debugging `configure'). It can also use an optional file (typically called `config.cache' and enabled with `--cache-file=config.cache' or simply `-C') that saves the results of its tests to speed up reconfiguring. Caching is disabled by default to prevent problems with accidental use of stale cache files. If you need to do unusual things to compile the package, please try to figure out how `configure' could check whether to do them, and mail diffs or instructions to the address given in the `README' so they can be considered for the next release. If you are using the cache, and at some point `config.cache' contains results you don't want to keep, you may remove or edit it. The file `configure.ac' (or `configure.in') is used to create `configure' by a program called `autoconf'. You need `configure.ac' if you want to change it or regenerate `configure' using a newer version of `autoconf'. The simplest way to compile this package is: 1. `cd' to the directory containing the package's source code and type `./configure' to configure the package for your system. Running `configure' might take a while. While running, it prints some messages telling which features it is checking for. 2. Type `make' to compile the package. 3. Optionally, type `make check' to run any self-tests that come with the package, generally using the just-built uninstalled binaries. 4. Type `make install' to install the programs and any data files and documentation. When installing into a prefix owned by root, it is recommended that the package be configured and built as a regular user, and only the `make install' phase executed with root privileges. 5. Optionally, type `make installcheck' to repeat any self-tests, but this time using the binaries in their final installed location. This target does not install anything. Running this target as a regular user, particularly if the prior `make install' required root privileges, verifies that the installation completed correctly. 6. You can remove the program binaries and object files from the source code directory by typing `make clean'. To also remove the files that `configure' created (so you can compile the package for a different kind of computer), type `make distclean'. There is also a `make maintainer-clean' target, but that is intended mainly for the package's developers. If you use it, you may have to get all sorts of other programs in order to regenerate files that came with the distribution. 7. Often, you can also type `make uninstall' to remove the installed files again. In practice, not all packages have tested that uninstallation works correctly, even though it is required by the GNU Coding Standards. 8. Some packages, particularly those that use Automake, provide `make distcheck', which can by used by developers to test that all other targets like `make install' and `make uninstall' work correctly. This target is generally not run by end users. Compilers and Options ===================== Some systems require unusual options for compilation or linking that the `configure' script does not know about. Run `./configure --help' for details on some of the pertinent environment variables. You can give `configure' initial values for configuration parameters by setting variables in the command line or in the environment. Here is an example: ./configure CC=c99 CFLAGS=-g LIBS=-lposix *Note Defining Variables::, for more details. Compiling For Multiple Architectures ==================================== You can compile the package for more than one kind of computer at the same time, by placing the object files for each architecture in their own directory. To do this, you can use GNU `make'. `cd' to the directory where you want the object files and executables to go and run the `configure' script. `configure' automatically checks for the source code in the directory that `configure' is in and in `..'. This is known as a "VPATH" build. With a non-GNU `make', it is safer to compile the package for one architecture at a time in the source code directory. After you have installed the package for one architecture, use `make distclean' before reconfiguring for another architecture. On MacOS X 10.5 and later systems, you can create libraries and executables that work on multiple system types--known as "fat" or "universal" binaries--by specifying multiple `-arch' options to the compiler but only a single `-arch' option to the preprocessor. Like this: ./configure CC="gcc -arch i386 -arch x86_64 -arch ppc -arch ppc64" \ CXX="g++ -arch i386 -arch x86_64 -arch ppc -arch ppc64" \ CPP="gcc -E" CXXCPP="g++ -E" This is not guaranteed to produce working output in all cases, you may have to build one architecture at a time and combine the results using the `lipo' tool if you have problems. Installation Names ================== By default, `make install' installs the package's commands under `/usr/local/bin', include files under `/usr/local/include', etc. You can specify an installation prefix other than `/usr/local' by giving `configure' the option `--prefix=PREFIX', where PREFIX must be an absolute file name. You can specify separate installation prefixes for architecture-specific files and architecture-independent files. If you pass the option `--exec-prefix=PREFIX' to `configure', the package uses PREFIX as the prefix for installing programs and libraries. Documentation and other data files still use the regular prefix. In addition, if you use an unusual directory layout you can give options like `--bindir=DIR' to specify different values for particular kinds of files. Run `configure --help' for a list of the directories you can set and what kinds of files go in them. In general, the default for these options is expressed in terms of `${prefix}', so that specifying just `--prefix' will affect all of the other directory specifications that were not explicitly provided. The most portable way to affect installation locations is to pass the correct locations to `configure'; however, many packages provide one or both of the following shortcuts of passing variable assignments to the `make install' command line to change installation locations without having to reconfigure or recompile. The first method involves providing an override variable for each affected directory. For example, `make install prefix=/alternate/directory' will choose an alternate location for all directory configuration variables that were expressed in terms of `${prefix}'. Any directories that were specified during `configure', but not in terms of `${prefix}', must each be overridden at install time for the entire installation to be relocated. The approach of makefile variable overrides for each directory variable is required by the GNU Coding Standards, and ideally causes no recompilation. However, some platforms have known limitations with the semantics of shared libraries that end up requiring recompilation when using this method, particularly noticeable in packages that use GNU Libtool. The second method involves providing the `DESTDIR' variable. For example, `make install DESTDIR=/alternate/directory' will prepend `/alternate/directory' before all installation names. The approach of `DESTDIR' overrides is not required by the GNU Coding Standards, and does not work on platforms that have drive letters. On the other hand, it does better at avoiding recompilation issues, and works well even when some directory options were not specified in terms of `${prefix}' at `configure' time. Optional Features ================= If the package supports it, you can cause programs to be installed with an extra prefix or suffix on their names by giving `configure' the option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'. Some packages pay attention to `--enable-FEATURE' options to `configure', where FEATURE indicates an optional part of the package. They may also pay attention to `--with-PACKAGE' options, where PACKAGE is something like `gnu-as' or `x' (for the X Window System). The `README' should mention any `--enable-' and `--with-' options that the package recognizes. For packages that use the X Window System, `configure' can usually find the X include and library files automatically, but if it doesn't, you can use the `configure' options `--x-includes=DIR' and `--x-libraries=DIR' to specify their locations. Some packages offer the ability to configure how verbose the execution of `make' will be. For these packages, running `./configure --enable-silent-rules' sets the default to minimal output, which can be overridden with `make V=1'; while running `./configure --disable-silent-rules' sets the default to verbose, which can be overridden with `make V=0'. Particular systems ================== On HP-UX, the default C compiler is not ANSI C compatible. If GNU CC is not installed, it is recommended to use the following options in order to use an ANSI C compiler: ./configure CC="cc -Ae -D_XOPEN_SOURCE=500" and if that doesn't work, install pre-built binaries of GCC for HP-UX. HP-UX `make' updates targets which have the same time stamps as their prerequisites, which makes it generally unusable when shipped generated files such as `configure' are involved. Use GNU `make' instead. On OSF/1 a.k.a. Tru64, some versions of the default C compiler cannot parse its `' header file. The option `-nodtk' can be used as a workaround. If GNU CC is not installed, it is therefore recommended to try ./configure CC="cc" and if that doesn't work, try ./configure CC="cc -nodtk" On Solaris, don't put `/usr/ucb' early in your `PATH'. This directory contains several dysfunctional programs; working variants of these programs are available in `/usr/bin'. So, if you need `/usr/ucb' in your `PATH', put it _after_ `/usr/bin'. On Haiku, software installed for all users goes in `/boot/common', not `/usr/local'. It is recommended to use the following options: ./configure --prefix=/boot/common Specifying the System Type ========================== There may be some features `configure' cannot figure out automatically, but needs to determine by the type of machine the package will run on. Usually, assuming the package is built to be run on the _same_ architectures, `configure' can figure that out, but if it prints a message saying it cannot guess the machine type, give it the `--build=TYPE' option. TYPE can either be a short name for the system type, such as `sun4', or a canonical name which has the form: CPU-COMPANY-SYSTEM where SYSTEM can have one of these forms: OS KERNEL-OS See the file `config.sub' for the possible values of each field. If `config.sub' isn't included in this package, then this package doesn't need to know the machine type. If you are _building_ compiler tools for cross-compiling, you should use the option `--target=TYPE' to select the type of system they will produce code for. If you want to _use_ a cross compiler, that generates code for a platform different from the build platform, you should specify the "host" platform (i.e., that on which the generated programs will eventually be run) with `--host=TYPE'. Sharing Defaults ================ If you want to set default values for `configure' scripts to share, you can create a site shell script called `config.site' that gives default values for variables like `CC', `cache_file', and `prefix'. `configure' looks for `PREFIX/share/config.site' if it exists, then `PREFIX/etc/config.site' if it exists. Or, you can set the `CONFIG_SITE' environment variable to the location of the site script. A warning: not all `configure' scripts look for a site script. Defining Variables ================== Variables not defined in a site shell script can be set in the environment passed to `configure'. However, some packages may run configure again during the build, and the customized values of these variables may be lost. In order to avoid this problem, you should set them in the `configure' command line, using `VAR=value'. For example: ./configure CC=/usr/local2/bin/gcc causes the specified `gcc' to be used as the C compiler (unless it is overridden in the site shell script). Unfortunately, this technique does not work for `CONFIG_SHELL' due to an Autoconf limitation. Until the limitation is lifted, you can use this workaround: CONFIG_SHELL=/bin/bash ./configure CONFIG_SHELL=/bin/bash `configure' Invocation ====================== `configure' recognizes the following options to control how it operates. `--help' `-h' Print a summary of all of the options to `configure', and exit. `--help=short' `--help=recursive' Print a summary of the options unique to this package's `configure', and exit. The `short' variant lists options used only in the top level, while the `recursive' variant lists options also present in any nested packages. `--version' `-V' Print the version of Autoconf used to generate the `configure' script, and exit. `--cache-file=FILE' Enable the cache: use and save the results of the tests in FILE, traditionally `config.cache'. FILE defaults to `/dev/null' to disable caching. `--config-cache' `-C' Alias for `--cache-file=config.cache'. `--quiet' `--silent' `-q' Do not print messages saying which checks are being made. To suppress all normal output, redirect it to `/dev/null' (any error messages will still be shown). `--srcdir=DIR' Look for the package's source code in directory DIR. Usually `configure' can determine that directory automatically. `--prefix=DIR' Use DIR as the installation prefix. *note Installation Names:: for more details, including other options available for fine-tuning the installation locations. `--no-create' `-n' Run the configure checks, but stop before creating any output files. `configure' also accepts some other, not widely useful, options. Run `configure --help' for more details. eztrace-1.1-2/Makefile.am000066400000000000000000000107641265506773700152350ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. ACLOCAL_AMFLAGS=-I m4 if AMEXTERNLITL TLCFLAGS=$(TL_CPPFLAGS) TLLDFLAGS=$(TL_LDFLAGS) TLLIBADD=$(TL_LIB) else # AMEXTERNLITL TLCFLAGS = -I$(top_srcdir)/extlib/litl/src -I$(top_builddir)/extlib/litl/src TLLDFLAGS = $(top_builddir)/extlib/litl/src/liblitl.la TLLIBADD=$(TL_LIB) endif # AMINTERNLITL if AMEXTERNGTG GTGCFLAGS=$(GTG_CPPFLAGS) GTGLDFLAGS=$(GTG_LDFLAGS) else # AMEXTERNGTG GTGCFLAGS = -I$(top_srcdir)/extlib/gtg/tools -I$(top_builddir)/extlib/gtg GTGLDFLAGS = $(top_builddir)/extlib/gtg/libgtg.la endif # AMEXTERNGTG SUBDIRS = extlib/ \ src/core/ \ src/modules/omp \ src/modules/mpi \ src/modules/starpu \ src/modules/pthread \ src/modules/stdio \ src/modules/memory \ src/modules/papi \ src/modules/cuda \ test/mpi \ test/openmp \ test/pptrace/automatic \ test/static \ test/stdio \ test/memory \ test/pthread \ test/automake if WITHDOC SUBDIRS += doc endif #WITHDOC pkgconfigdir = $(libdir)/pkgconfig pkgconfig_DATA = eztrace.pc if WITHDOC dist_man_MANS = doc/man/eztrace.1 \ doc/man/eztrace.old.1 \ doc/man/eztrace_avail.1 \ doc/man/eztrace_cc.1 \ doc/man/eztrace_convert.1 \ doc/man/eztrace_create_plugin.1 \ doc/man/eztrace_loaded.1 \ doc/man/eztrace_stats.1 endif #WITHDOC EXTRA_DIST = \ bootstrap \ ChangeLog \ README.stats \ test/mpi/Makefile.am \ test/mpi/mpi_openmp.c \ test/mpi/mpi_ring.c \ test/mpi/mpi_ping.c \ test/mpi/mpi_spawn.c \ test/mpi/persistent.c \ test/mpi/test_mpi.c \ test/mpi/mpi_multiring.c \ test/mpi/waitany.c \ test/mpi/allgather.c \ test/mpi/waitall.c \ test/openmp/Makefile.am \ test/openmp/openmp_simple.c \ test/openmp/openmp_nowait.f \ test/openmp/openmp_nowait_c.c \ test/openmp/test_task.c \ test/pthread/cond.c \ test/pthread/race_cond.c \ test/pthread/dummy_thread.c \ test/pthread/test_pthread.c \ test/pthread/test_sigsegv.c \ test/stdio/stdio.c \ test/memory/memory.c \ test/module_generator/example.tpl \ test/module_generator/example_application/example.c \ test/module_generator/example_application/example.h \ test/module_generator/example_application/main.c \ test/module_generator/example_application/Makefile \ example/README \ example/libexample_eztrace/example.c \ example/libexample_eztrace/example_ev_codes.h \ example/libexample_eztrace/eztrace_convert_example.c \ example/libexample_eztrace/Makefile \ example/libexample_orig/static_example.c \ example/libexample_orig/example.c \ example/libexample_orig/example.h \ example/libexample_orig/main.c \ example/libexample_orig/Makefile \ test/static/Makefile.in \ test/static/static.c \ test/static/staticlib.c \ test/static/staticlib_ev_codes.h \ test/static/eztrace_convert_staticlib.c \ test/pptrace/automatic/binary.c \ test/pptrace/automatic/common.h \ test/pptrace/automatic/errors.c \ test/pptrace/automatic/hijack.c \ test/pptrace/automatic/Makefile.in \ test/pptrace/automatic/opcodes.c \ test/pptrace/automatic/tracing.c \ test/pptrace/automatic/wait_open.c \ test/pptrace/automatic/testcase/Makefile \ test/pptrace/automatic/testcase/titi.c if WITHDOC EXTRA_DIST += doc/user_manual.tex endif #WITHDOC include_HEADERS = src/pptrace/types.h \ src/pptrace/pptrace.h \ src/pptrace/opcodes.h \ src/pptrace/memory.h \ src/pptrace/hijack.h \ src/pptrace/isize.h \ src/pptrace/binary.h \ src/pptrace/errors.h \ src/pptrace/tracing.h \ src/pptrace/os/linux/linux.h \ src/pptrace/os/linux/linux.c \ src/pptrace/arch/bfd.c if X86_64 include_HEADERS += src/pptrace/arch/x86_64/trace.c \ src/pptrace/arch/x86_64/opcode.c \ src/pptrace/arch/x86_64/hijack.c endif # X86_64 if ARM include_HEADERS += src/pptrace/arch/armv7/trace.c \ src/pptrace/arch/armv7/opcode.c endif # ARM include_HEADERS += src/pptrace/cpu/intel.c \ src/pptrace/cpu/arm.c SHELLTESTS = test/pptrace/automatic/errors.test \ test/pptrace/automatic/binary.test \ test/pptrace/automatic/tracing.test \ test/pptrace/automatic/opcodes.test \ test/pptrace/automatic/wait_open.test \ test/pptrace/automatic/hijack.test #TESTS=$(SHELLTESTS) $(CTESTS) eztrace-1.1-2/Makefile.in000066400000000000000000001113501265506773700152370ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @WITHDOC_TRUE@am__append_1 = doc @WITHDOC_TRUE@am__append_2 = doc/user_manual.tex @X86_64_TRUE@am__append_3 = src/pptrace/arch/x86_64/trace.c \ @X86_64_TRUE@ src/pptrace/arch/x86_64/opcode.c \ @X86_64_TRUE@ src/pptrace/arch/x86_64/hijack.c @ARM_TRUE@am__append_4 = src/pptrace/arch/armv7/trace.c \ @ARM_TRUE@ src/pptrace/arch/armv7/opcode.c subdir = . ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(top_srcdir)/configure \ $(am__configure_deps) $(am__include_HEADERS_DIST) \ $(am__DIST_COMMON) am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \ configure.lineno config.status.lineno mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = eztrace.pc src/core/input/Makefile.template \ test/pptrace/automatic/Makefile CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ ctags-recursive dvi-recursive html-recursive info-recursive \ install-data-recursive install-dvi-recursive \ install-exec-recursive install-html-recursive \ install-info-recursive install-pdf-recursive \ install-ps-recursive install-recursive installcheck-recursive \ installdirs-recursive pdf-recursive ps-recursive \ tags-recursive uninstall-recursive am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } man1dir = $(mandir)/man1 am__installdirs = "$(DESTDIR)$(man1dir)" "$(DESTDIR)$(pkgconfigdir)" \ "$(DESTDIR)$(includedir)" NROFF = nroff MANS = $(dist_man_MANS) DATA = $(pkgconfig_DATA) am__include_HEADERS_DIST = src/pptrace/types.h src/pptrace/pptrace.h \ src/pptrace/opcodes.h src/pptrace/memory.h \ src/pptrace/hijack.h src/pptrace/isize.h src/pptrace/binary.h \ src/pptrace/errors.h src/pptrace/tracing.h \ src/pptrace/os/linux/linux.h src/pptrace/os/linux/linux.c \ src/pptrace/arch/bfd.c src/pptrace/arch/x86_64/trace.c \ src/pptrace/arch/x86_64/opcode.c \ src/pptrace/arch/x86_64/hijack.c \ src/pptrace/arch/armv7/trace.c src/pptrace/arch/armv7/opcode.c \ src/pptrace/cpu/intel.c src/pptrace/cpu/arm.c HEADERS = $(include_HEADERS) RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \ distclean-recursive maintainer-clean-recursive am__recursive_targets = \ $(RECURSIVE_TARGETS) \ $(RECURSIVE_CLEAN_TARGETS) \ $(am__extra_recursive_targets) AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ cscope distdir dist dist-all distcheck am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags CSCOPE = cscope DIST_SUBDIRS = extlib/ src/core/ src/modules/omp src/modules/mpi \ src/modules/starpu src/modules/pthread src/modules/stdio \ src/modules/memory src/modules/papi src/modules/cuda test/mpi \ test/openmp test/pptrace/automatic test/static test/stdio \ test/memory test/pthread test/automake doc am__DIST_COMMON = $(dist_man_MANS) $(srcdir)/Makefile.in \ $(srcdir)/eztrace.pc.in \ $(top_srcdir)/src/core/input/Makefile.template.in \ $(top_srcdir)/test/pptrace/automatic/Makefile.in AUTHORS \ COPYING ChangeLog INSTALL NEWS README TODO compile \ config.guess config.sub depcomp install-sh ltmain.sh missing DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) distdir = $(PACKAGE)-$(VERSION) top_distdir = $(distdir) am__remove_distdir = \ if test -d "$(distdir)"; then \ find "$(distdir)" -type d ! -perm -200 -exec chmod u+w {} ';' \ && rm -rf "$(distdir)" \ || { sleep 5 && rm -rf "$(distdir)"; }; \ else :; fi am__post_remove_distdir = $(am__remove_distdir) am__relativize = \ dir0=`pwd`; \ sed_first='s,^\([^/]*\)/.*$$,\1,'; \ sed_rest='s,^[^/]*/*,,'; \ sed_last='s,^.*/\([^/]*\)$$,\1,'; \ sed_butlast='s,/*[^/]*$$,,'; \ while test -n "$$dir1"; do \ first=`echo "$$dir1" | sed -e "$$sed_first"`; \ if test "$$first" != "."; then \ if test "$$first" = ".."; then \ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \ else \ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \ if test "$$first2" = "$$first"; then \ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \ else \ dir2="../$$dir2"; \ fi; \ dir0="$$dir0"/"$$first"; \ fi; \ fi; \ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \ done; \ reldir="$$dir2" DIST_ARCHIVES = $(distdir).tar.gz GZIP_ENV = --best DIST_TARGETS = dist-gzip distuninstallcheck_listfiles = find . -type f -print am__distuninstallcheck_listfiles = $(distuninstallcheck_listfiles) \ | sed 's|^\./|$(prefix)/|' | grep -v '$(infodir)/dir$$' distcleancheck_listfiles = find . -type f -print ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ ACLOCAL_AMFLAGS = -I m4 @AMEXTERNLITL_FALSE@TLCFLAGS = -I$(top_srcdir)/extlib/litl/src -I$(top_builddir)/extlib/litl/src @AMEXTERNLITL_TRUE@TLCFLAGS = $(TL_CPPFLAGS) @AMEXTERNLITL_FALSE@TLLDFLAGS = $(top_builddir)/extlib/litl/src/liblitl.la @AMEXTERNLITL_TRUE@TLLDFLAGS = $(TL_LDFLAGS) @AMEXTERNLITL_FALSE@TLLIBADD = $(TL_LIB) @AMEXTERNLITL_TRUE@TLLIBADD = $(TL_LIB) @AMEXTERNGTG_FALSE@GTGCFLAGS = -I$(top_srcdir)/extlib/gtg/tools -I$(top_builddir)/extlib/gtg @AMEXTERNGTG_TRUE@GTGCFLAGS = $(GTG_CPPFLAGS) @AMEXTERNGTG_FALSE@GTGLDFLAGS = $(top_builddir)/extlib/gtg/libgtg.la @AMEXTERNGTG_TRUE@GTGLDFLAGS = $(GTG_LDFLAGS) SUBDIRS = extlib/ src/core/ src/modules/omp src/modules/mpi \ src/modules/starpu src/modules/pthread src/modules/stdio \ src/modules/memory src/modules/papi src/modules/cuda test/mpi \ test/openmp test/pptrace/automatic test/static test/stdio \ test/memory test/pthread test/automake $(am__append_1) pkgconfigdir = $(libdir)/pkgconfig pkgconfig_DATA = eztrace.pc @WITHDOC_TRUE@dist_man_MANS = doc/man/eztrace.1 \ @WITHDOC_TRUE@ doc/man/eztrace.old.1 \ @WITHDOC_TRUE@ doc/man/eztrace_avail.1 \ @WITHDOC_TRUE@ doc/man/eztrace_cc.1 \ @WITHDOC_TRUE@ doc/man/eztrace_convert.1 \ @WITHDOC_TRUE@ doc/man/eztrace_create_plugin.1 \ @WITHDOC_TRUE@ doc/man/eztrace_loaded.1 \ @WITHDOC_TRUE@ doc/man/eztrace_stats.1 EXTRA_DIST = bootstrap ChangeLog README.stats test/mpi/Makefile.am \ test/mpi/mpi_openmp.c test/mpi/mpi_ring.c test/mpi/mpi_ping.c \ test/mpi/mpi_spawn.c test/mpi/persistent.c test/mpi/test_mpi.c \ test/mpi/mpi_multiring.c test/mpi/waitany.c \ test/mpi/allgather.c test/mpi/waitall.c \ test/openmp/Makefile.am test/openmp/openmp_simple.c \ test/openmp/openmp_nowait.f test/openmp/openmp_nowait_c.c \ test/openmp/test_task.c test/pthread/cond.c \ test/pthread/race_cond.c test/pthread/dummy_thread.c \ test/pthread/test_pthread.c test/pthread/test_sigsegv.c \ test/stdio/stdio.c test/memory/memory.c \ test/module_generator/example.tpl \ test/module_generator/example_application/example.c \ test/module_generator/example_application/example.h \ test/module_generator/example_application/main.c \ test/module_generator/example_application/Makefile \ example/README example/libexample_eztrace/example.c \ example/libexample_eztrace/example_ev_codes.h \ example/libexample_eztrace/eztrace_convert_example.c \ example/libexample_eztrace/Makefile \ example/libexample_orig/static_example.c \ example/libexample_orig/example.c \ example/libexample_orig/example.h \ example/libexample_orig/main.c \ example/libexample_orig/Makefile test/static/Makefile.in \ test/static/static.c test/static/staticlib.c \ test/static/staticlib_ev_codes.h \ test/static/eztrace_convert_staticlib.c \ test/pptrace/automatic/binary.c \ test/pptrace/automatic/common.h \ test/pptrace/automatic/errors.c \ test/pptrace/automatic/hijack.c \ test/pptrace/automatic/Makefile.in \ test/pptrace/automatic/opcodes.c \ test/pptrace/automatic/tracing.c \ test/pptrace/automatic/wait_open.c \ test/pptrace/automatic/testcase/Makefile \ test/pptrace/automatic/testcase/titi.c $(am__append_2) include_HEADERS = src/pptrace/types.h src/pptrace/pptrace.h \ src/pptrace/opcodes.h src/pptrace/memory.h \ src/pptrace/hijack.h src/pptrace/isize.h src/pptrace/binary.h \ src/pptrace/errors.h src/pptrace/tracing.h \ src/pptrace/os/linux/linux.h src/pptrace/os/linux/linux.c \ src/pptrace/arch/bfd.c $(am__append_3) $(am__append_4) \ src/pptrace/cpu/intel.c src/pptrace/cpu/arm.c SHELLTESTS = test/pptrace/automatic/errors.test \ test/pptrace/automatic/binary.test \ test/pptrace/automatic/tracing.test \ test/pptrace/automatic/opcodes.test \ test/pptrace/automatic/wait_open.test \ test/pptrace/automatic/hijack.test all: all-recursive .SUFFIXES: am--refresh: Makefile @: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ echo ' cd $(srcdir) && $(AUTOMAKE) --gnu'; \ $(am__cd) $(srcdir) && $(AUTOMAKE) --gnu \ && exit 0; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ echo ' $(SHELL) ./config.status'; \ $(SHELL) ./config.status;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) $(SHELL) ./config.status --recheck $(top_srcdir)/configure: $(am__configure_deps) $(am__cd) $(srcdir) && $(AUTOCONF) $(ACLOCAL_M4): $(am__aclocal_m4_deps) $(am__cd) $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS) $(am__aclocal_m4_deps): eztrace.pc: $(top_builddir)/config.status $(srcdir)/eztrace.pc.in cd $(top_builddir) && $(SHELL) ./config.status $@ src/core/input/Makefile.template: $(top_builddir)/config.status $(top_srcdir)/src/core/input/Makefile.template.in cd $(top_builddir) && $(SHELL) ./config.status $@ test/pptrace/automatic/Makefile: $(top_builddir)/config.status $(top_srcdir)/test/pptrace/automatic/Makefile.in cd $(top_builddir) && $(SHELL) ./config.status $@ mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs distclean-libtool: -rm -f libtool config.lt install-man1: $(dist_man_MANS) @$(NORMAL_INSTALL) @list1=''; \ list2='$(dist_man_MANS)'; \ test -n "$(man1dir)" \ && test -n "`echo $$list1$$list2`" \ || exit 0; \ echo " $(MKDIR_P) '$(DESTDIR)$(man1dir)'"; \ $(MKDIR_P) "$(DESTDIR)$(man1dir)" || exit 1; \ { for i in $$list1; do echo "$$i"; done; \ if test -n "$$list2"; then \ for i in $$list2; do echo "$$i"; done \ | sed -n '/\.1[a-z]*$$/p'; \ fi; \ } | while read p; do \ if test -f $$p; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; echo "$$p"; \ done | \ sed -e 'n;s,.*/,,;p;h;s,.*\.,,;s,^[^1][0-9a-z]*$$,1,;x' \ -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,' | \ sed 'N;N;s,\n, ,g' | { \ list=; while read file base inst; do \ if test "$$base" = "$$inst"; then list="$$list $$file"; else \ echo " $(INSTALL_DATA) '$$file' '$(DESTDIR)$(man1dir)/$$inst'"; \ $(INSTALL_DATA) "$$file" "$(DESTDIR)$(man1dir)/$$inst" || exit $$?; \ fi; \ done; \ for i in $$list; do echo "$$i"; done | $(am__base_list) | \ while read files; do \ test -z "$$files" || { \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(man1dir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(man1dir)" || exit $$?; }; \ done; } uninstall-man1: @$(NORMAL_UNINSTALL) @list=''; test -n "$(man1dir)" || exit 0; \ files=`{ for i in $$list; do echo "$$i"; done; \ l2='$(dist_man_MANS)'; for i in $$l2; do echo "$$i"; done | \ sed -n '/\.1[a-z]*$$/p'; \ } | sed -e 's,.*/,,;h;s,.*\.,,;s,^[^1][0-9a-z]*$$,1,;x' \ -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,'`; \ dir='$(DESTDIR)$(man1dir)'; $(am__uninstall_files_from_dir) install-pkgconfigDATA: $(pkgconfig_DATA) @$(NORMAL_INSTALL) @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(pkgconfigdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(pkgconfigdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(pkgconfigdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(pkgconfigdir)" || exit $$?; \ done uninstall-pkgconfigDATA: @$(NORMAL_UNINSTALL) @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(pkgconfigdir)'; $(am__uninstall_files_from_dir) install-includeHEADERS: $(include_HEADERS) @$(NORMAL_INSTALL) @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(includedir)'"; \ $(MKDIR_P) "$(DESTDIR)$(includedir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_HEADER) $$files '$(DESTDIR)$(includedir)'"; \ $(INSTALL_HEADER) $$files "$(DESTDIR)$(includedir)" || exit $$?; \ done uninstall-includeHEADERS: @$(NORMAL_UNINSTALL) @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(includedir)'; $(am__uninstall_files_from_dir) # This directory's subdirectories are mostly independent; you can cd # into them and run 'make' without going through this Makefile. # To change the values of 'make' variables: instead of editing Makefiles, # (1) if the variable is set in 'config.status', edit 'config.status' # (which will cause the Makefiles to be regenerated when you run 'make'); # (2) otherwise, pass the desired values on the 'make' command line. $(am__recursive_targets): @fail=; \ if $(am__make_keepgoing); then \ failcom='fail=yes'; \ else \ failcom='exit 1'; \ fi; \ dot_seen=no; \ target=`echo $@ | sed s/-recursive//`; \ case "$@" in \ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ *) list='$(SUBDIRS)' ;; \ esac; \ for subdir in $$list; do \ echo "Making $$target in $$subdir"; \ if test "$$subdir" = "."; then \ dot_seen=yes; \ local_target="$$target-am"; \ else \ local_target="$$target"; \ fi; \ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ || eval $$failcom; \ done; \ if test "$$dot_seen" = "no"; then \ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ fi; test -z "$$fail" ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-recursive TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ include_option=--etags-include; \ empty_fix=.; \ else \ include_option=--include; \ empty_fix=; \ fi; \ list='$(SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ test ! -f $$subdir/TAGS || \ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \ fi; \ done; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-recursive CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscope: cscope.files test ! -s cscope.files \ || $(CSCOPE) -b -q $(AM_CSCOPEFLAGS) $(CSCOPEFLAGS) -i cscope.files $(CSCOPE_ARGS) clean-cscope: -rm -f cscope.files cscope.files: clean-cscope cscopelist cscopelist: cscopelist-recursive cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags -rm -f cscope.out cscope.in.out cscope.po.out cscope.files distdir: $(DISTFILES) $(am__remove_distdir) test -d "$(distdir)" || mkdir "$(distdir)" @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ $(am__make_dryrun) \ || test -d "$(distdir)/$$subdir" \ || $(MKDIR_P) "$(distdir)/$$subdir" \ || exit 1; \ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \ $(am__relativize); \ new_distdir=$$reldir; \ dir1=$$subdir; dir2="$(top_distdir)"; \ $(am__relativize); \ new_top_distdir=$$reldir; \ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \ ($(am__cd) $$subdir && \ $(MAKE) $(AM_MAKEFLAGS) \ top_distdir="$$new_top_distdir" \ distdir="$$new_distdir" \ am__remove_distdir=: \ am__skip_length_check=: \ am__skip_mode_fix=: \ distdir) \ || exit 1; \ fi; \ done -test -n "$(am__skip_mode_fix)" \ || find "$(distdir)" -type d ! -perm -755 \ -exec chmod u+rwx,go+rx {} \; -o \ ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \ ! -type d ! -perm -400 -exec chmod a+r {} \; -o \ ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \ || chmod -R a+r "$(distdir)" dist-gzip: distdir tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz $(am__post_remove_distdir) dist-bzip2: distdir tardir=$(distdir) && $(am__tar) | BZIP2=$${BZIP2--9} bzip2 -c >$(distdir).tar.bz2 $(am__post_remove_distdir) dist-lzip: distdir tardir=$(distdir) && $(am__tar) | lzip -c $${LZIP_OPT--9} >$(distdir).tar.lz $(am__post_remove_distdir) dist-xz: distdir tardir=$(distdir) && $(am__tar) | XZ_OPT=$${XZ_OPT--e} xz -c >$(distdir).tar.xz $(am__post_remove_distdir) dist-tarZ: distdir @echo WARNING: "Support for distribution archives compressed with" \ "legacy program 'compress' is deprecated." >&2 @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z $(am__post_remove_distdir) dist-shar: distdir @echo WARNING: "Support for shar distribution archives is" \ "deprecated." >&2 @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 shar $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).shar.gz $(am__post_remove_distdir) dist-zip: distdir -rm -f $(distdir).zip zip -rq $(distdir).zip $(distdir) $(am__post_remove_distdir) dist dist-all: $(MAKE) $(AM_MAKEFLAGS) $(DIST_TARGETS) am__post_remove_distdir='@:' $(am__post_remove_distdir) # This target untars the dist file and tries a VPATH configuration. Then # it guarantees that the distribution is self-contained by making another # tarfile. distcheck: dist case '$(DIST_ARCHIVES)' in \ *.tar.gz*) \ GZIP=$(GZIP_ENV) gzip -dc $(distdir).tar.gz | $(am__untar) ;;\ *.tar.bz2*) \ bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\ *.tar.lz*) \ lzip -dc $(distdir).tar.lz | $(am__untar) ;;\ *.tar.xz*) \ xz -dc $(distdir).tar.xz | $(am__untar) ;;\ *.tar.Z*) \ uncompress -c $(distdir).tar.Z | $(am__untar) ;;\ *.shar.gz*) \ GZIP=$(GZIP_ENV) gzip -dc $(distdir).shar.gz | unshar ;;\ *.zip*) \ unzip $(distdir).zip ;;\ esac chmod -R a-w $(distdir) chmod u+w $(distdir) mkdir $(distdir)/_build $(distdir)/_build/sub $(distdir)/_inst chmod a-w $(distdir) test -d $(distdir)/_build || exit 0; \ dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \ && dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \ && am__cwd=`pwd` \ && $(am__cd) $(distdir)/_build/sub \ && ../../configure \ $(AM_DISTCHECK_CONFIGURE_FLAGS) \ $(DISTCHECK_CONFIGURE_FLAGS) \ --srcdir=../.. --prefix="$$dc_install_base" \ && $(MAKE) $(AM_MAKEFLAGS) \ && $(MAKE) $(AM_MAKEFLAGS) dvi \ && $(MAKE) $(AM_MAKEFLAGS) check \ && $(MAKE) $(AM_MAKEFLAGS) install \ && $(MAKE) $(AM_MAKEFLAGS) installcheck \ && $(MAKE) $(AM_MAKEFLAGS) uninstall \ && $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \ distuninstallcheck \ && chmod -R a-w "$$dc_install_base" \ && ({ \ (cd ../.. && umask 077 && mkdir "$$dc_destdir") \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \ distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \ } || { rm -rf "$$dc_destdir"; exit 1; }) \ && rm -rf "$$dc_destdir" \ && $(MAKE) $(AM_MAKEFLAGS) dist \ && rm -rf $(DIST_ARCHIVES) \ && $(MAKE) $(AM_MAKEFLAGS) distcleancheck \ && cd "$$am__cwd" \ || exit 1 $(am__post_remove_distdir) @(echo "$(distdir) archives ready for distribution: "; \ list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \ sed -e 1h -e 1s/./=/g -e 1p -e 1x -e '$$p' -e '$$x' distuninstallcheck: @test -n '$(distuninstallcheck_dir)' || { \ echo 'ERROR: trying to run $@ with an empty' \ '$$(distuninstallcheck_dir)' >&2; \ exit 1; \ }; \ $(am__cd) '$(distuninstallcheck_dir)' || { \ echo 'ERROR: cannot chdir into $(distuninstallcheck_dir)' >&2; \ exit 1; \ }; \ test `$(am__distuninstallcheck_listfiles) | wc -l` -eq 0 \ || { echo "ERROR: files left after uninstall:" ; \ if test -n "$(DESTDIR)"; then \ echo " (check DESTDIR support)"; \ fi ; \ $(distuninstallcheck_listfiles) ; \ exit 1; } >&2 distcleancheck: distclean @if test '$(srcdir)' = . ; then \ echo "ERROR: distcleancheck can only run from a VPATH build" ; \ exit 1 ; \ fi @test `$(distcleancheck_listfiles) | wc -l` -eq 0 \ || { echo "ERROR: files left in build directory after distclean:" ; \ $(distcleancheck_listfiles) ; \ exit 1; } >&2 check-am: all-am check: check-recursive all-am: Makefile $(MANS) $(DATA) $(HEADERS) installdirs: installdirs-recursive installdirs-am: for dir in "$(DESTDIR)$(man1dir)" "$(DESTDIR)$(pkgconfigdir)" "$(DESTDIR)$(includedir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-recursive install-exec: install-exec-recursive install-data: install-data-recursive uninstall: uninstall-recursive install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-recursive install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-recursive clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-recursive -rm -f $(am__CONFIG_DISTCLEAN_FILES) -rm -f Makefile distclean-am: clean-am distclean-generic distclean-libtool \ distclean-tags dvi: dvi-recursive dvi-am: html: html-recursive html-am: info: info-recursive info-am: install-data-am: install-includeHEADERS install-man \ install-pkgconfigDATA install-dvi: install-dvi-recursive install-dvi-am: install-exec-am: install-html: install-html-recursive install-html-am: install-info: install-info-recursive install-info-am: install-man: install-man1 install-pdf: install-pdf-recursive install-pdf-am: install-ps: install-ps-recursive install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-recursive -rm -f $(am__CONFIG_DISTCLEAN_FILES) -rm -rf $(top_srcdir)/autom4te.cache -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-recursive mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-recursive pdf-am: ps: ps-recursive ps-am: uninstall-am: uninstall-includeHEADERS uninstall-man \ uninstall-pkgconfigDATA uninstall-man: uninstall-man1 .MAKE: $(am__recursive_targets) install-am install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am \ am--refresh check check-am clean clean-cscope clean-generic \ clean-libtool cscope cscopelist-am ctags ctags-am dist \ dist-all dist-bzip2 dist-gzip dist-lzip dist-shar dist-tarZ \ dist-xz dist-zip distcheck distclean distclean-generic \ distclean-libtool distclean-tags distcleancheck distdir \ distuninstallcheck dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-includeHEADERS install-info \ install-info-am install-man install-man1 install-pdf \ install-pdf-am install-pkgconfigDATA install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ installdirs-am maintainer-clean maintainer-clean-generic \ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \ ps ps-am tags tags-am uninstall uninstall-am \ uninstall-includeHEADERS uninstall-man uninstall-man1 \ uninstall-pkgconfigDATA .PRECIOUS: Makefile #TESTS=$(SHELLTESTS) $(CTESTS) # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/NEWS000066400000000000000000000000001265506773700136560ustar00rootroot00000000000000eztrace-1.1-2/README000066400000000000000000000361071265506773700140600ustar00rootroot00000000000000 What is EZTrace? ============================================= EZTrace is a tool that aims at generating automatically execution traces from HPC (High Performance Computing) programs. It generates execution trace files that can be interpreted by visualization tools such as ViTE. Requirements ============================================= In order to run EZTrace, you need the following software: * autoconf 2.63; * libelf or libbfd. Otherwise, only eztrace.old would be installed and the functionality would be limited, see the FAQ section. On Debian, libelf can be installed from command line by the following command: apt-get install libelf-dev * [Optional] Any MPI implementation. Getting EZTrace ============================================= * You can get the latest stable release on EZTrace website: http://eztrace.gforge.inria.fr/ * Current development version is available via GIT git clone git://scm.gforge.inria.fr/eztrace/eztrace.git After getting the latest development version (from GIT), you need to run './bootstrap' and only then build the tool. Building EZTrace ============================================= At first, you need to configure EZTrace by invoking the configure script: $ ./configure --prefix= Options to configure. You can pass several options to the configure script for specifying where it should find the needed libraries: --with-litl=$LITL_ROOT or ARG(=no): specify where LiTL is installed --with-gtg=$GTG_ROOT: specify where GTG is installed. --with-mpi=$MPI_ROOT: specify where MPI is installed. The mpi.h file must be located in the $MPI_ROOT/include/ directory. --with-mpi-include=: specify the directory that contains the mpi.h file. --with-papi=$PAPI_ROOT: specify where PAPI is installed. The papi.h file must be located in the $PAPI_ROOT/include directory and libpapi should be in $PAPI_ROOT/lib Once EZTrace is configured, just type: $ make $ make install Using EZTrace ============================================= Choosing the functions to instrument ------------------------------------ First, you should select the functions you want to instrument in your application. For this, you can set the EZTRACE_TRACE environment variable to the list of plugins that should be used: $ export EZTRACE_TRACE="pthread mpi" You can get the list of available plugins with the eztrace_avail command: $ eztrace_avail 3 stdio Module for stdio functions (read, write, select, poll, etc.) 2 pthread Module for PThread synchronization functions (mutex, semaphore, spinlock, etc.) 6 papi Module for PAPI Performance counters 1 omp Module for OpenMP parallel regions 4 mpi Module for MPI functions 5 memory Module for memory functions (malloc, free, etc.) You can get the list of selected modules with the eztrace_loaded command: $ export EZTRACE_TRACE="pthread mpi" $ eztrace_loaded 2 pthread Module for PThread synchronization functions (mutex, semaphore, spinlock, etc.) 4 mpi Module for MPI functions NB: you can also select the modules to load when invoking eztrace using the -t option. For instance: $ eztrace -t "memory pthread" ./my_program Creating execution traces ------------------------- Once the list of plugins is selected, you can run your application with eztrace. For example: $ eztrace ./my_program my_arg1 my_arg2 This command line executes your program and generates a trace file in the /tmp directory (usually the file is named /tmp/_eztrace_log_rank_#rank). Using EZTrace with MPI ---------------------- EZTrace needs to instrument each MPI process. Thus, you can run the following command: $ mpirun -np 16 eztrace ./my_program When your application ends. Each process writes a file named /tmp/_eztrace_log_rank_. Changing The output directory ----------------------------- By default, each process saves its trace in the local /tmp directory. You can change this by setting EZTRACE_TRACE_DIR or by using the -o option in eztrace: $ export EZTRACE_TRACE_DIR=$HOME/traces or $ mpirun -np 16 eztrace -o $HOME/traces ./my_program Merging execution traces ------------------------ Once the execution traces are recorded, you can merge and convert them into a file format that can be read by your visualization software: $ eztrace_convert -o my_paje.trace /tmp/_eztrace_log_rank_0 /tmp/_eztrace_log_rank_1 This converts the trace files into the Paje format. If gtg is installed with OTF support (this is enabled by default), you can choose to convert into the OTF file format with the -t OTF option: $ eztrace_convert -t OTF /tmp/_eztrace_log_rank_0 /tmp/_eztrace_log_rank_1 Filtering events ---------------- You can select the plugins to use for the conversion phase by using the EZTRACE_TRACE variable: if your traces contains MPI and OpenMP events, setting EZTRACE_TRACE to mpi and calling eztrace_convert creates an output trace that only contains MPI events. Computing statistics -------------------- Instead of creating a merged trace file, you can tell EZTrace to compute statistics on the recorded traces: $ eztrace_stats /tmp/_eztrace_log_rank_0 /tmp/_eztrace_log_rank_1 [...] PThread: ------- 6 locks acquired MPI: --- 27 messages sent MPI_RECV:10 calls MPI_BARRIER:11 calls 163 events handled Defining custom plugins ------------------------ Since EZTrace works with plugins, you can create one and instrument the functions that you want. An example of plugin is available in the example directory. Once your plugin is created, you should tell EZTrace where to find it. For this, just set the EZTRACE_LIBRARY_PATH to the appropriate directory(-ies): $ export EZTRACE_LIBRARY_PATH=: $ eztrace_avail 3 stdio Module for stdio functions (read, write, select, poll, etc.) 2 pthread Module for PThread synchronization functions (mutex, semaphore, spinlock, etc.) 6 papi Module for PAPI Performance counters 1 omp Module for OpenMP parallel regions 4 mpi Module for MPI functions 5 memory Module for memory functions (malloc, free, etc.) 99 plugin1 Example module for libplugin1 98 plugin2 Example module for the plugin2 library You can also use the -l option when invoking eztrace: $ eztrace -l : ./my_program Generating custom plugins -------------------------- You can generate one plugin and instrument the functions you want to. In order to generate your plugin, you need to create a file containing: * The name of the library you want to trace (libNAME.so) * A brief description of the library (optional) * An ID to identify the module (0? is reserved for eztrace internal use. Thus, you can use any between 10 and ff) * The prototype of the functions you want to instrument Basically, the file should look like that: BEGIN_MODULE NAME example_lib DESC "module for the example library" ID 99 int example_do_event(int n) double example_function1(double* array, int array_size) END_MODULE Now use eztrace_create_plugin to generate the plugin source code: $ eztrace_create_plugin example.tpl New Module Module name: 'example_lib' Module description: '"module for the example library"' Module id: '99' emulate record_state for 'example_do_event' Function 'example_do_event' done emulate record_state for 'example_function1' Function 'example_function1' done End of Module example_lib The source code is generated in the output directory. Just type: $ make Now set the EZTRACE_LIBRARY_PATH to the appropriate directory and you are good to go. You can also specify (in the example.tpl file) the way a function is depicted in the output trace. For instance: int submit_job(int* array, int array_size) BEGIN ADD_VAR("job counter", 1) END Specifies that when the submit_job function is called, the output trace should increment the "job counter" variable. You can now track the value of a variable! The test/module_generator directory contains several scripts that demonstrate the various commands available. Environment variables ===================== Here is a list of the environment variables that you can use for tuning EZTrace. * General-purpose variables: - EZTRACE_TRACE_DIR: specifies the directory in which the traces are created (default: /tmp). You can also use the -o option in eztrace. - EZTRACE_LIBRARY_PATH: specifies the directories in which eztrace can find eztrace modules (default: none) You can also use the -l option in eztrace. - EZTRACE_TRACE: specifies the list of eztrace modules to load (default: the list of available modules) You can also use the -t option in eztrace. - EZTRACE_BUFFER_SIZE: specifies the size (in byte) of the buffer in which eztrace stores events (default: 16MB) - EZTRACE_FLUSH: specifies the behavior of eztrace when the event buffer is full. If set to 1, the buffer is flushed. This permits to record trace larger than EZTRACE_BUFFER_SIZE, but this may impact the application performance. If set to 0, additional event won't be recorded. The trace is thus truncated, but there is no impact on performance. (default: 0). You can also enable buffer flushing with the -f option in eztrace. - EZTRACE_SIGALARM: ask EZTrace to stop the application every x ms in order to collect information (such as hardware counters). (default: 0) * Error-handling variables - EZTRACE_NO_SIGNAL_HANDLER: disables eztrace signal handling (default: 0) * Hardware counters-related variables: - EZTRACE_PAPI_COUNTERS: selects hardware events to trace using the PAPI library, e.g. export EZTRACE_PAPI_COUNTERS="PAPI_L3_TCM PAPI_FP_INS". Please note that the list of supported events as well as the number of events, which can be traced simultaneously, vary depending on the processor type. This information can be retrieved using 'papi_avail' and the processor documentation. - EZTRACE_PAPI_SAMPLE_INTERVAL: select the minimum interval (in microseconds) between each check of the PAPI counters (default: 100) * MPI-related variables: - EZTRACE_MPI_DUMP_MESSAGES: tells EZTrace to dump the list of messages into a file. You can then compute your own statistics on MPI messages. * CUDA-related variables: - EZTRACE_CUDA_CUPTI_DISABLED: disable the use of CUPTI in EZTrace. This option disables the recording of events that happen on the GPU. * submodules variables: - EZTRACE_USE_GETCPU: enable/disable the getcpu module (default: disabled) - EZTRACE_GETCPU_INTERVAL: specify the interval (in microsecond) between each probe of the getcpu module (default: 10000) Known limitations ================= * The CUDA module has not been tested on multi-GPU architecture. It is likely to fail in such situation * If EZTrace is compiled with a particular MPI implementation (OpenMPI for instance) it won't work if you run your application with another (MPICH2 for instance). So make sure your application uses the same MPI implementation as EZTrace. Frequently Asked Questions ============================================= Q: What would happen if I do not install neither libelf nor libbfd before the installation of EZTrace? A: In that case, the configuration of EZTrace would succeed with a warning regarding the missing library. And, after the installation only eztrace.old would be available. The EZTrace launcher (eztrace) that uses pptrace would not work. Q: When I run my MPI application with EZTrace, all the processes generate /tmp/_eztrace_log_rank_1 files. What's going wrong? A: This happens when EZTrace fails to intercept calls to MPI_Init (or MPI_Init_thread). There may be several reasons for that: * EZTrace MPI module was not compiled. For intercepting calls to MPI functions, you need the MPI module in your installation (look for the $EZTRACE_ROOT/lib/libeztrace-autostart-mpi.so file). If you don't see that file, it means that something went wrong during the configuration of EZTrace, so check for errors or warnings in you config.log file. * You specified the list of modules to use and the MPI module wasn't in there. Check your EZTRACE_TRACE variable or use eztrace_loaded. If you still experience problems, please contact EZTrace development team so that we can fix your problem. Q: What if I don't want to trace my whole application, but only a small part of it? A: Then, you can call eztrace_start() and eztrace_stop() in your code to specify the part to be traced. You will need to #include and to link with libeztrace. Then, just run your application as usual (i.e. $ ./my_program my_arg1) Q: I need to trace my program while using gdb, how can I do that? A: Just add the -d option to eztrace to enable gdb: $ eztrace -d ./my_program my_arg1 my_arg2 Please note that this should be applied only when a bug occurs while using EZTrace. Q: I want my trace to be saved in a specific directory, how can I do that? A: By default, EZTrace saves the trace in the /tmp directory. You can change this by setting EZTRACE_TRACE_DIR or by providing the -o option to eztrace. Q: What if I don't care about OpenMP and I only want to see MPI communication? A: You can set EZTRACE_TRACE to the list of "modules" you want to activate. By default, all the available modules are enabled, but you can tell EZTrace to trace only MPI or OpenMP functions: $ export EZTRACE_TRACE=mpi $ export EZTRACE_TRACE=omp $ export EZTRACE_TRACE="omp mpi" Q: Can EZTrace generate an OTF trace file so that I can visualize it with Vampir? A: Yes, since EZTrace relies on GTG for writing output traces, it can generate OTF trace files. When converting the trace with eztrace_convert, just add the -t OTF option: $ eztrace_convert -t OTF /tmp/_eztrace_log_rank_0 /tmp/_eztrace_log_rank_1 Q: I don't have any error during installation, but I can't find the eztrace program. All I've got is an eztrace.preload file. What happened ? A: The eztrace program relies on libelf or libbfd for instrumenting applications. If neither of these libraries were found during configure, the program is not created. You can either fall back to using eztrace.old (in that case, only instrumentation through shared libraries is supported); or you can install either libelf (on Debian: install the libelf-dev package) or libbfd (on Debian: install the binutils-dev package). Q: I don't have libbfd on my system. Do I really need it ? A: The eztrace program relies on libbfd for instrumenting applications. If it is not available on your system, you can disable pptrace (the part that instruments application) by passing --enable-pptrace=no to configure. In that case, the eztrace program is not created, but you can use eztrace.preload instead. Troubleshooting ============================================= If you encounter a bug or want some explanation about EZTrace, feel free to ask to the developers: * On the developer mailing list * On our IRC channel: - server: chat.freenode.net - channel: #eztrace eztrace-1.1-2/README.stats000066400000000000000000000052711265506773700152130ustar00rootroot00000000000000When running eztrace_stats on a set of traces of an MPI application, EZTrace prints various statistics on the MPI messages (average size of messages, time spent waiting for an incoming message, etc.) eztrace_stats also create a set of files that depict the behavior of the application. These files are stored in /tmp/eztrace_stats_USER by default (the output directory can be specified by passing the -o option to eztrace_stats) The following files are created: - communication_matrix.nb_messages.dat This file contains the communication matrix with the number of messages sent from an MPI process to the other processes. - communication_matrix.message_size.dat This file contains the communication matrix with the total size of messages sent from an MPI process to the other processes. - message_size.dat This file contains the distribution of message size - message_size.gp This GNUplot script exploits message_size.dat Additionnaly, you can ask eztrace_stats to create a file that contains the list of messages that were exchanged. This can be done by setting EZTRACE_MPI_DUMP_MESSAGES to 1. After running eztrace_stats, the file ${USER}_eztrace_message_dump is created. Here is an example of such file: -------- # src dest len tag Isend_tick SWait_tick Wait_done_tick Irecv_tick RWait_tick Wait_done_tick Sender_request Receiver_request 13 0 61440 1b58 115542014654 115542048379 115626670523 115541830089 115542030875 115848696986 0x296b540 0x36f4cc8 7 0 61440 1770 115542396436 115542398916 115625999773 115541829660 115542030702 115848696830 0x33d43e8 0x36f4ca0 -------- Each line correspond to a message that was exchanged. The columns correspond to: - src: the rank of the MPI process that sent the message - dest: the rank of the MPI process that received the message - len: the length (in byte) of the message - tag: the MPI tag (in hexadecimal) that was used - Isend_tick: the date (in nanosecond) when the sending process called MPI_Isend (or entered MPI_Send) - SWait_tick: the date (in nanosecond) when the sending process called MPI_Wait (or entered MPI_Send) - Wait_done_tick: the date (in nanosecond) when the sending process left MPI_Wait (or left MPI_Send) - Irecv_tick: the date (in nanosecond) when the receiving process called MPI_Irecv (or entered MPI_Recv) - Rwait_tick: the date (in nanosecond) when the receiving process called MPI_Wait (or entered MPI_Recv) - Wait_done_tick: the date (in nanosecond) when the receiving process left MPI_Wait (or left MPI_Recv) - Sender_request: the MPI_Request that was passed to MPI_Isend - Receiver_request: the MPI_Request that was passed to MPI_Irecveztrace-1.1-2/TODO000066400000000000000000000027241265506773700136660ustar00rootroot00000000000000Bugs: ===== * ./configure --prefix=/usr && make -j1 && make DESTDIR=/quelque/part/ install Features ======== * add support for MPI-IO * Add OpenCL support ? * event filtering: allow for filtering events. For instance: * don't record event foo if its depth is > n * don't record event foo if it's called more than x times * don't record any event whose depth is > n * improve module generator: include statistics * improve statistics: compute the duration of functions * add a program that list the functions that are intercepted/ permits to select the functions to intercept eztrace_create_plugin: ===================== * Need to add the "#include " automatically when a function take a variable number of parameters (ie. void func(...) ) * add support for functions that a pointer to a function as a parameter (ie. void func( void (*func_name)(int*) ) ) OpenMP ====== * During a parallel section, we should modify the state of each thread by adding the "team id" (~ parallel section identifier) * Fix the memory leak in parallel_start() MPI === * when using configuring eztrace to use OpenMPI, calling "eztrace prog" may raise an 'undefined symbol' error if the program does not use OpenMPI. This is because some symbols are defined in OpenMPI's libmpi.so. When eztrace's libmpi.so is loaded, these symbols are needed. Misc. ==== * update the documentation. The creation of user-defined plugins should be well documented (at least on the web page) ! eztrace-1.1-2/aclocal.m4000066400000000000000000001225111265506773700150330ustar00rootroot00000000000000# generated automatically by aclocal 1.15 -*- Autoconf -*- # Copyright (C) 1996-2014 Free Software Foundation, Inc. # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. m4_ifndef([AC_CONFIG_MACRO_DIRS], [m4_defun([_AM_CONFIG_MACRO_DIRS], [])m4_defun([AC_CONFIG_MACRO_DIRS], [_AM_CONFIG_MACRO_DIRS($@)])]) m4_ifndef([AC_AUTOCONF_VERSION], [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.69],, [m4_warning([this file was generated for autoconf 2.69. You have another version of autoconf. It may work, but is not guaranteed to. If you have problems, you may need to regenerate the build system entirely. To do so, use the procedure documented by the package, typically 'autoreconf'.])]) # Copyright (C) 2002-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_AUTOMAKE_VERSION(VERSION) # ---------------------------- # Automake X.Y traces this macro to ensure aclocal.m4 has been # generated from the m4 files accompanying Automake X.Y. # (This private macro should not be called outside this file.) AC_DEFUN([AM_AUTOMAKE_VERSION], [am__api_version='1.15' dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to dnl require some minimum version. Point them to the right macro. m4_if([$1], [1.15], [], [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl ]) # _AM_AUTOCONF_VERSION(VERSION) # ----------------------------- # aclocal traces this macro to find the Autoconf version. # This is a private macro too. Using m4_define simplifies # the logic in aclocal, which can simply ignore this definition. m4_define([_AM_AUTOCONF_VERSION], []) # AM_SET_CURRENT_AUTOMAKE_VERSION # ------------------------------- # Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced. # This function is AC_REQUIREd by AM_INIT_AUTOMAKE. AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], [AM_AUTOMAKE_VERSION([1.15])dnl m4_ifndef([AC_AUTOCONF_VERSION], [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl _AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))]) # AM_AUX_DIR_EXPAND -*- Autoconf -*- # Copyright (C) 2001-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets # $ac_aux_dir to '$srcdir/foo'. In other projects, it is set to # '$srcdir', '$srcdir/..', or '$srcdir/../..'. # # Of course, Automake must honor this variable whenever it calls a # tool from the auxiliary directory. The problem is that $srcdir (and # therefore $ac_aux_dir as well) can be either absolute or relative, # depending on how configure is run. This is pretty annoying, since # it makes $ac_aux_dir quite unusable in subdirectories: in the top # source directory, any form will work fine, but in subdirectories a # relative path needs to be adjusted first. # # $ac_aux_dir/missing # fails when called from a subdirectory if $ac_aux_dir is relative # $top_srcdir/$ac_aux_dir/missing # fails if $ac_aux_dir is absolute, # fails when called from a subdirectory in a VPATH build with # a relative $ac_aux_dir # # The reason of the latter failure is that $top_srcdir and $ac_aux_dir # are both prefixed by $srcdir. In an in-source build this is usually # harmless because $srcdir is '.', but things will broke when you # start a VPATH build or use an absolute $srcdir. # # So we could use something similar to $top_srcdir/$ac_aux_dir/missing, # iff we strip the leading $srcdir from $ac_aux_dir. That would be: # am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"` # and then we would define $MISSING as # MISSING="\${SHELL} $am_aux_dir/missing" # This will work as long as MISSING is not called from configure, because # unfortunately $(top_srcdir) has no meaning in configure. # However there are other variables, like CC, which are often used in # configure, and could therefore not use this "fixed" $ac_aux_dir. # # Another solution, used here, is to always expand $ac_aux_dir to an # absolute PATH. The drawback is that using absolute paths prevent a # configured tree to be moved without reconfiguration. AC_DEFUN([AM_AUX_DIR_EXPAND], [AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl # Expand $ac_aux_dir to an absolute path. am_aux_dir=`cd "$ac_aux_dir" && pwd` ]) # AM_CONDITIONAL -*- Autoconf -*- # Copyright (C) 1997-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_CONDITIONAL(NAME, SHELL-CONDITION) # ------------------------------------- # Define a conditional. AC_DEFUN([AM_CONDITIONAL], [AC_PREREQ([2.52])dnl m4_if([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])], [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl AC_SUBST([$1_TRUE])dnl AC_SUBST([$1_FALSE])dnl _AM_SUBST_NOTMAKE([$1_TRUE])dnl _AM_SUBST_NOTMAKE([$1_FALSE])dnl m4_define([_AM_COND_VALUE_$1], [$2])dnl if $2; then $1_TRUE= $1_FALSE='#' else $1_TRUE='#' $1_FALSE= fi AC_CONFIG_COMMANDS_PRE( [if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then AC_MSG_ERROR([[conditional "$1" was never defined. Usually this means the macro was only invoked conditionally.]]) fi])]) # Copyright (C) 1999-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # There are a few dirty hacks below to avoid letting 'AC_PROG_CC' be # written in clear, in which case automake, when reading aclocal.m4, # will think it sees a *use*, and therefore will trigger all it's # C support machinery. Also note that it means that autoscan, seeing # CC etc. in the Makefile, will ask for an AC_PROG_CC use... # _AM_DEPENDENCIES(NAME) # ---------------------- # See how the compiler implements dependency checking. # NAME is "CC", "CXX", "OBJC", "OBJCXX", "UPC", or "GJC". # We try a few techniques and use that to set a single cache variable. # # We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was # modified to invoke _AM_DEPENDENCIES(CC); we would have a circular # dependency, and given that the user is not expected to run this macro, # just rely on AC_PROG_CC. AC_DEFUN([_AM_DEPENDENCIES], [AC_REQUIRE([AM_SET_DEPDIR])dnl AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl AC_REQUIRE([AM_MAKE_INCLUDE])dnl AC_REQUIRE([AM_DEP_TRACK])dnl m4_if([$1], [CC], [depcc="$CC" am_compiler_list=], [$1], [CXX], [depcc="$CXX" am_compiler_list=], [$1], [OBJC], [depcc="$OBJC" am_compiler_list='gcc3 gcc'], [$1], [OBJCXX], [depcc="$OBJCXX" am_compiler_list='gcc3 gcc'], [$1], [UPC], [depcc="$UPC" am_compiler_list=], [$1], [GCJ], [depcc="$GCJ" am_compiler_list='gcc3 gcc'], [depcc="$$1" am_compiler_list=]) AC_CACHE_CHECK([dependency style of $depcc], [am_cv_$1_dependencies_compiler_type], [if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_$1_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp` fi am__universal=false m4_case([$1], [CC], [case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac], [CXX], [case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac]) for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_$1_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_$1_dependencies_compiler_type=none fi ]) AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type]) AM_CONDITIONAL([am__fastdep$1], [ test "x$enable_dependency_tracking" != xno \ && test "$am_cv_$1_dependencies_compiler_type" = gcc3]) ]) # AM_SET_DEPDIR # ------------- # Choose a directory name for dependency files. # This macro is AC_REQUIREd in _AM_DEPENDENCIES. AC_DEFUN([AM_SET_DEPDIR], [AC_REQUIRE([AM_SET_LEADING_DOT])dnl AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl ]) # AM_DEP_TRACK # ------------ AC_DEFUN([AM_DEP_TRACK], [AC_ARG_ENABLE([dependency-tracking], [dnl AS_HELP_STRING( [--enable-dependency-tracking], [do not reject slow dependency extractors]) AS_HELP_STRING( [--disable-dependency-tracking], [speeds up one-time build])]) if test "x$enable_dependency_tracking" != xno; then am_depcomp="$ac_aux_dir/depcomp" AMDEPBACKSLASH='\' am__nodep='_no' fi AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno]) AC_SUBST([AMDEPBACKSLASH])dnl _AM_SUBST_NOTMAKE([AMDEPBACKSLASH])dnl AC_SUBST([am__nodep])dnl _AM_SUBST_NOTMAKE([am__nodep])dnl ]) # Generate code to set up dependency tracking. -*- Autoconf -*- # Copyright (C) 1999-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_OUTPUT_DEPENDENCY_COMMANDS # ------------------------------ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], [{ # Older Autoconf quotes --file arguments for eval, but not when files # are listed without --file. Let's play safe and only enable the eval # if we detect the quoting. case $CONFIG_FILES in *\'*) eval set x "$CONFIG_FILES" ;; *) set x $CONFIG_FILES ;; esac shift for mf do # Strip MF so we end up with the name of the file. mf=`echo "$mf" | sed -e 's/:.*$//'` # Check whether this is an Automake generated Makefile or not. # We used to match only the files named 'Makefile.in', but # some people rename them; so instead we look at the file content. # Grep'ing the first line is not enough: some people post-process # each Makefile.in and add a new line on top of each file to say so. # Grep'ing the whole file is not good either: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then dirpart=`AS_DIRNAME("$mf")` else continue fi # Extract the definition of DEPDIR, am__include, and am__quote # from the Makefile without running 'make'. DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` test -z "$DEPDIR" && continue am__include=`sed -n 's/^am__include = //p' < "$mf"` test -z "$am__include" && continue am__quote=`sed -n 's/^am__quote = //p' < "$mf"` # Find all dependency output files, they are included files with # $(DEPDIR) in their names. We invoke sed twice because it is the # simplest approach to changing $(DEPDIR) to its actual value in the # expansion. for file in `sed -n " s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do # Make sure the directory exists. test -f "$dirpart/$file" && continue fdir=`AS_DIRNAME(["$file"])` AS_MKDIR_P([$dirpart/$fdir]) # echo "creating $dirpart/$file" echo '# dummy' > "$dirpart/$file" done done } ])# _AM_OUTPUT_DEPENDENCY_COMMANDS # AM_OUTPUT_DEPENDENCY_COMMANDS # ----------------------------- # This macro should only be invoked once -- use via AC_REQUIRE. # # This code is only required when automatic dependency tracking # is enabled. FIXME. This creates each '.P' file that we will # need in order to bootstrap the dependency handling code. AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS], [AC_CONFIG_COMMANDS([depfiles], [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS], [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"]) ]) # Do all the work for Automake. -*- Autoconf -*- # Copyright (C) 1996-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This macro actually does too much. Some checks are only needed if # your package does certain things. But this isn't really a big deal. dnl Redefine AC_PROG_CC to automatically invoke _AM_PROG_CC_C_O. m4_define([AC_PROG_CC], m4_defn([AC_PROG_CC]) [_AM_PROG_CC_C_O ]) # AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE]) # AM_INIT_AUTOMAKE([OPTIONS]) # ----------------------------------------------- # The call with PACKAGE and VERSION arguments is the old style # call (pre autoconf-2.50), which is being phased out. PACKAGE # and VERSION should now be passed to AC_INIT and removed from # the call to AM_INIT_AUTOMAKE. # We support both call styles for the transition. After # the next Automake release, Autoconf can make the AC_INIT # arguments mandatory, and then we can depend on a new Autoconf # release and drop the old call support. AC_DEFUN([AM_INIT_AUTOMAKE], [AC_PREREQ([2.65])dnl dnl Autoconf wants to disallow AM_ names. We explicitly allow dnl the ones we care about. m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl AC_REQUIRE([AC_PROG_INSTALL])dnl if test "`cd $srcdir && pwd`" != "`pwd`"; then # Use -I$(srcdir) only when $(srcdir) != ., so that make's output # is not polluted with repeated "-I." AC_SUBST([am__isrc], [' -I$(srcdir)'])_AM_SUBST_NOTMAKE([am__isrc])dnl # test to see if srcdir already configured if test -f $srcdir/config.status; then AC_MSG_ERROR([source directory already configured; run "make distclean" there first]) fi fi # test whether we have cygpath if test -z "$CYGPATH_W"; then if (cygpath --version) >/dev/null 2>/dev/null; then CYGPATH_W='cygpath -w' else CYGPATH_W=echo fi fi AC_SUBST([CYGPATH_W]) # Define the identity of the package. dnl Distinguish between old-style and new-style calls. m4_ifval([$2], [AC_DIAGNOSE([obsolete], [$0: two- and three-arguments forms are deprecated.]) m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl AC_SUBST([PACKAGE], [$1])dnl AC_SUBST([VERSION], [$2])], [_AM_SET_OPTIONS([$1])dnl dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT. m4_if( m4_ifdef([AC_PACKAGE_NAME], [ok]):m4_ifdef([AC_PACKAGE_VERSION], [ok]), [ok:ok],, [m4_fatal([AC_INIT should be called with package and version arguments])])dnl AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl _AM_IF_OPTION([no-define],, [AC_DEFINE_UNQUOTED([PACKAGE], ["$PACKAGE"], [Name of package]) AC_DEFINE_UNQUOTED([VERSION], ["$VERSION"], [Version number of package])])dnl # Some tools Automake needs. AC_REQUIRE([AM_SANITY_CHECK])dnl AC_REQUIRE([AC_ARG_PROGRAM])dnl AM_MISSING_PROG([ACLOCAL], [aclocal-${am__api_version}]) AM_MISSING_PROG([AUTOCONF], [autoconf]) AM_MISSING_PROG([AUTOMAKE], [automake-${am__api_version}]) AM_MISSING_PROG([AUTOHEADER], [autoheader]) AM_MISSING_PROG([MAKEINFO], [makeinfo]) AC_REQUIRE([AM_PROG_INSTALL_SH])dnl AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl AC_REQUIRE([AC_PROG_MKDIR_P])dnl # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: # # AC_SUBST([mkdir_p], ['$(MKDIR_P)']) # We need awk for the "check" target (and possibly the TAP driver). The # system "awk" is bad on some platforms. AC_REQUIRE([AC_PROG_AWK])dnl AC_REQUIRE([AC_PROG_MAKE_SET])dnl AC_REQUIRE([AM_SET_LEADING_DOT])dnl _AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])], [_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])], [_AM_PROG_TAR([v7])])]) _AM_IF_OPTION([no-dependencies],, [AC_PROVIDE_IFELSE([AC_PROG_CC], [_AM_DEPENDENCIES([CC])], [m4_define([AC_PROG_CC], m4_defn([AC_PROG_CC])[_AM_DEPENDENCIES([CC])])])dnl AC_PROVIDE_IFELSE([AC_PROG_CXX], [_AM_DEPENDENCIES([CXX])], [m4_define([AC_PROG_CXX], m4_defn([AC_PROG_CXX])[_AM_DEPENDENCIES([CXX])])])dnl AC_PROVIDE_IFELSE([AC_PROG_OBJC], [_AM_DEPENDENCIES([OBJC])], [m4_define([AC_PROG_OBJC], m4_defn([AC_PROG_OBJC])[_AM_DEPENDENCIES([OBJC])])])dnl AC_PROVIDE_IFELSE([AC_PROG_OBJCXX], [_AM_DEPENDENCIES([OBJCXX])], [m4_define([AC_PROG_OBJCXX], m4_defn([AC_PROG_OBJCXX])[_AM_DEPENDENCIES([OBJCXX])])])dnl ]) AC_REQUIRE([AM_SILENT_RULES])dnl dnl The testsuite driver may need to know about EXEEXT, so add the dnl 'am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen. This dnl macro is hooked onto _AC_COMPILER_EXEEXT early, see below. AC_CONFIG_COMMANDS_PRE(dnl [m4_provide_if([_AM_COMPILER_EXEEXT], [AM_CONDITIONAL([am__EXEEXT], [test -n "$EXEEXT"])])])dnl # POSIX will say in a future version that running "rm -f" with no argument # is OK; and we want to be able to make that assumption in our Makefile # recipes. So use an aggressive probe to check that the usage we want is # actually supported "in the wild" to an acceptable degree. # See automake bug#10828. # To make any issue more visible, cause the running configure to be aborted # by default if the 'rm' program in use doesn't match our expectations; the # user can still override this though. if rm -f && rm -fr && rm -rf; then : OK; else cat >&2 <<'END' Oops! Your 'rm' program seems unable to run without file operands specified on the command line, even when the '-f' option is present. This is contrary to the behaviour of most rm programs out there, and not conforming with the upcoming POSIX standard: Please tell bug-automake@gnu.org about your system, including the value of your $PATH and any error possibly output before this message. This can help us improve future automake versions. END if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then echo 'Configuration will proceed anyway, since you have set the' >&2 echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 echo >&2 else cat >&2 <<'END' Aborting the configuration process, to ensure you take notice of the issue. You can download and install GNU coreutils to get an 'rm' implementation that behaves properly: . If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM to "yes", and re-run configure. END AC_MSG_ERROR([Your 'rm' program is bad, sorry.]) fi fi dnl The trailing newline in this macro's definition is deliberate, for dnl backward compatibility and to allow trailing 'dnl'-style comments dnl after the AM_INIT_AUTOMAKE invocation. See automake bug#16841. ]) dnl Hook into '_AC_COMPILER_EXEEXT' early to learn its expansion. Do not dnl add the conditional right here, as _AC_COMPILER_EXEEXT may be further dnl mangled by Autoconf and run in a shell conditional statement. m4_define([_AC_COMPILER_EXEEXT], m4_defn([_AC_COMPILER_EXEEXT])[m4_provide([_AM_COMPILER_EXEEXT])]) # When config.status generates a header, we must update the stamp-h file. # This file resides in the same directory as the config header # that is generated. The stamp files are numbered to have different names. # Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the # loop where config.status creates the headers, so we can generate # our stamp files there. AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK], [# Compute $1's index in $config_headers. _am_arg=$1 _am_stamp_count=1 for _am_header in $config_headers :; do case $_am_header in $_am_arg | $_am_arg:* ) break ;; * ) _am_stamp_count=`expr $_am_stamp_count + 1` ;; esac done echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count]) # Copyright (C) 2001-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_PROG_INSTALL_SH # ------------------ # Define $install_sh. AC_DEFUN([AM_PROG_INSTALL_SH], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl if test x"${install_sh+set}" != xset; then case $am_aux_dir in *\ * | *\ *) install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; *) install_sh="\${SHELL} $am_aux_dir/install-sh" esac fi AC_SUBST([install_sh])]) # Copyright (C) 2003-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # Check whether the underlying file-system supports filenames # with a leading dot. For instance MS-DOS doesn't. AC_DEFUN([AM_SET_LEADING_DOT], [rm -rf .tst 2>/dev/null mkdir .tst 2>/dev/null if test -d .tst; then am__leading_dot=. else am__leading_dot=_ fi rmdir .tst 2>/dev/null AC_SUBST([am__leading_dot])]) # Check to see how 'make' treats includes. -*- Autoconf -*- # Copyright (C) 2001-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_MAKE_INCLUDE() # ----------------- # Check to see how make treats includes. AC_DEFUN([AM_MAKE_INCLUDE], [am_make=${MAKE-make} cat > confinc << 'END' am__doit: @echo this is the am__doit target .PHONY: am__doit END # If we don't find an include directive, just comment out the code. AC_MSG_CHECKING([for style of include used by $am_make]) am__include="#" am__quote= _am_result=none # First try GNU make style include. echo "include confinc" > confmf # Ignore all kinds of additional output from 'make'. case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=include am__quote= _am_result=GNU ;; esac # Now try BSD make style include. if test "$am__include" = "#"; then echo '.include "confinc"' > confmf case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=.include am__quote="\"" _am_result=BSD ;; esac fi AC_SUBST([am__include]) AC_SUBST([am__quote]) AC_MSG_RESULT([$_am_result]) rm -f confinc confmf ]) # Fake the existence of programs that GNU maintainers use. -*- Autoconf -*- # Copyright (C) 1997-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_MISSING_PROG(NAME, PROGRAM) # ------------------------------ AC_DEFUN([AM_MISSING_PROG], [AC_REQUIRE([AM_MISSING_HAS_RUN]) $1=${$1-"${am_missing_run}$2"} AC_SUBST($1)]) # AM_MISSING_HAS_RUN # ------------------ # Define MISSING if not defined so far and test if it is modern enough. # If it is, set am_missing_run to use it, otherwise, to nothing. AC_DEFUN([AM_MISSING_HAS_RUN], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl AC_REQUIRE_AUX_FILE([missing])dnl if test x"${MISSING+set}" != xset; then case $am_aux_dir in *\ * | *\ *) MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; *) MISSING="\${SHELL} $am_aux_dir/missing" ;; esac fi # Use eval to expand $SHELL if eval "$MISSING --is-lightweight"; then am_missing_run="$MISSING " else am_missing_run= AC_MSG_WARN(['missing' script is too old or missing]) fi ]) # Helper functions for option handling. -*- Autoconf -*- # Copyright (C) 2001-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_MANGLE_OPTION(NAME) # ----------------------- AC_DEFUN([_AM_MANGLE_OPTION], [[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])]) # _AM_SET_OPTION(NAME) # -------------------- # Set option NAME. Presently that only means defining a flag for this option. AC_DEFUN([_AM_SET_OPTION], [m4_define(_AM_MANGLE_OPTION([$1]), [1])]) # _AM_SET_OPTIONS(OPTIONS) # ------------------------ # OPTIONS is a space-separated list of Automake options. AC_DEFUN([_AM_SET_OPTIONS], [m4_foreach_w([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])]) # _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET]) # ------------------------------------------- # Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. AC_DEFUN([_AM_IF_OPTION], [m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) # Copyright (C) 1999-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_PROG_CC_C_O # --------------- # Like AC_PROG_CC_C_O, but changed for automake. We rewrite AC_PROG_CC # to automatically call this. AC_DEFUN([_AM_PROG_CC_C_O], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl AC_REQUIRE_AUX_FILE([compile])dnl AC_LANG_PUSH([C])dnl AC_CACHE_CHECK( [whether $CC understands -c and -o together], [am_cv_prog_cc_c_o], [AC_LANG_CONFTEST([AC_LANG_PROGRAM([])]) # Make sure it works both with $CC and with simple cc. # Following AC_PROG_CC_C_O, we do the test twice because some # compilers refuse to overwrite an existing .o file with -o, # though they will create one. am_cv_prog_cc_c_o=yes for am_i in 1 2; do if AM_RUN_LOG([$CC -c conftest.$ac_ext -o conftest2.$ac_objext]) \ && test -f conftest2.$ac_objext; then : OK else am_cv_prog_cc_c_o=no break fi done rm -f core conftest* unset am_i]) if test "$am_cv_prog_cc_c_o" != yes; then # Losing compiler, so override with the script. # FIXME: It is wrong to rewrite CC. # But if we don't then we get into trouble of one sort or another. # A longer-term fix would be to have automake use am__CC in this case, # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" CC="$am_aux_dir/compile $CC" fi AC_LANG_POP([C])]) # For backward compatibility. AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])]) # Copyright (C) 2001-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_RUN_LOG(COMMAND) # ------------------- # Run COMMAND, save the exit status in ac_status, and log it. # (This has been adapted from Autoconf's _AC_RUN_LOG macro.) AC_DEFUN([AM_RUN_LOG], [{ echo "$as_me:$LINENO: $1" >&AS_MESSAGE_LOG_FD ($1) >&AS_MESSAGE_LOG_FD 2>&AS_MESSAGE_LOG_FD ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD (exit $ac_status); }]) # Check to make sure that the build environment is sane. -*- Autoconf -*- # Copyright (C) 1996-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_SANITY_CHECK # --------------- AC_DEFUN([AM_SANITY_CHECK], [AC_MSG_CHECKING([whether build environment is sane]) # Reject unsafe characters in $srcdir or the absolute working directory # name. Accept space and tab only in the latter. am_lf=' ' case `pwd` in *[[\\\"\#\$\&\'\`$am_lf]]*) AC_MSG_ERROR([unsafe absolute working directory name]);; esac case $srcdir in *[[\\\"\#\$\&\'\`$am_lf\ \ ]]*) AC_MSG_ERROR([unsafe srcdir value: '$srcdir']);; esac # Do 'set' in a subshell so we don't clobber the current shell's # arguments. Must try -L first in case configure is actually a # symlink; some systems play weird games with the mod time of symlinks # (eg FreeBSD returns the mod time of the symlink's containing # directory). if ( am_has_slept=no for am_try in 1 2; do echo "timestamp, slept: $am_has_slept" > conftest.file set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` if test "$[*]" = "X"; then # -L didn't work. set X `ls -t "$srcdir/configure" conftest.file` fi if test "$[*]" != "X $srcdir/configure conftest.file" \ && test "$[*]" != "X conftest.file $srcdir/configure"; then # If neither matched, then we have a broken ls. This can happen # if, for instance, CONFIG_SHELL is bash and it inherits a # broken ls alias from the environment. This has actually # happened. Such a system could not be considered "sane". AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken alias in your environment]) fi if test "$[2]" = conftest.file || test $am_try -eq 2; then break fi # Just in case. sleep 1 am_has_slept=yes done test "$[2]" = conftest.file ) then # Ok. : else AC_MSG_ERROR([newly created file is older than distributed files! Check your system clock]) fi AC_MSG_RESULT([yes]) # If we didn't sleep, we still need to ensure time stamps of config.status and # generated files are strictly newer. am_sleep_pid= if grep 'slept: no' conftest.file >/dev/null 2>&1; then ( sleep 1 ) & am_sleep_pid=$! fi AC_CONFIG_COMMANDS_PRE( [AC_MSG_CHECKING([that generated files are newer than configure]) if test -n "$am_sleep_pid"; then # Hide warnings about reused PIDs. wait $am_sleep_pid 2>/dev/null fi AC_MSG_RESULT([done])]) rm -f conftest.file ]) # Copyright (C) 2009-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_SILENT_RULES([DEFAULT]) # -------------------------- # Enable less verbose build rules; with the default set to DEFAULT # ("yes" being less verbose, "no" or empty being verbose). AC_DEFUN([AM_SILENT_RULES], [AC_ARG_ENABLE([silent-rules], [dnl AS_HELP_STRING( [--enable-silent-rules], [less verbose build output (undo: "make V=1")]) AS_HELP_STRING( [--disable-silent-rules], [verbose build output (undo: "make V=0")])dnl ]) case $enable_silent_rules in @%:@ ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=m4_if([$1], [yes], [0], [1]);; esac dnl dnl A few 'make' implementations (e.g., NonStop OS and NextStep) dnl do not support nested variable expansions. dnl See automake bug#9928 and bug#10237. am_make=${MAKE-make} AC_CACHE_CHECK([whether $am_make supports nested variables], [am_cv_make_support_nested_variables], [if AS_ECHO([['TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit']]) | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi]) if test $am_cv_make_support_nested_variables = yes; then dnl Using '$V' instead of '$(V)' breaks IRIX make. AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AC_SUBST([AM_V])dnl AM_SUBST_NOTMAKE([AM_V])dnl AC_SUBST([AM_DEFAULT_V])dnl AM_SUBST_NOTMAKE([AM_DEFAULT_V])dnl AC_SUBST([AM_DEFAULT_VERBOSITY])dnl AM_BACKSLASH='\' AC_SUBST([AM_BACKSLASH])dnl _AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl ]) # Copyright (C) 2001-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_PROG_INSTALL_STRIP # --------------------- # One issue with vendor 'install' (even GNU) is that you can't # specify the program used to strip binaries. This is especially # annoying in cross-compiling environments, where the build's strip # is unlikely to handle the host's binaries. # Fortunately install-sh will honor a STRIPPROG variable, so we # always use install-sh in "make install-strip", and initialize # STRIPPROG with the value of the STRIP variable (set by the user). AC_DEFUN([AM_PROG_INSTALL_STRIP], [AC_REQUIRE([AM_PROG_INSTALL_SH])dnl # Installed binaries are usually stripped using 'strip' when the user # run "make install-strip". However 'strip' might not be the right # tool to use in cross-compilation environments, therefore Automake # will honor the 'STRIP' environment variable to overrule this program. dnl Don't test for $cross_compiling = yes, because it might be 'maybe'. if test "$cross_compiling" != no; then AC_CHECK_TOOL([STRIP], [strip], :) fi INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" AC_SUBST([INSTALL_STRIP_PROGRAM])]) # Copyright (C) 2006-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_SUBST_NOTMAKE(VARIABLE) # --------------------------- # Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in. # This macro is traced by Automake. AC_DEFUN([_AM_SUBST_NOTMAKE]) # AM_SUBST_NOTMAKE(VARIABLE) # -------------------------- # Public sister of _AM_SUBST_NOTMAKE. AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)]) # Check how to create a tarball. -*- Autoconf -*- # Copyright (C) 2004-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_PROG_TAR(FORMAT) # -------------------- # Check how to create a tarball in format FORMAT. # FORMAT should be one of 'v7', 'ustar', or 'pax'. # # Substitute a variable $(am__tar) that is a command # writing to stdout a FORMAT-tarball containing the directory # $tardir. # tardir=directory && $(am__tar) > result.tar # # Substitute a variable $(am__untar) that extract such # a tarball read from stdin. # $(am__untar) < result.tar # AC_DEFUN([_AM_PROG_TAR], [# Always define AMTAR for backward compatibility. Yes, it's still used # in the wild :-( We should find a proper way to deprecate it ... AC_SUBST([AMTAR], ['$${TAR-tar}']) # We'll loop over all known methods to create a tar archive until one works. _am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none' m4_if([$1], [v7], [am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -'], [m4_case([$1], [ustar], [# The POSIX 1988 'ustar' format is defined with fixed-size fields. # There is notably a 21 bits limit for the UID and the GID. In fact, # the 'pax' utility can hang on bigger UID/GID (see automake bug#8343 # and bug#13588). am_max_uid=2097151 # 2^21 - 1 am_max_gid=$am_max_uid # The $UID and $GID variables are not portable, so we need to resort # to the POSIX-mandated id(1) utility. Errors in the 'id' calls # below are definitely unexpected, so allow the users to see them # (that is, avoid stderr redirection). am_uid=`id -u || echo unknown` am_gid=`id -g || echo unknown` AC_MSG_CHECKING([whether UID '$am_uid' is supported by ustar format]) if test $am_uid -le $am_max_uid; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) _am_tools=none fi AC_MSG_CHECKING([whether GID '$am_gid' is supported by ustar format]) if test $am_gid -le $am_max_gid; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) _am_tools=none fi], [pax], [], [m4_fatal([Unknown tar format])]) AC_MSG_CHECKING([how to create a $1 tar archive]) # Go ahead even if we have the value already cached. We do so because we # need to set the values for the 'am__tar' and 'am__untar' variables. _am_tools=${am_cv_prog_tar_$1-$_am_tools} for _am_tool in $_am_tools; do case $_am_tool in gnutar) for _am_tar in tar gnutar gtar; do AM_RUN_LOG([$_am_tar --version]) && break done am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' am__untar="$_am_tar -xf -" ;; plaintar) # Must skip GNU tar: if it does not support --format= it doesn't create # ustar tarball either. (tar --version) >/dev/null 2>&1 && continue am__tar='tar chf - "$$tardir"' am__tar_='tar chf - "$tardir"' am__untar='tar xf -' ;; pax) am__tar='pax -L -x $1 -w "$$tardir"' am__tar_='pax -L -x $1 -w "$tardir"' am__untar='pax -r' ;; cpio) am__tar='find "$$tardir" -print | cpio -o -H $1 -L' am__tar_='find "$tardir" -print | cpio -o -H $1 -L' am__untar='cpio -i -H $1 -d' ;; none) am__tar=false am__tar_=false am__untar=false ;; esac # If the value was cached, stop now. We just wanted to have am__tar # and am__untar set. test -n "${am_cv_prog_tar_$1}" && break # tar/untar a dummy directory, and stop if the command works. rm -rf conftest.dir mkdir conftest.dir echo GrepMe > conftest.dir/file AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) rm -rf conftest.dir if test -s conftest.tar; then AM_RUN_LOG([$am__untar /dev/null 2>&1 && break fi done rm -rf conftest.dir AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) AC_MSG_RESULT([$am_cv_prog_tar_$1])]) AC_SUBST([am__tar]) AC_SUBST([am__untar]) ]) # _AM_PROG_TAR m4_include([m4/libtool.m4]) m4_include([m4/ltoptions.m4]) m4_include([m4/ltsugar.m4]) m4_include([m4/ltversion.m4]) m4_include([m4/lt~obsolete.m4]) m4_include([m4/pkg.m4]) eztrace-1.1-2/bootstrap000077500000000000000000000003211265506773700151300ustar00rootroot00000000000000#!/bin/sh cd extlib/litl && autoreconf -vfi || exit 1 ; cd - cd extlib/gtg && autoreconf -vfi || exit 1 ; cd - cd extlib/opari2/build-frontend && autoreconf -vfi || exit 1 ; cd - autoreconf -vfi ||exit 1 eztrace-1.1-2/compile000077500000000000000000000162451265506773700145570ustar00rootroot00000000000000#! /bin/sh # Wrapper for compilers which do not understand '-c -o'. scriptversion=2012-10-14.11; # UTC # Copyright (C) 1999-2014 Free Software Foundation, Inc. # Written by Tom Tromey . # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2, or (at your option) # any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # This file is maintained in Automake, please report # bugs to or send patches to # . nl=' ' # We need space, tab and new line, in precisely that order. Quoting is # there to prevent tools from complaining about whitespace usage. IFS=" "" $nl" file_conv= # func_file_conv build_file lazy # Convert a $build file to $host form and store it in $file # Currently only supports Windows hosts. If the determined conversion # type is listed in (the comma separated) LAZY, no conversion will # take place. func_file_conv () { file=$1 case $file in / | /[!/]*) # absolute file, and not a UNC file if test -z "$file_conv"; then # lazily determine how to convert abs files case `uname -s` in MINGW*) file_conv=mingw ;; CYGWIN*) file_conv=cygwin ;; *) file_conv=wine ;; esac fi case $file_conv/,$2, in *,$file_conv,*) ;; mingw/*) file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'` ;; cygwin/*) file=`cygpath -m "$file" || echo "$file"` ;; wine/*) file=`winepath -w "$file" || echo "$file"` ;; esac ;; esac } # func_cl_dashL linkdir # Make cl look for libraries in LINKDIR func_cl_dashL () { func_file_conv "$1" if test -z "$lib_path"; then lib_path=$file else lib_path="$lib_path;$file" fi linker_opts="$linker_opts -LIBPATH:$file" } # func_cl_dashl library # Do a library search-path lookup for cl func_cl_dashl () { lib=$1 found=no save_IFS=$IFS IFS=';' for dir in $lib_path $LIB do IFS=$save_IFS if $shared && test -f "$dir/$lib.dll.lib"; then found=yes lib=$dir/$lib.dll.lib break fi if test -f "$dir/$lib.lib"; then found=yes lib=$dir/$lib.lib break fi if test -f "$dir/lib$lib.a"; then found=yes lib=$dir/lib$lib.a break fi done IFS=$save_IFS if test "$found" != yes; then lib=$lib.lib fi } # func_cl_wrapper cl arg... # Adjust compile command to suit cl func_cl_wrapper () { # Assume a capable shell lib_path= shared=: linker_opts= for arg do if test -n "$eat"; then eat= else case $1 in -o) # configure might choose to run compile as 'compile cc -o foo foo.c'. eat=1 case $2 in *.o | *.[oO][bB][jJ]) func_file_conv "$2" set x "$@" -Fo"$file" shift ;; *) func_file_conv "$2" set x "$@" -Fe"$file" shift ;; esac ;; -I) eat=1 func_file_conv "$2" mingw set x "$@" -I"$file" shift ;; -I*) func_file_conv "${1#-I}" mingw set x "$@" -I"$file" shift ;; -l) eat=1 func_cl_dashl "$2" set x "$@" "$lib" shift ;; -l*) func_cl_dashl "${1#-l}" set x "$@" "$lib" shift ;; -L) eat=1 func_cl_dashL "$2" ;; -L*) func_cl_dashL "${1#-L}" ;; -static) shared=false ;; -Wl,*) arg=${1#-Wl,} save_ifs="$IFS"; IFS=',' for flag in $arg; do IFS="$save_ifs" linker_opts="$linker_opts $flag" done IFS="$save_ifs" ;; -Xlinker) eat=1 linker_opts="$linker_opts $2" ;; -*) set x "$@" "$1" shift ;; *.cc | *.CC | *.cxx | *.CXX | *.[cC]++) func_file_conv "$1" set x "$@" -Tp"$file" shift ;; *.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO]) func_file_conv "$1" mingw set x "$@" "$file" shift ;; *) set x "$@" "$1" shift ;; esac fi shift done if test -n "$linker_opts"; then linker_opts="-link$linker_opts" fi exec "$@" $linker_opts exit 1 } eat= case $1 in '') echo "$0: No command. Try '$0 --help' for more information." 1>&2 exit 1; ;; -h | --h*) cat <<\EOF Usage: compile [--help] [--version] PROGRAM [ARGS] Wrapper for compilers which do not understand '-c -o'. Remove '-o dest.o' from ARGS, run PROGRAM with the remaining arguments, and rename the output as expected. If you are trying to build a whole package this is not the right script to run: please start by reading the file 'INSTALL'. Report bugs to . EOF exit $? ;; -v | --v*) echo "compile $scriptversion" exit $? ;; cl | *[/\\]cl | cl.exe | *[/\\]cl.exe ) func_cl_wrapper "$@" # Doesn't return... ;; esac ofile= cfile= for arg do if test -n "$eat"; then eat= else case $1 in -o) # configure might choose to run compile as 'compile cc -o foo foo.c'. # So we strip '-o arg' only if arg is an object. eat=1 case $2 in *.o | *.obj) ofile=$2 ;; *) set x "$@" -o "$2" shift ;; esac ;; *.c) cfile=$1 set x "$@" "$1" shift ;; *) set x "$@" "$1" shift ;; esac fi shift done if test -z "$ofile" || test -z "$cfile"; then # If no '-o' option was seen then we might have been invoked from a # pattern rule where we don't need one. That is ok -- this is a # normal compilation that the losing compiler can handle. If no # '.c' file was seen then we are probably linking. That is also # ok. exec "$@" fi # Name of file we expect compiler to create. cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'` # Create the lock directory. # Note: use '[/\\:.-]' here to ensure that we don't use the same name # that we are using for the .o file. Also, base the name on the expected # object file name, since that is what matters with a parallel build. lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d while true; do if mkdir "$lockdir" >/dev/null 2>&1; then break fi sleep 1 done # FIXME: race condition here if user kills between mkdir and trap. trap "rmdir '$lockdir'; exit 1" 1 2 15 # Run the compile. "$@" ret=$? if test -f "$cofile"; then test "$cofile" = "$ofile" || mv "$cofile" "$ofile" elif test -f "${cofile}bj"; then test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile" fi rmdir "$lockdir" exit $ret # Local Variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC" # time-stamp-end: "; # UTC" # End: eztrace-1.1-2/config.guess000077500000000000000000001247531265506773700155250ustar00rootroot00000000000000#! /bin/sh # Attempt to guess a canonical system name. # Copyright 1992-2015 Free Software Foundation, Inc. timestamp='2015-08-20' # This file is free software; you can redistribute it and/or modify it # under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, see . # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that # program. This Exception is an additional permission under section 7 # of the GNU General Public License, version 3 ("GPLv3"). # # Originally written by Per Bothner; maintained since 2000 by Ben Elliston. # # You can get the latest version of this script from: # http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD # # Please send patches to . me=`echo "$0" | sed -e 's,.*/,,'` usage="\ Usage: $0 [OPTION] Output the configuration name of the system \`$me' is run on. Operation modes: -h, --help print this help, then exit -t, --time-stamp print date of last modification, then exit -v, --version print version number, then exit Report bugs and patches to ." version="\ GNU config.guess ($timestamp) Originally written by Per Bothner. Copyright 1992-2015 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." help=" Try \`$me --help' for more information." # Parse command line while test $# -gt 0 ; do case $1 in --time-stamp | --time* | -t ) echo "$timestamp" ; exit ;; --version | -v ) echo "$version" ; exit ;; --help | --h* | -h ) echo "$usage"; exit ;; -- ) # Stop option processing shift; break ;; - ) # Use stdin as input. break ;; -* ) echo "$me: invalid option $1$help" >&2 exit 1 ;; * ) break ;; esac done if test $# != 0; then echo "$me: too many arguments$help" >&2 exit 1 fi trap 'exit 1' 1 2 15 # CC_FOR_BUILD -- compiler used by this script. Note that the use of a # compiler to aid in system detection is discouraged as it requires # temporary files to be created and, as you can see below, it is a # headache to deal with in a portable fashion. # Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still # use `HOST_CC' if defined, but it is deprecated. # Portable tmp directory creation inspired by the Autoconf team. set_cc_for_build=' trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ; trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ; : ${TMPDIR=/tmp} ; { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } || { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } || { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } || { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ; dummy=$tmp/dummy ; tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ; case $CC_FOR_BUILD,$HOST_CC,$CC in ,,) echo "int x;" > $dummy.c ; for c in cc gcc c89 c99 ; do if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then CC_FOR_BUILD="$c"; break ; fi ; done ; if test x"$CC_FOR_BUILD" = x ; then CC_FOR_BUILD=no_compiler_found ; fi ;; ,,*) CC_FOR_BUILD=$CC ;; ,*,*) CC_FOR_BUILD=$HOST_CC ;; esac ; set_cc_for_build= ;' # This is needed to find uname on a Pyramid OSx when run in the BSD universe. # (ghazi@noc.rutgers.edu 1994-08-24) if (test -f /.attbin/uname) >/dev/null 2>&1 ; then PATH=$PATH:/.attbin ; export PATH fi UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown case "${UNAME_SYSTEM}" in Linux|GNU|GNU/*) # If the system lacks a compiler, then just pick glibc. # We could probably try harder. LIBC=gnu eval $set_cc_for_build cat <<-EOF > $dummy.c #include #if defined(__UCLIBC__) LIBC=uclibc #elif defined(__dietlibc__) LIBC=dietlibc #else LIBC=gnu #endif EOF eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^LIBC' | sed 's, ,,g'` ;; esac # Note: order is significant - the case branches are not exclusive. case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in *:NetBSD:*:*) # NetBSD (nbsd) targets should (where applicable) match one or # more of the tuples: *-*-netbsdelf*, *-*-netbsdaout*, # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently # switched to ELF, *-*-netbsd* would select the old # object file format. This provides both forward # compatibility and a consistent mechanism for selecting the # object file format. # # Note: NetBSD doesn't particularly care about the vendor # portion of the name. We always set it to "unknown". sysctl="sysctl -n hw.machine_arch" UNAME_MACHINE_ARCH=`(uname -p 2>/dev/null || \ /sbin/$sysctl 2>/dev/null || \ /usr/sbin/$sysctl 2>/dev/null || \ echo unknown)` case "${UNAME_MACHINE_ARCH}" in armeb) machine=armeb-unknown ;; arm*) machine=arm-unknown ;; sh3el) machine=shl-unknown ;; sh3eb) machine=sh-unknown ;; sh5el) machine=sh5le-unknown ;; earmv*) arch=`echo ${UNAME_MACHINE_ARCH} | sed -e 's,^e\(armv[0-9]\).*$,\1,'` endian=`echo ${UNAME_MACHINE_ARCH} | sed -ne 's,^.*\(eb\)$,\1,p'` machine=${arch}${endian}-unknown ;; *) machine=${UNAME_MACHINE_ARCH}-unknown ;; esac # The Operating System including object format, if it has switched # to ELF recently, or will in the future. case "${UNAME_MACHINE_ARCH}" in arm*|earm*|i386|m68k|ns32k|sh3*|sparc|vax) eval $set_cc_for_build if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ELF__ then # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout). # Return netbsd for either. FIX? os=netbsd else os=netbsdelf fi ;; *) os=netbsd ;; esac # Determine ABI tags. case "${UNAME_MACHINE_ARCH}" in earm*) expr='s/^earmv[0-9]/-eabi/;s/eb$//' abi=`echo ${UNAME_MACHINE_ARCH} | sed -e "$expr"` ;; esac # The OS release # Debian GNU/NetBSD machines have a different userland, and # thus, need a distinct triplet. However, they do not need # kernel version information, so it can be replaced with a # suitable tag, in the style of linux-gnu. case "${UNAME_VERSION}" in Debian*) release='-gnu' ;; *) release=`echo ${UNAME_RELEASE} | sed -e 's/[-_].*//' | cut -d. -f1,2` ;; esac # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM: # contains redundant information, the shorter form: # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used. echo "${machine}-${os}${release}${abi}" exit ;; *:Bitrig:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'` echo ${UNAME_MACHINE_ARCH}-unknown-bitrig${UNAME_RELEASE} exit ;; *:OpenBSD:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'` echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE} exit ;; *:ekkoBSD:*:*) echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE} exit ;; *:SolidBSD:*:*) echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE} exit ;; macppc:MirBSD:*:*) echo powerpc-unknown-mirbsd${UNAME_RELEASE} exit ;; *:MirBSD:*:*) echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE} exit ;; *:Sortix:*:*) echo ${UNAME_MACHINE}-unknown-sortix exit ;; alpha:OSF1:*:*) case $UNAME_RELEASE in *4.0) UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` ;; *5.*) UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'` ;; esac # According to Compaq, /usr/sbin/psrinfo has been available on # OSF/1 and Tru64 systems produced since 1995. I hope that # covers most systems running today. This code pipes the CPU # types through head -n 1, so we only detect the type of CPU 0. ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1` case "$ALPHA_CPU_TYPE" in "EV4 (21064)") UNAME_MACHINE="alpha" ;; "EV4.5 (21064)") UNAME_MACHINE="alpha" ;; "LCA4 (21066/21068)") UNAME_MACHINE="alpha" ;; "EV5 (21164)") UNAME_MACHINE="alphaev5" ;; "EV5.6 (21164A)") UNAME_MACHINE="alphaev56" ;; "EV5.6 (21164PC)") UNAME_MACHINE="alphapca56" ;; "EV5.7 (21164PC)") UNAME_MACHINE="alphapca57" ;; "EV6 (21264)") UNAME_MACHINE="alphaev6" ;; "EV6.7 (21264A)") UNAME_MACHINE="alphaev67" ;; "EV6.8CB (21264C)") UNAME_MACHINE="alphaev68" ;; "EV6.8AL (21264B)") UNAME_MACHINE="alphaev68" ;; "EV6.8CX (21264D)") UNAME_MACHINE="alphaev68" ;; "EV6.9A (21264/EV69A)") UNAME_MACHINE="alphaev69" ;; "EV7 (21364)") UNAME_MACHINE="alphaev7" ;; "EV7.9 (21364A)") UNAME_MACHINE="alphaev79" ;; esac # A Pn.n version is a patched version. # A Vn.n version is a released version. # A Tn.n version is a released field test version. # A Xn.n version is an unreleased experimental baselevel. # 1.2 uses "1.2" for uname -r. echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` # Reset EXIT trap before exiting to avoid spurious non-zero exit code. exitcode=$? trap '' 0 exit $exitcode ;; Alpha\ *:Windows_NT*:*) # How do we know it's Interix rather than the generic POSIX subsystem? # Should we change UNAME_MACHINE based on the output of uname instead # of the specific Alpha model? echo alpha-pc-interix exit ;; 21064:Windows_NT:50:3) echo alpha-dec-winnt3.5 exit ;; Amiga*:UNIX_System_V:4.0:*) echo m68k-unknown-sysv4 exit ;; *:[Aa]miga[Oo][Ss]:*:*) echo ${UNAME_MACHINE}-unknown-amigaos exit ;; *:[Mm]orph[Oo][Ss]:*:*) echo ${UNAME_MACHINE}-unknown-morphos exit ;; *:OS/390:*:*) echo i370-ibm-openedition exit ;; *:z/VM:*:*) echo s390-ibm-zvmoe exit ;; *:OS400:*:*) echo powerpc-ibm-os400 exit ;; arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*) echo arm-acorn-riscix${UNAME_RELEASE} exit ;; arm*:riscos:*:*|arm*:RISCOS:*:*) echo arm-unknown-riscos exit ;; SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*) echo hppa1.1-hitachi-hiuxmpp exit ;; Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*) # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE. if test "`(/bin/universe) 2>/dev/null`" = att ; then echo pyramid-pyramid-sysv3 else echo pyramid-pyramid-bsd fi exit ;; NILE*:*:*:dcosx) echo pyramid-pyramid-svr4 exit ;; DRS?6000:unix:4.0:6*) echo sparc-icl-nx6 exit ;; DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*) case `/usr/bin/uname -p` in sparc) echo sparc-icl-nx7; exit ;; esac ;; s390x:SunOS:*:*) echo ${UNAME_MACHINE}-ibm-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4H:SunOS:5.*:*) echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*) echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; i86pc:AuroraUX:5.*:* | i86xen:AuroraUX:5.*:*) echo i386-pc-auroraux${UNAME_RELEASE} exit ;; i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*) eval $set_cc_for_build SUN_ARCH="i386" # If there is a compiler, see if it is configured for 64-bit objects. # Note that the Sun cc does not turn __LP64__ into 1 like gcc does. # This test works for both compilers. if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then if (echo '#ifdef __amd64'; echo IS_64BIT_ARCH; echo '#endif') | \ (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ grep IS_64BIT_ARCH >/dev/null then SUN_ARCH="x86_64" fi fi echo ${SUN_ARCH}-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4*:SunOS:6*:*) # According to config.sub, this is the proper way to canonicalize # SunOS6. Hard to guess exactly what SunOS6 will be like, but # it's likely to be more like Solaris than SunOS4. echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4*:SunOS:*:*) case "`/usr/bin/arch -k`" in Series*|S4*) UNAME_RELEASE=`uname -v` ;; esac # Japanese Language versions have a version number like `4.1.3-JL'. echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'` exit ;; sun3*:SunOS:*:*) echo m68k-sun-sunos${UNAME_RELEASE} exit ;; sun*:*:4.2BSD:*) UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null` test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3 case "`/bin/arch`" in sun3) echo m68k-sun-sunos${UNAME_RELEASE} ;; sun4) echo sparc-sun-sunos${UNAME_RELEASE} ;; esac exit ;; aushp:SunOS:*:*) echo sparc-auspex-sunos${UNAME_RELEASE} exit ;; # The situation for MiNT is a little confusing. The machine name # can be virtually everything (everything which is not # "atarist" or "atariste" at least should have a processor # > m68000). The system name ranges from "MiNT" over "FreeMiNT" # to the lowercase version "mint" (or "freemint"). Finally # the system name "TOS" denotes a system which is actually not # MiNT. But MiNT is downward compatible to TOS, so this should # be no problem. atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*) echo m68k-atari-mint${UNAME_RELEASE} exit ;; atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*) echo m68k-atari-mint${UNAME_RELEASE} exit ;; *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*) echo m68k-atari-mint${UNAME_RELEASE} exit ;; milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*) echo m68k-milan-mint${UNAME_RELEASE} exit ;; hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*) echo m68k-hades-mint${UNAME_RELEASE} exit ;; *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*) echo m68k-unknown-mint${UNAME_RELEASE} exit ;; m68k:machten:*:*) echo m68k-apple-machten${UNAME_RELEASE} exit ;; powerpc:machten:*:*) echo powerpc-apple-machten${UNAME_RELEASE} exit ;; RISC*:Mach:*:*) echo mips-dec-mach_bsd4.3 exit ;; RISC*:ULTRIX:*:*) echo mips-dec-ultrix${UNAME_RELEASE} exit ;; VAX*:ULTRIX*:*:*) echo vax-dec-ultrix${UNAME_RELEASE} exit ;; 2020:CLIX:*:* | 2430:CLIX:*:*) echo clipper-intergraph-clix${UNAME_RELEASE} exit ;; mips:*:*:UMIPS | mips:*:*:RISCos) eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #ifdef __cplusplus #include /* for printf() prototype */ int main (int argc, char *argv[]) { #else int main (argc, argv) int argc; char *argv[]; { #endif #if defined (host_mips) && defined (MIPSEB) #if defined (SYSTYPE_SYSV) printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0); #endif #if defined (SYSTYPE_SVR4) printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0); #endif #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD) printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0); #endif #endif exit (-1); } EOF $CC_FOR_BUILD -o $dummy $dummy.c && dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` && SYSTEM_NAME=`$dummy $dummyarg` && { echo "$SYSTEM_NAME"; exit; } echo mips-mips-riscos${UNAME_RELEASE} exit ;; Motorola:PowerMAX_OS:*:*) echo powerpc-motorola-powermax exit ;; Motorola:*:4.3:PL8-*) echo powerpc-harris-powermax exit ;; Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*) echo powerpc-harris-powermax exit ;; Night_Hawk:Power_UNIX:*:*) echo powerpc-harris-powerunix exit ;; m88k:CX/UX:7*:*) echo m88k-harris-cxux7 exit ;; m88k:*:4*:R4*) echo m88k-motorola-sysv4 exit ;; m88k:*:3*:R3*) echo m88k-motorola-sysv3 exit ;; AViiON:dgux:*:*) # DG/UX returns AViiON for all architectures UNAME_PROCESSOR=`/usr/bin/uname -p` if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ] then if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \ [ ${TARGET_BINARY_INTERFACE}x = x ] then echo m88k-dg-dgux${UNAME_RELEASE} else echo m88k-dg-dguxbcs${UNAME_RELEASE} fi else echo i586-dg-dgux${UNAME_RELEASE} fi exit ;; M88*:DolphinOS:*:*) # DolphinOS (SVR3) echo m88k-dolphin-sysv3 exit ;; M88*:*:R3*:*) # Delta 88k system running SVR3 echo m88k-motorola-sysv3 exit ;; XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3) echo m88k-tektronix-sysv3 exit ;; Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD) echo m68k-tektronix-bsd exit ;; *:IRIX*:*:*) echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'` exit ;; ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX. echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id exit ;; # Note that: echo "'`uname -s`'" gives 'AIX ' i*86:AIX:*:*) echo i386-ibm-aix exit ;; ia64:AIX:*:*) if [ -x /usr/bin/oslevel ] ; then IBM_REV=`/usr/bin/oslevel` else IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} fi echo ${UNAME_MACHINE}-ibm-aix${IBM_REV} exit ;; *:AIX:2:3) if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #include main() { if (!__power_pc()) exit(1); puts("powerpc-ibm-aix3.2.5"); exit(0); } EOF if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` then echo "$SYSTEM_NAME" else echo rs6000-ibm-aix3.2.5 fi elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then echo rs6000-ibm-aix3.2.4 else echo rs6000-ibm-aix3.2 fi exit ;; *:AIX:*:[4567]) IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'` if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then IBM_ARCH=rs6000 else IBM_ARCH=powerpc fi if [ -x /usr/bin/lslpp ] ; then IBM_REV=`/usr/bin/lslpp -Lqc bos.rte.libc | awk -F: '{ print $3 }' | sed s/[0-9]*$/0/` else IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} fi echo ${IBM_ARCH}-ibm-aix${IBM_REV} exit ;; *:AIX:*:*) echo rs6000-ibm-aix exit ;; ibmrt:4.4BSD:*|romp-ibm:BSD:*) echo romp-ibm-bsd4.4 exit ;; ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to exit ;; # report: romp-ibm BSD 4.3 *:BOSX:*:*) echo rs6000-bull-bosx exit ;; DPX/2?00:B.O.S.:*:*) echo m68k-bull-sysv3 exit ;; 9000/[34]??:4.3bsd:1.*:*) echo m68k-hp-bsd exit ;; hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*) echo m68k-hp-bsd4.4 exit ;; 9000/[34678]??:HP-UX:*:*) HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` case "${UNAME_MACHINE}" in 9000/31? ) HP_ARCH=m68000 ;; 9000/[34]?? ) HP_ARCH=m68k ;; 9000/[678][0-9][0-9]) if [ -x /usr/bin/getconf ]; then sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null` sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null` case "${sc_cpu_version}" in 523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0 528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1 532) # CPU_PA_RISC2_0 case "${sc_kernel_bits}" in 32) HP_ARCH="hppa2.0n" ;; 64) HP_ARCH="hppa2.0w" ;; '') HP_ARCH="hppa2.0" ;; # HP-UX 10.20 esac ;; esac fi if [ "${HP_ARCH}" = "" ]; then eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #define _HPUX_SOURCE #include #include int main () { #if defined(_SC_KERNEL_BITS) long bits = sysconf(_SC_KERNEL_BITS); #endif long cpu = sysconf (_SC_CPU_VERSION); switch (cpu) { case CPU_PA_RISC1_0: puts ("hppa1.0"); break; case CPU_PA_RISC1_1: puts ("hppa1.1"); break; case CPU_PA_RISC2_0: #if defined(_SC_KERNEL_BITS) switch (bits) { case 64: puts ("hppa2.0w"); break; case 32: puts ("hppa2.0n"); break; default: puts ("hppa2.0"); break; } break; #else /* !defined(_SC_KERNEL_BITS) */ puts ("hppa2.0"); break; #endif default: puts ("hppa1.0"); break; } exit (0); } EOF (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy` test -z "$HP_ARCH" && HP_ARCH=hppa fi ;; esac if [ ${HP_ARCH} = "hppa2.0w" ] then eval $set_cc_for_build # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler # generating 64-bit code. GNU and HP use different nomenclature: # # $ CC_FOR_BUILD=cc ./config.guess # => hppa2.0w-hp-hpux11.23 # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess # => hppa64-hp-hpux11.23 if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | grep -q __LP64__ then HP_ARCH="hppa2.0w" else HP_ARCH="hppa64" fi fi echo ${HP_ARCH}-hp-hpux${HPUX_REV} exit ;; ia64:HP-UX:*:*) HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` echo ia64-hp-hpux${HPUX_REV} exit ;; 3050*:HI-UX:*:*) eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #include int main () { long cpu = sysconf (_SC_CPU_VERSION); /* The order matters, because CPU_IS_HP_MC68K erroneously returns true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct results, however. */ if (CPU_IS_PA_RISC (cpu)) { switch (cpu) { case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break; case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break; case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break; default: puts ("hppa-hitachi-hiuxwe2"); break; } } else if (CPU_IS_HP_MC68K (cpu)) puts ("m68k-hitachi-hiuxwe2"); else puts ("unknown-hitachi-hiuxwe2"); exit (0); } EOF $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` && { echo "$SYSTEM_NAME"; exit; } echo unknown-hitachi-hiuxwe2 exit ;; 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* ) echo hppa1.1-hp-bsd exit ;; 9000/8??:4.3bsd:*:*) echo hppa1.0-hp-bsd exit ;; *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*) echo hppa1.0-hp-mpeix exit ;; hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* ) echo hppa1.1-hp-osf exit ;; hp8??:OSF1:*:*) echo hppa1.0-hp-osf exit ;; i*86:OSF1:*:*) if [ -x /usr/sbin/sysversion ] ; then echo ${UNAME_MACHINE}-unknown-osf1mk else echo ${UNAME_MACHINE}-unknown-osf1 fi exit ;; parisc*:Lites*:*:*) echo hppa1.1-hp-lites exit ;; C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*) echo c1-convex-bsd exit ;; C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*) if getsysinfo -f scalar_acc then echo c32-convex-bsd else echo c2-convex-bsd fi exit ;; C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*) echo c34-convex-bsd exit ;; C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*) echo c38-convex-bsd exit ;; C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*) echo c4-convex-bsd exit ;; CRAY*Y-MP:*:*:*) echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; CRAY*[A-Z]90:*:*:*) echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \ | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \ -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \ -e 's/\.[^.]*$/.X/' exit ;; CRAY*TS:*:*:*) echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; CRAY*T3E:*:*:*) echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; CRAY*SV1:*:*:*) echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; *:UNICOS/mp:*:*) echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*) FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'` echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" exit ;; 5000:UNIX_System_V:4.*:*) FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'` echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" exit ;; i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*) echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE} exit ;; sparc*:BSD/OS:*:*) echo sparc-unknown-bsdi${UNAME_RELEASE} exit ;; *:BSD/OS:*:*) echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE} exit ;; *:FreeBSD:*:*) UNAME_PROCESSOR=`/usr/bin/uname -p` case ${UNAME_PROCESSOR} in amd64) echo x86_64-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; *) echo ${UNAME_PROCESSOR}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; esac exit ;; i*:CYGWIN*:*) echo ${UNAME_MACHINE}-pc-cygwin exit ;; *:MINGW64*:*) echo ${UNAME_MACHINE}-pc-mingw64 exit ;; *:MINGW*:*) echo ${UNAME_MACHINE}-pc-mingw32 exit ;; *:MSYS*:*) echo ${UNAME_MACHINE}-pc-msys exit ;; i*:windows32*:*) # uname -m includes "-pc" on this system. echo ${UNAME_MACHINE}-mingw32 exit ;; i*:PW*:*) echo ${UNAME_MACHINE}-pc-pw32 exit ;; *:Interix*:*) case ${UNAME_MACHINE} in x86) echo i586-pc-interix${UNAME_RELEASE} exit ;; authenticamd | genuineintel | EM64T) echo x86_64-unknown-interix${UNAME_RELEASE} exit ;; IA64) echo ia64-unknown-interix${UNAME_RELEASE} exit ;; esac ;; [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*) echo i${UNAME_MACHINE}-pc-mks exit ;; 8664:Windows_NT:*) echo x86_64-pc-mks exit ;; i*:Windows_NT*:* | Pentium*:Windows_NT*:*) # How do we know it's Interix rather than the generic POSIX subsystem? # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we # UNAME_MACHINE based on the output of uname instead of i386? echo i586-pc-interix exit ;; i*:UWIN*:*) echo ${UNAME_MACHINE}-pc-uwin exit ;; amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*) echo x86_64-unknown-cygwin exit ;; p*:CYGWIN*:*) echo powerpcle-unknown-cygwin exit ;; prep*:SunOS:5.*:*) echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; *:GNU:*:*) # the GNU system echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-${LIBC}`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'` exit ;; *:GNU/*:*:*) # other systems with GNU libc and userland echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-${LIBC} exit ;; i*86:Minix:*:*) echo ${UNAME_MACHINE}-pc-minix exit ;; aarch64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; aarch64_be:Linux:*:*) UNAME_MACHINE=aarch64_be echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; alpha:Linux:*:*) case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in EV5) UNAME_MACHINE=alphaev5 ;; EV56) UNAME_MACHINE=alphaev56 ;; PCA56) UNAME_MACHINE=alphapca56 ;; PCA57) UNAME_MACHINE=alphapca56 ;; EV6) UNAME_MACHINE=alphaev6 ;; EV67) UNAME_MACHINE=alphaev67 ;; EV68*) UNAME_MACHINE=alphaev68 ;; esac objdump --private-headers /bin/sh | grep -q ld.so.1 if test "$?" = 0 ; then LIBC="gnulibc1" ; fi echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; arc:Linux:*:* | arceb:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; arm*:Linux:*:*) eval $set_cc_for_build if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ARM_EABI__ then echo ${UNAME_MACHINE}-unknown-linux-${LIBC} else if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ARM_PCS_VFP then echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabi else echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabihf fi fi exit ;; avr32*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; cris:Linux:*:*) echo ${UNAME_MACHINE}-axis-linux-${LIBC} exit ;; crisv32:Linux:*:*) echo ${UNAME_MACHINE}-axis-linux-${LIBC} exit ;; e2k:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; frv:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; hexagon:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; i*86:Linux:*:*) echo ${UNAME_MACHINE}-pc-linux-${LIBC} exit ;; ia64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; m32r*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; m68*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; mips:Linux:*:* | mips64:Linux:*:*) eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #undef CPU #undef ${UNAME_MACHINE} #undef ${UNAME_MACHINE}el #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) CPU=${UNAME_MACHINE}el #else #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) CPU=${UNAME_MACHINE} #else CPU= #endif #endif EOF eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^CPU'` test x"${CPU}" != x && { echo "${CPU}-unknown-linux-${LIBC}"; exit; } ;; openrisc*:Linux:*:*) echo or1k-unknown-linux-${LIBC} exit ;; or32:Linux:*:* | or1k*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; padre:Linux:*:*) echo sparc-unknown-linux-${LIBC} exit ;; parisc64:Linux:*:* | hppa64:Linux:*:*) echo hppa64-unknown-linux-${LIBC} exit ;; parisc:Linux:*:* | hppa:Linux:*:*) # Look for CPU level case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in PA7*) echo hppa1.1-unknown-linux-${LIBC} ;; PA8*) echo hppa2.0-unknown-linux-${LIBC} ;; *) echo hppa-unknown-linux-${LIBC} ;; esac exit ;; ppc64:Linux:*:*) echo powerpc64-unknown-linux-${LIBC} exit ;; ppc:Linux:*:*) echo powerpc-unknown-linux-${LIBC} exit ;; ppc64le:Linux:*:*) echo powerpc64le-unknown-linux-${LIBC} exit ;; ppcle:Linux:*:*) echo powerpcle-unknown-linux-${LIBC} exit ;; s390:Linux:*:* | s390x:Linux:*:*) echo ${UNAME_MACHINE}-ibm-linux-${LIBC} exit ;; sh64*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; sh*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; sparc:Linux:*:* | sparc64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; tile*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; vax:Linux:*:*) echo ${UNAME_MACHINE}-dec-linux-${LIBC} exit ;; x86_64:Linux:*:*) echo ${UNAME_MACHINE}-pc-linux-${LIBC} exit ;; xtensa*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; i*86:DYNIX/ptx:4*:*) # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. # earlier versions are messed up and put the nodename in both # sysname and nodename. echo i386-sequent-sysv4 exit ;; i*86:UNIX_SV:4.2MP:2.*) # Unixware is an offshoot of SVR4, but it has its own version # number series starting with 2... # I am not positive that other SVR4 systems won't match this, # I just have to hope. -- rms. # Use sysv4.2uw... so that sysv4* matches it. echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION} exit ;; i*86:OS/2:*:*) # If we were able to find `uname', then EMX Unix compatibility # is probably installed. echo ${UNAME_MACHINE}-pc-os2-emx exit ;; i*86:XTS-300:*:STOP) echo ${UNAME_MACHINE}-unknown-stop exit ;; i*86:atheos:*:*) echo ${UNAME_MACHINE}-unknown-atheos exit ;; i*86:syllable:*:*) echo ${UNAME_MACHINE}-pc-syllable exit ;; i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*) echo i386-unknown-lynxos${UNAME_RELEASE} exit ;; i*86:*DOS:*:*) echo ${UNAME_MACHINE}-pc-msdosdjgpp exit ;; i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*) UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'` if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL} else echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL} fi exit ;; i*86:*:5:[678]*) # UnixWare 7.x, OpenUNIX and OpenServer 6. case `/bin/uname -X | grep "^Machine"` in *486*) UNAME_MACHINE=i486 ;; *Pentium) UNAME_MACHINE=i586 ;; *Pent*|*Celeron) UNAME_MACHINE=i686 ;; esac echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION} exit ;; i*86:*:3.2:*) if test -f /usr/options/cb.name; then UNAME_REL=`sed -n 's/.*Version //p' /dev/null >/dev/null ; then UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')` (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486 (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \ && UNAME_MACHINE=i586 (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \ && UNAME_MACHINE=i686 (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \ && UNAME_MACHINE=i686 echo ${UNAME_MACHINE}-pc-sco$UNAME_REL else echo ${UNAME_MACHINE}-pc-sysv32 fi exit ;; pc:*:*:*) # Left here for compatibility: # uname -m prints for DJGPP always 'pc', but it prints nothing about # the processor, so we play safe by assuming i586. # Note: whatever this is, it MUST be the same as what config.sub # prints for the "djgpp" host, or else GDB configury will decide that # this is a cross-build. echo i586-pc-msdosdjgpp exit ;; Intel:Mach:3*:*) echo i386-pc-mach3 exit ;; paragon:*:*:*) echo i860-intel-osf1 exit ;; i860:*:4.*:*) # i860-SVR4 if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4 else # Add other i860-SVR4 vendors below as they are discovered. echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4 fi exit ;; mini*:CTIX:SYS*5:*) # "miniframe" echo m68010-convergent-sysv exit ;; mc68k:UNIX:SYSTEM5:3.51m) echo m68k-convergent-sysv exit ;; M680?0:D-NIX:5.3:*) echo m68k-diab-dnix exit ;; M68*:*:R3V[5678]*:*) test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;; 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0) OS_REL='' test -r /etc/.relid \ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4.3${OS_REL}; exit; } /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*) /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4; exit; } ;; NCR*:*:4.2:* | MPRAS*:*:4.2:*) OS_REL='.3' test -r /etc/.relid \ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4.3${OS_REL}; exit; } /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } /bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*) echo m68k-unknown-lynxos${UNAME_RELEASE} exit ;; mc68030:UNIX_System_V:4.*:*) echo m68k-atari-sysv4 exit ;; TSUNAMI:LynxOS:2.*:*) echo sparc-unknown-lynxos${UNAME_RELEASE} exit ;; rs6000:LynxOS:2.*:*) echo rs6000-unknown-lynxos${UNAME_RELEASE} exit ;; PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.[02]*:*) echo powerpc-unknown-lynxos${UNAME_RELEASE} exit ;; SM[BE]S:UNIX_SV:*:*) echo mips-dde-sysv${UNAME_RELEASE} exit ;; RM*:ReliantUNIX-*:*:*) echo mips-sni-sysv4 exit ;; RM*:SINIX-*:*:*) echo mips-sni-sysv4 exit ;; *:SINIX-*:*:*) if uname -p 2>/dev/null >/dev/null ; then UNAME_MACHINE=`(uname -p) 2>/dev/null` echo ${UNAME_MACHINE}-sni-sysv4 else echo ns32k-sni-sysv fi exit ;; PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort # says echo i586-unisys-sysv4 exit ;; *:UNIX_System_V:4*:FTX*) # From Gerald Hewes . # How about differentiating between stratus architectures? -djm echo hppa1.1-stratus-sysv4 exit ;; *:*:*:FTX*) # From seanf@swdc.stratus.com. echo i860-stratus-sysv4 exit ;; i*86:VOS:*:*) # From Paul.Green@stratus.com. echo ${UNAME_MACHINE}-stratus-vos exit ;; *:VOS:*:*) # From Paul.Green@stratus.com. echo hppa1.1-stratus-vos exit ;; mc68*:A/UX:*:*) echo m68k-apple-aux${UNAME_RELEASE} exit ;; news*:NEWS-OS:6*:*) echo mips-sony-newsos6 exit ;; R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*) if [ -d /usr/nec ]; then echo mips-nec-sysv${UNAME_RELEASE} else echo mips-unknown-sysv${UNAME_RELEASE} fi exit ;; BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only. echo powerpc-be-beos exit ;; BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only. echo powerpc-apple-beos exit ;; BePC:BeOS:*:*) # BeOS running on Intel PC compatible. echo i586-pc-beos exit ;; BePC:Haiku:*:*) # Haiku running on Intel PC compatible. echo i586-pc-haiku exit ;; x86_64:Haiku:*:*) echo x86_64-unknown-haiku exit ;; SX-4:SUPER-UX:*:*) echo sx4-nec-superux${UNAME_RELEASE} exit ;; SX-5:SUPER-UX:*:*) echo sx5-nec-superux${UNAME_RELEASE} exit ;; SX-6:SUPER-UX:*:*) echo sx6-nec-superux${UNAME_RELEASE} exit ;; SX-7:SUPER-UX:*:*) echo sx7-nec-superux${UNAME_RELEASE} exit ;; SX-8:SUPER-UX:*:*) echo sx8-nec-superux${UNAME_RELEASE} exit ;; SX-8R:SUPER-UX:*:*) echo sx8r-nec-superux${UNAME_RELEASE} exit ;; Power*:Rhapsody:*:*) echo powerpc-apple-rhapsody${UNAME_RELEASE} exit ;; *:Rhapsody:*:*) echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE} exit ;; *:Darwin:*:*) UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown eval $set_cc_for_build if test "$UNAME_PROCESSOR" = unknown ; then UNAME_PROCESSOR=powerpc fi if test `echo "$UNAME_RELEASE" | sed -e 's/\..*//'` -le 10 ; then if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \ (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ grep IS_64BIT_ARCH >/dev/null then case $UNAME_PROCESSOR in i386) UNAME_PROCESSOR=x86_64 ;; powerpc) UNAME_PROCESSOR=powerpc64 ;; esac fi fi elif test "$UNAME_PROCESSOR" = i386 ; then # Avoid executing cc on OS X 10.9, as it ships with a stub # that puts up a graphical alert prompting to install # developer tools. Any system running Mac OS X 10.7 or # later (Darwin 11 and later) is required to have a 64-bit # processor. This is not true of the ARM version of Darwin # that Apple uses in portable devices. UNAME_PROCESSOR=x86_64 fi echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE} exit ;; *:procnto*:*:* | *:QNX:[0123456789]*:*) UNAME_PROCESSOR=`uname -p` if test "$UNAME_PROCESSOR" = "x86"; then UNAME_PROCESSOR=i386 UNAME_MACHINE=pc fi echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE} exit ;; *:QNX:*:4*) echo i386-pc-qnx exit ;; NEO-?:NONSTOP_KERNEL:*:*) echo neo-tandem-nsk${UNAME_RELEASE} exit ;; NSE-*:NONSTOP_KERNEL:*:*) echo nse-tandem-nsk${UNAME_RELEASE} exit ;; NSR-?:NONSTOP_KERNEL:*:*) echo nsr-tandem-nsk${UNAME_RELEASE} exit ;; *:NonStop-UX:*:*) echo mips-compaq-nonstopux exit ;; BS2000:POSIX*:*:*) echo bs2000-siemens-sysv exit ;; DS/*:UNIX_System_V:*:*) echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE} exit ;; *:Plan9:*:*) # "uname -m" is not consistent, so use $cputype instead. 386 # is converted to i386 for consistency with other x86 # operating systems. if test "$cputype" = "386"; then UNAME_MACHINE=i386 else UNAME_MACHINE="$cputype" fi echo ${UNAME_MACHINE}-unknown-plan9 exit ;; *:TOPS-10:*:*) echo pdp10-unknown-tops10 exit ;; *:TENEX:*:*) echo pdp10-unknown-tenex exit ;; KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*) echo pdp10-dec-tops20 exit ;; XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*) echo pdp10-xkl-tops20 exit ;; *:TOPS-20:*:*) echo pdp10-unknown-tops20 exit ;; *:ITS:*:*) echo pdp10-unknown-its exit ;; SEI:*:*:SEIUX) echo mips-sei-seiux${UNAME_RELEASE} exit ;; *:DragonFly:*:*) echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` exit ;; *:*VMS:*:*) UNAME_MACHINE=`(uname -p) 2>/dev/null` case "${UNAME_MACHINE}" in A*) echo alpha-dec-vms ; exit ;; I*) echo ia64-dec-vms ; exit ;; V*) echo vax-dec-vms ; exit ;; esac ;; *:XENIX:*:SysV) echo i386-pc-xenix exit ;; i*86:skyos:*:*) echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//' exit ;; i*86:rdos:*:*) echo ${UNAME_MACHINE}-pc-rdos exit ;; i*86:AROS:*:*) echo ${UNAME_MACHINE}-pc-aros exit ;; x86_64:VMkernel:*:*) echo ${UNAME_MACHINE}-unknown-esx exit ;; esac cat >&2 < in order to provide the needed information to handle your system. config.guess timestamp = $timestamp uname -m = `(uname -m) 2>/dev/null || echo unknown` uname -r = `(uname -r) 2>/dev/null || echo unknown` uname -s = `(uname -s) 2>/dev/null || echo unknown` uname -v = `(uname -v) 2>/dev/null || echo unknown` /usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null` /bin/uname -X = `(/bin/uname -X) 2>/dev/null` hostinfo = `(hostinfo) 2>/dev/null` /bin/universe = `(/bin/universe) 2>/dev/null` /usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null` /bin/arch = `(/bin/arch) 2>/dev/null` /usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null` /usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null` UNAME_MACHINE = ${UNAME_MACHINE} UNAME_RELEASE = ${UNAME_RELEASE} UNAME_SYSTEM = ${UNAME_SYSTEM} UNAME_VERSION = ${UNAME_VERSION} EOF exit 1 # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'" # End: eztrace-1.1-2/config.sub000077500000000000000000001064601265506773700151630ustar00rootroot00000000000000#! /bin/sh # Configuration validation subroutine script. # Copyright 1992-2015 Free Software Foundation, Inc. timestamp='2015-08-20' # This file is free software; you can redistribute it and/or modify it # under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, see . # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that # program. This Exception is an additional permission under section 7 # of the GNU General Public License, version 3 ("GPLv3"). # Please send patches to . # # Configuration subroutine to validate and canonicalize a configuration type. # Supply the specified configuration type as an argument. # If it is invalid, we print an error message on stderr and exit with code 1. # Otherwise, we print the canonical config type on stdout and succeed. # You can get the latest version of this script from: # http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub;hb=HEAD # This file is supposed to be the same for all GNU packages # and recognize all the CPU types, system types and aliases # that are meaningful with *any* GNU software. # Each package is responsible for reporting which valid configurations # it does not support. The user should be able to distinguish # a failure to support a valid configuration from a meaningless # configuration. # The goal of this file is to map all the various variations of a given # machine specification into a single specification in the form: # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM # or in some cases, the newer four-part form: # CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM # It is wrong to echo any other type of specification. me=`echo "$0" | sed -e 's,.*/,,'` usage="\ Usage: $0 [OPTION] CPU-MFR-OPSYS $0 [OPTION] ALIAS Canonicalize a configuration name. Operation modes: -h, --help print this help, then exit -t, --time-stamp print date of last modification, then exit -v, --version print version number, then exit Report bugs and patches to ." version="\ GNU config.sub ($timestamp) Copyright 1992-2015 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." help=" Try \`$me --help' for more information." # Parse command line while test $# -gt 0 ; do case $1 in --time-stamp | --time* | -t ) echo "$timestamp" ; exit ;; --version | -v ) echo "$version" ; exit ;; --help | --h* | -h ) echo "$usage"; exit ;; -- ) # Stop option processing shift; break ;; - ) # Use stdin as input. break ;; -* ) echo "$me: invalid option $1$help" exit 1 ;; *local*) # First pass through any local machine types. echo $1 exit ;; * ) break ;; esac done case $# in 0) echo "$me: missing argument$help" >&2 exit 1;; 1) ;; *) echo "$me: too many arguments$help" >&2 exit 1;; esac # Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any). # Here we must recognize all the valid KERNEL-OS combinations. maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'` case $maybe_os in nto-qnx* | linux-gnu* | linux-android* | linux-dietlibc | linux-newlib* | \ linux-musl* | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | \ knetbsd*-gnu* | netbsd*-gnu* | netbsd*-eabi* | \ kopensolaris*-gnu* | \ storm-chaos* | os2-emx* | rtmk-nova*) os=-$maybe_os basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'` ;; android-linux) os=-linux-android basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`-unknown ;; *) basic_machine=`echo $1 | sed 's/-[^-]*$//'` if [ $basic_machine != $1 ] then os=`echo $1 | sed 's/.*-/-/'` else os=; fi ;; esac ### Let's recognize common machines as not being operating systems so ### that things like config.sub decstation-3100 work. We also ### recognize some manufacturers as not being operating systems, so we ### can provide default operating systems below. case $os in -sun*os*) # Prevent following clause from handling this invalid input. ;; -dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \ -att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \ -unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \ -convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\ -c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \ -harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \ -apple | -axis | -knuth | -cray | -microblaze*) os= basic_machine=$1 ;; -bluegene*) os=-cnk ;; -sim | -cisco | -oki | -wec | -winbond) os= basic_machine=$1 ;; -scout) ;; -wrs) os=-vxworks basic_machine=$1 ;; -chorusos*) os=-chorusos basic_machine=$1 ;; -chorusrdb) os=-chorusrdb basic_machine=$1 ;; -hiux*) os=-hiuxwe2 ;; -sco6) os=-sco5v6 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco5) os=-sco3.2v5 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco4) os=-sco3.2v4 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco3.2.[4-9]*) os=`echo $os | sed -e 's/sco3.2./sco3.2v/'` basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco3.2v[4-9]*) # Don't forget version if it is 3.2v4 or newer. basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco5v6*) # Don't forget version if it is 3.2v4 or newer. basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco*) os=-sco3.2v2 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -udk*) basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -isc) os=-isc2.2 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -clix*) basic_machine=clipper-intergraph ;; -isc*) basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -lynx*178) os=-lynxos178 ;; -lynx*5) os=-lynxos5 ;; -lynx*) os=-lynxos ;; -ptx*) basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'` ;; -windowsnt*) os=`echo $os | sed -e 's/windowsnt/winnt/'` ;; -psos*) os=-psos ;; -mint | -mint[0-9]*) basic_machine=m68k-atari os=-mint ;; esac # Decode aliases for certain CPU-COMPANY combinations. case $basic_machine in # Recognize the basic CPU types without company name. # Some are omitted here because they have special meanings below. 1750a | 580 \ | a29k \ | aarch64 | aarch64_be \ | alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \ | alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \ | am33_2.0 \ | arc | arceb \ | arm | arm[bl]e | arme[lb] | armv[2-8] | armv[3-8][lb] | armv7[arm] \ | avr | avr32 \ | ba \ | be32 | be64 \ | bfin \ | c4x | c8051 | clipper \ | d10v | d30v | dlx | dsp16xx \ | e2k | epiphany \ | fido | fr30 | frv | ft32 \ | h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \ | hexagon \ | i370 | i860 | i960 | ia64 \ | ip2k | iq2000 \ | k1om \ | le32 | le64 \ | lm32 \ | m32c | m32r | m32rle | m68000 | m68k | m88k \ | maxq | mb | microblaze | microblazeel | mcore | mep | metag \ | mips | mipsbe | mipseb | mipsel | mipsle \ | mips16 \ | mips64 | mips64el \ | mips64octeon | mips64octeonel \ | mips64orion | mips64orionel \ | mips64r5900 | mips64r5900el \ | mips64vr | mips64vrel \ | mips64vr4100 | mips64vr4100el \ | mips64vr4300 | mips64vr4300el \ | mips64vr5000 | mips64vr5000el \ | mips64vr5900 | mips64vr5900el \ | mipsisa32 | mipsisa32el \ | mipsisa32r2 | mipsisa32r2el \ | mipsisa32r6 | mipsisa32r6el \ | mipsisa64 | mipsisa64el \ | mipsisa64r2 | mipsisa64r2el \ | mipsisa64r6 | mipsisa64r6el \ | mipsisa64sb1 | mipsisa64sb1el \ | mipsisa64sr71k | mipsisa64sr71kel \ | mipsr5900 | mipsr5900el \ | mipstx39 | mipstx39el \ | mn10200 | mn10300 \ | moxie \ | mt \ | msp430 \ | nds32 | nds32le | nds32be \ | nios | nios2 | nios2eb | nios2el \ | ns16k | ns32k \ | open8 | or1k | or1knd | or32 \ | pdp10 | pdp11 | pj | pjl \ | powerpc | powerpc64 | powerpc64le | powerpcle \ | pyramid \ | riscv32 | riscv64 \ | rl78 | rx \ | score \ | sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[234]eb | sheb | shbe | shle | sh[1234]le | sh3ele \ | sh64 | sh64le \ | sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \ | sparcv8 | sparcv9 | sparcv9b | sparcv9v \ | spu \ | tahoe | tic4x | tic54x | tic55x | tic6x | tic80 | tron \ | ubicom32 \ | v850 | v850e | v850e1 | v850e2 | v850es | v850e2v3 \ | visium \ | we32k \ | x86 | xc16x | xstormy16 | xtensa \ | z8k | z80) basic_machine=$basic_machine-unknown ;; c54x) basic_machine=tic54x-unknown ;; c55x) basic_machine=tic55x-unknown ;; c6x) basic_machine=tic6x-unknown ;; leon|leon[3-9]) basic_machine=sparc-$basic_machine ;; m6811 | m68hc11 | m6812 | m68hc12 | m68hcs12x | nvptx | picochip) basic_machine=$basic_machine-unknown os=-none ;; m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k) ;; ms1) basic_machine=mt-unknown ;; strongarm | thumb | xscale) basic_machine=arm-unknown ;; xgate) basic_machine=$basic_machine-unknown os=-none ;; xscaleeb) basic_machine=armeb-unknown ;; xscaleel) basic_machine=armel-unknown ;; # We use `pc' rather than `unknown' # because (1) that's what they normally are, and # (2) the word "unknown" tends to confuse beginning users. i*86 | x86_64) basic_machine=$basic_machine-pc ;; # Object if more than one company name word. *-*-*) echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 exit 1 ;; # Recognize the basic CPU types with company name. 580-* \ | a29k-* \ | aarch64-* | aarch64_be-* \ | alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \ | alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \ | alphapca5[67]-* | alpha64pca5[67]-* | arc-* | arceb-* \ | arm-* | armbe-* | armle-* | armeb-* | armv*-* \ | avr-* | avr32-* \ | ba-* \ | be32-* | be64-* \ | bfin-* | bs2000-* \ | c[123]* | c30-* | [cjt]90-* | c4x-* \ | c8051-* | clipper-* | craynv-* | cydra-* \ | d10v-* | d30v-* | dlx-* \ | e2k-* | elxsi-* \ | f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \ | h8300-* | h8500-* \ | hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \ | hexagon-* \ | i*86-* | i860-* | i960-* | ia64-* \ | ip2k-* | iq2000-* \ | k1om-* \ | le32-* | le64-* \ | lm32-* \ | m32c-* | m32r-* | m32rle-* \ | m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \ | m88110-* | m88k-* | maxq-* | mcore-* | metag-* \ | microblaze-* | microblazeel-* \ | mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \ | mips16-* \ | mips64-* | mips64el-* \ | mips64octeon-* | mips64octeonel-* \ | mips64orion-* | mips64orionel-* \ | mips64r5900-* | mips64r5900el-* \ | mips64vr-* | mips64vrel-* \ | mips64vr4100-* | mips64vr4100el-* \ | mips64vr4300-* | mips64vr4300el-* \ | mips64vr5000-* | mips64vr5000el-* \ | mips64vr5900-* | mips64vr5900el-* \ | mipsisa32-* | mipsisa32el-* \ | mipsisa32r2-* | mipsisa32r2el-* \ | mipsisa32r6-* | mipsisa32r6el-* \ | mipsisa64-* | mipsisa64el-* \ | mipsisa64r2-* | mipsisa64r2el-* \ | mipsisa64r6-* | mipsisa64r6el-* \ | mipsisa64sb1-* | mipsisa64sb1el-* \ | mipsisa64sr71k-* | mipsisa64sr71kel-* \ | mipsr5900-* | mipsr5900el-* \ | mipstx39-* | mipstx39el-* \ | mmix-* \ | mt-* \ | msp430-* \ | nds32-* | nds32le-* | nds32be-* \ | nios-* | nios2-* | nios2eb-* | nios2el-* \ | none-* | np1-* | ns16k-* | ns32k-* \ | open8-* \ | or1k*-* \ | orion-* \ | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \ | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* \ | pyramid-* \ | riscv32-* | riscv64-* \ | rl78-* | romp-* | rs6000-* | rx-* \ | sh-* | sh[1234]-* | sh[24]a-* | sh[24]aeb-* | sh[23]e-* | sh[34]eb-* | sheb-* | shbe-* \ | shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \ | sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \ | sparclite-* \ | sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | sv1-* | sx*-* \ | tahoe-* \ | tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \ | tile*-* \ | tron-* \ | ubicom32-* \ | v850-* | v850e-* | v850e1-* | v850es-* | v850e2-* | v850e2v3-* \ | vax-* \ | visium-* \ | we32k-* \ | x86-* | x86_64-* | xc16x-* | xps100-* \ | xstormy16-* | xtensa*-* \ | ymp-* \ | z8k-* | z80-*) ;; # Recognize the basic CPU types without company name, with glob match. xtensa*) basic_machine=$basic_machine-unknown ;; # Recognize the various machine names and aliases which stand # for a CPU type and a company and sometimes even an OS. 386bsd) basic_machine=i386-unknown os=-bsd ;; 3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc) basic_machine=m68000-att ;; 3b*) basic_machine=we32k-att ;; a29khif) basic_machine=a29k-amd os=-udi ;; abacus) basic_machine=abacus-unknown ;; adobe68k) basic_machine=m68010-adobe os=-scout ;; alliant | fx80) basic_machine=fx80-alliant ;; altos | altos3068) basic_machine=m68k-altos ;; am29k) basic_machine=a29k-none os=-bsd ;; amd64) basic_machine=x86_64-pc ;; amd64-*) basic_machine=x86_64-`echo $basic_machine | sed 's/^[^-]*-//'` ;; amdahl) basic_machine=580-amdahl os=-sysv ;; amiga | amiga-*) basic_machine=m68k-unknown ;; amigaos | amigados) basic_machine=m68k-unknown os=-amigaos ;; amigaunix | amix) basic_machine=m68k-unknown os=-sysv4 ;; apollo68) basic_machine=m68k-apollo os=-sysv ;; apollo68bsd) basic_machine=m68k-apollo os=-bsd ;; aros) basic_machine=i386-pc os=-aros ;; asmjs) basic_machine=asmjs-unknown ;; aux) basic_machine=m68k-apple os=-aux ;; balance) basic_machine=ns32k-sequent os=-dynix ;; blackfin) basic_machine=bfin-unknown os=-linux ;; blackfin-*) basic_machine=bfin-`echo $basic_machine | sed 's/^[^-]*-//'` os=-linux ;; bluegene*) basic_machine=powerpc-ibm os=-cnk ;; c54x-*) basic_machine=tic54x-`echo $basic_machine | sed 's/^[^-]*-//'` ;; c55x-*) basic_machine=tic55x-`echo $basic_machine | sed 's/^[^-]*-//'` ;; c6x-*) basic_machine=tic6x-`echo $basic_machine | sed 's/^[^-]*-//'` ;; c90) basic_machine=c90-cray os=-unicos ;; cegcc) basic_machine=arm-unknown os=-cegcc ;; convex-c1) basic_machine=c1-convex os=-bsd ;; convex-c2) basic_machine=c2-convex os=-bsd ;; convex-c32) basic_machine=c32-convex os=-bsd ;; convex-c34) basic_machine=c34-convex os=-bsd ;; convex-c38) basic_machine=c38-convex os=-bsd ;; cray | j90) basic_machine=j90-cray os=-unicos ;; craynv) basic_machine=craynv-cray os=-unicosmp ;; cr16 | cr16-*) basic_machine=cr16-unknown os=-elf ;; crds | unos) basic_machine=m68k-crds ;; crisv32 | crisv32-* | etraxfs*) basic_machine=crisv32-axis ;; cris | cris-* | etrax*) basic_machine=cris-axis ;; crx) basic_machine=crx-unknown os=-elf ;; da30 | da30-*) basic_machine=m68k-da30 ;; decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn) basic_machine=mips-dec ;; decsystem10* | dec10*) basic_machine=pdp10-dec os=-tops10 ;; decsystem20* | dec20*) basic_machine=pdp10-dec os=-tops20 ;; delta | 3300 | motorola-3300 | motorola-delta \ | 3300-motorola | delta-motorola) basic_machine=m68k-motorola ;; delta88) basic_machine=m88k-motorola os=-sysv3 ;; dicos) basic_machine=i686-pc os=-dicos ;; djgpp) basic_machine=i586-pc os=-msdosdjgpp ;; dpx20 | dpx20-*) basic_machine=rs6000-bull os=-bosx ;; dpx2* | dpx2*-bull) basic_machine=m68k-bull os=-sysv3 ;; ebmon29k) basic_machine=a29k-amd os=-ebmon ;; elxsi) basic_machine=elxsi-elxsi os=-bsd ;; encore | umax | mmax) basic_machine=ns32k-encore ;; es1800 | OSE68k | ose68k | ose | OSE) basic_machine=m68k-ericsson os=-ose ;; fx2800) basic_machine=i860-alliant ;; genix) basic_machine=ns32k-ns ;; gmicro) basic_machine=tron-gmicro os=-sysv ;; go32) basic_machine=i386-pc os=-go32 ;; h3050r* | hiux*) basic_machine=hppa1.1-hitachi os=-hiuxwe2 ;; h8300hms) basic_machine=h8300-hitachi os=-hms ;; h8300xray) basic_machine=h8300-hitachi os=-xray ;; h8500hms) basic_machine=h8500-hitachi os=-hms ;; harris) basic_machine=m88k-harris os=-sysv3 ;; hp300-*) basic_machine=m68k-hp ;; hp300bsd) basic_machine=m68k-hp os=-bsd ;; hp300hpux) basic_machine=m68k-hp os=-hpux ;; hp3k9[0-9][0-9] | hp9[0-9][0-9]) basic_machine=hppa1.0-hp ;; hp9k2[0-9][0-9] | hp9k31[0-9]) basic_machine=m68000-hp ;; hp9k3[2-9][0-9]) basic_machine=m68k-hp ;; hp9k6[0-9][0-9] | hp6[0-9][0-9]) basic_machine=hppa1.0-hp ;; hp9k7[0-79][0-9] | hp7[0-79][0-9]) basic_machine=hppa1.1-hp ;; hp9k78[0-9] | hp78[0-9]) # FIXME: really hppa2.0-hp basic_machine=hppa1.1-hp ;; hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893) # FIXME: really hppa2.0-hp basic_machine=hppa1.1-hp ;; hp9k8[0-9][13679] | hp8[0-9][13679]) basic_machine=hppa1.1-hp ;; hp9k8[0-9][0-9] | hp8[0-9][0-9]) basic_machine=hppa1.0-hp ;; hppa-next) os=-nextstep3 ;; hppaosf) basic_machine=hppa1.1-hp os=-osf ;; hppro) basic_machine=hppa1.1-hp os=-proelf ;; i370-ibm* | ibm*) basic_machine=i370-ibm ;; i*86v32) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv32 ;; i*86v4*) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv4 ;; i*86v) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv ;; i*86sol2) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-solaris2 ;; i386mach) basic_machine=i386-mach os=-mach ;; i386-vsta | vsta) basic_machine=i386-unknown os=-vsta ;; iris | iris4d) basic_machine=mips-sgi case $os in -irix*) ;; *) os=-irix4 ;; esac ;; isi68 | isi) basic_machine=m68k-isi os=-sysv ;; leon-*|leon[3-9]-*) basic_machine=sparc-`echo $basic_machine | sed 's/-.*//'` ;; m68knommu) basic_machine=m68k-unknown os=-linux ;; m68knommu-*) basic_machine=m68k-`echo $basic_machine | sed 's/^[^-]*-//'` os=-linux ;; m88k-omron*) basic_machine=m88k-omron ;; magnum | m3230) basic_machine=mips-mips os=-sysv ;; merlin) basic_machine=ns32k-utek os=-sysv ;; microblaze*) basic_machine=microblaze-xilinx ;; mingw64) basic_machine=x86_64-pc os=-mingw64 ;; mingw32) basic_machine=i686-pc os=-mingw32 ;; mingw32ce) basic_machine=arm-unknown os=-mingw32ce ;; miniframe) basic_machine=m68000-convergent ;; *mint | -mint[0-9]* | *MiNT | *MiNT[0-9]*) basic_machine=m68k-atari os=-mint ;; mips3*-*) basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'` ;; mips3*) basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown ;; monitor) basic_machine=m68k-rom68k os=-coff ;; morphos) basic_machine=powerpc-unknown os=-morphos ;; moxiebox) basic_machine=moxie-unknown os=-moxiebox ;; msdos) basic_machine=i386-pc os=-msdos ;; ms1-*) basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'` ;; msys) basic_machine=i686-pc os=-msys ;; mvs) basic_machine=i370-ibm os=-mvs ;; nacl) basic_machine=le32-unknown os=-nacl ;; ncr3000) basic_machine=i486-ncr os=-sysv4 ;; netbsd386) basic_machine=i386-unknown os=-netbsd ;; netwinder) basic_machine=armv4l-rebel os=-linux ;; news | news700 | news800 | news900) basic_machine=m68k-sony os=-newsos ;; news1000) basic_machine=m68030-sony os=-newsos ;; news-3600 | risc-news) basic_machine=mips-sony os=-newsos ;; necv70) basic_machine=v70-nec os=-sysv ;; next | m*-next ) basic_machine=m68k-next case $os in -nextstep* ) ;; -ns2*) os=-nextstep2 ;; *) os=-nextstep3 ;; esac ;; nh3000) basic_machine=m68k-harris os=-cxux ;; nh[45]000) basic_machine=m88k-harris os=-cxux ;; nindy960) basic_machine=i960-intel os=-nindy ;; mon960) basic_machine=i960-intel os=-mon960 ;; nonstopux) basic_machine=mips-compaq os=-nonstopux ;; np1) basic_machine=np1-gould ;; neo-tandem) basic_machine=neo-tandem ;; nse-tandem) basic_machine=nse-tandem ;; nsr-tandem) basic_machine=nsr-tandem ;; op50n-* | op60c-*) basic_machine=hppa1.1-oki os=-proelf ;; openrisc | openrisc-*) basic_machine=or32-unknown ;; os400) basic_machine=powerpc-ibm os=-os400 ;; OSE68000 | ose68000) basic_machine=m68000-ericsson os=-ose ;; os68k) basic_machine=m68k-none os=-os68k ;; pa-hitachi) basic_machine=hppa1.1-hitachi os=-hiuxwe2 ;; paragon) basic_machine=i860-intel os=-osf ;; parisc) basic_machine=hppa-unknown os=-linux ;; parisc-*) basic_machine=hppa-`echo $basic_machine | sed 's/^[^-]*-//'` os=-linux ;; pbd) basic_machine=sparc-tti ;; pbb) basic_machine=m68k-tti ;; pc532 | pc532-*) basic_machine=ns32k-pc532 ;; pc98) basic_machine=i386-pc ;; pc98-*) basic_machine=i386-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentium | p5 | k5 | k6 | nexgen | viac3) basic_machine=i586-pc ;; pentiumpro | p6 | 6x86 | athlon | athlon_*) basic_machine=i686-pc ;; pentiumii | pentium2 | pentiumiii | pentium3) basic_machine=i686-pc ;; pentium4) basic_machine=i786-pc ;; pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*) basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentiumpro-* | p6-* | 6x86-* | athlon-*) basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*) basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentium4-*) basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pn) basic_machine=pn-gould ;; power) basic_machine=power-ibm ;; ppc | ppcbe) basic_machine=powerpc-unknown ;; ppc-* | ppcbe-*) basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ppcle | powerpclittle | ppc-le | powerpc-little) basic_machine=powerpcle-unknown ;; ppcle-* | powerpclittle-*) basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ppc64) basic_machine=powerpc64-unknown ;; ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ppc64le | powerpc64little | ppc64-le | powerpc64-little) basic_machine=powerpc64le-unknown ;; ppc64le-* | powerpc64little-*) basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ps2) basic_machine=i386-ibm ;; pw32) basic_machine=i586-unknown os=-pw32 ;; rdos | rdos64) basic_machine=x86_64-pc os=-rdos ;; rdos32) basic_machine=i386-pc os=-rdos ;; rom68k) basic_machine=m68k-rom68k os=-coff ;; rm[46]00) basic_machine=mips-siemens ;; rtpc | rtpc-*) basic_machine=romp-ibm ;; s390 | s390-*) basic_machine=s390-ibm ;; s390x | s390x-*) basic_machine=s390x-ibm ;; sa29200) basic_machine=a29k-amd os=-udi ;; sb1) basic_machine=mipsisa64sb1-unknown ;; sb1el) basic_machine=mipsisa64sb1el-unknown ;; sde) basic_machine=mipsisa32-sde os=-elf ;; sei) basic_machine=mips-sei os=-seiux ;; sequent) basic_machine=i386-sequent ;; sh) basic_machine=sh-hitachi os=-hms ;; sh5el) basic_machine=sh5le-unknown ;; sh64) basic_machine=sh64-unknown ;; sparclite-wrs | simso-wrs) basic_machine=sparclite-wrs os=-vxworks ;; sps7) basic_machine=m68k-bull os=-sysv2 ;; spur) basic_machine=spur-unknown ;; st2000) basic_machine=m68k-tandem ;; stratus) basic_machine=i860-stratus os=-sysv4 ;; strongarm-* | thumb-*) basic_machine=arm-`echo $basic_machine | sed 's/^[^-]*-//'` ;; sun2) basic_machine=m68000-sun ;; sun2os3) basic_machine=m68000-sun os=-sunos3 ;; sun2os4) basic_machine=m68000-sun os=-sunos4 ;; sun3os3) basic_machine=m68k-sun os=-sunos3 ;; sun3os4) basic_machine=m68k-sun os=-sunos4 ;; sun4os3) basic_machine=sparc-sun os=-sunos3 ;; sun4os4) basic_machine=sparc-sun os=-sunos4 ;; sun4sol2) basic_machine=sparc-sun os=-solaris2 ;; sun3 | sun3-*) basic_machine=m68k-sun ;; sun4) basic_machine=sparc-sun ;; sun386 | sun386i | roadrunner) basic_machine=i386-sun ;; sv1) basic_machine=sv1-cray os=-unicos ;; symmetry) basic_machine=i386-sequent os=-dynix ;; t3e) basic_machine=alphaev5-cray os=-unicos ;; t90) basic_machine=t90-cray os=-unicos ;; tile*) basic_machine=$basic_machine-unknown os=-linux-gnu ;; tx39) basic_machine=mipstx39-unknown ;; tx39el) basic_machine=mipstx39el-unknown ;; toad1) basic_machine=pdp10-xkl os=-tops20 ;; tower | tower-32) basic_machine=m68k-ncr ;; tpf) basic_machine=s390x-ibm os=-tpf ;; udi29k) basic_machine=a29k-amd os=-udi ;; ultra3) basic_machine=a29k-nyu os=-sym1 ;; v810 | necv810) basic_machine=v810-nec os=-none ;; vaxv) basic_machine=vax-dec os=-sysv ;; vms) basic_machine=vax-dec os=-vms ;; vpp*|vx|vx-*) basic_machine=f301-fujitsu ;; vxworks960) basic_machine=i960-wrs os=-vxworks ;; vxworks68) basic_machine=m68k-wrs os=-vxworks ;; vxworks29k) basic_machine=a29k-wrs os=-vxworks ;; w65*) basic_machine=w65-wdc os=-none ;; w89k-*) basic_machine=hppa1.1-winbond os=-proelf ;; xbox) basic_machine=i686-pc os=-mingw32 ;; xps | xps100) basic_machine=xps100-honeywell ;; xscale-* | xscalee[bl]-*) basic_machine=`echo $basic_machine | sed 's/^xscale/arm/'` ;; ymp) basic_machine=ymp-cray os=-unicos ;; z8k-*-coff) basic_machine=z8k-unknown os=-sim ;; z80-*-coff) basic_machine=z80-unknown os=-sim ;; none) basic_machine=none-none os=-none ;; # Here we handle the default manufacturer of certain CPU types. It is in # some cases the only manufacturer, in others, it is the most popular. w89k) basic_machine=hppa1.1-winbond ;; op50n) basic_machine=hppa1.1-oki ;; op60c) basic_machine=hppa1.1-oki ;; romp) basic_machine=romp-ibm ;; mmix) basic_machine=mmix-knuth ;; rs6000) basic_machine=rs6000-ibm ;; vax) basic_machine=vax-dec ;; pdp10) # there are many clones, so DEC is not a safe bet basic_machine=pdp10-unknown ;; pdp11) basic_machine=pdp11-dec ;; we32k) basic_machine=we32k-att ;; sh[1234] | sh[24]a | sh[24]aeb | sh[34]eb | sh[1234]le | sh[23]ele) basic_machine=sh-unknown ;; sparc | sparcv8 | sparcv9 | sparcv9b | sparcv9v) basic_machine=sparc-sun ;; cydra) basic_machine=cydra-cydrome ;; orion) basic_machine=orion-highlevel ;; orion105) basic_machine=clipper-highlevel ;; mac | mpw | mac-mpw) basic_machine=m68k-apple ;; pmac | pmac-mpw) basic_machine=powerpc-apple ;; *-unknown) # Make sure to match an already-canonicalized machine name. ;; *) echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 exit 1 ;; esac # Here we canonicalize certain aliases for manufacturers. case $basic_machine in *-digital*) basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'` ;; *-commodore*) basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'` ;; *) ;; esac # Decode manufacturer-specific aliases for certain operating systems. if [ x"$os" != x"" ] then case $os in # First match some system type aliases # that might get confused with valid system types. # -solaris* is a basic system type, with this one exception. -auroraux) os=-auroraux ;; -solaris1 | -solaris1.*) os=`echo $os | sed -e 's|solaris1|sunos4|'` ;; -solaris) os=-solaris2 ;; -svr4*) os=-sysv4 ;; -unixware*) os=-sysv4.2uw ;; -gnu/linux*) os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'` ;; # First accept the basic system types. # The portable systems comes first. # Each alternative MUST END IN A *, to match a version number. # -sysv* is not here because it comes later, after sysvr4. -gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \ | -*vms* | -sco* | -esix* | -isc* | -aix* | -cnk* | -sunos | -sunos[34]*\ | -hpux* | -unos* | -osf* | -luna* | -dgux* | -auroraux* | -solaris* \ | -sym* | -kopensolaris* | -plan9* \ | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \ | -aos* | -aros* | -cloudabi* | -sortix* \ | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \ | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \ | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \ | -bitrig* | -openbsd* | -solidbsd* \ | -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \ | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \ | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \ | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \ | -chorusos* | -chorusrdb* | -cegcc* \ | -cygwin* | -msys* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ | -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \ | -linux-newlib* | -linux-musl* | -linux-uclibc* \ | -uxpv* | -beos* | -mpeix* | -udk* | -moxiebox* \ | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \ | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \ | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \ | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \ | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \ | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \ | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es* | -tirtos*) # Remember, each alternative MUST END IN *, to match a version number. ;; -qnx*) case $basic_machine in x86-* | i*86-*) ;; *) os=-nto$os ;; esac ;; -nto-qnx*) ;; -nto*) os=`echo $os | sed -e 's|nto|nto-qnx|'` ;; -sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \ | -windows* | -osx | -abug | -netware* | -os9* | -beos* | -haiku* \ | -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*) ;; -mac*) os=`echo $os | sed -e 's|mac|macos|'` ;; -linux-dietlibc) os=-linux-dietlibc ;; -linux*) os=`echo $os | sed -e 's|linux|linux-gnu|'` ;; -sunos5*) os=`echo $os | sed -e 's|sunos5|solaris2|'` ;; -sunos6*) os=`echo $os | sed -e 's|sunos6|solaris3|'` ;; -opened*) os=-openedition ;; -os400*) os=-os400 ;; -wince*) os=-wince ;; -osfrose*) os=-osfrose ;; -osf*) os=-osf ;; -utek*) os=-bsd ;; -dynix*) os=-bsd ;; -acis*) os=-aos ;; -atheos*) os=-atheos ;; -syllable*) os=-syllable ;; -386bsd) os=-bsd ;; -ctix* | -uts*) os=-sysv ;; -nova*) os=-rtmk-nova ;; -ns2 ) os=-nextstep2 ;; -nsk*) os=-nsk ;; # Preserve the version number of sinix5. -sinix5.*) os=`echo $os | sed -e 's|sinix|sysv|'` ;; -sinix*) os=-sysv4 ;; -tpf*) os=-tpf ;; -triton*) os=-sysv3 ;; -oss*) os=-sysv3 ;; -svr4) os=-sysv4 ;; -svr3) os=-sysv3 ;; -sysvr4) os=-sysv4 ;; # This must come after -sysvr4. -sysv*) ;; -ose*) os=-ose ;; -es1800*) os=-ose ;; -xenix) os=-xenix ;; -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) os=-mint ;; -aros*) os=-aros ;; -zvmoe) os=-zvmoe ;; -dicos*) os=-dicos ;; -nacl*) ;; -none) ;; *) # Get rid of the `-' at the beginning of $os. os=`echo $os | sed 's/[^-]*-//'` echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2 exit 1 ;; esac else # Here we handle the default operating systems that come with various machines. # The value should be what the vendor currently ships out the door with their # machine or put another way, the most popular os provided with the machine. # Note that if you're going to try to match "-MANUFACTURER" here (say, # "-sun"), then you have to tell the case statement up towards the top # that MANUFACTURER isn't an operating system. Otherwise, code above # will signal an error saying that MANUFACTURER isn't an operating # system, and we'll never get to this point. case $basic_machine in score-*) os=-elf ;; spu-*) os=-elf ;; *-acorn) os=-riscix1.2 ;; arm*-rebel) os=-linux ;; arm*-semi) os=-aout ;; c4x-* | tic4x-*) os=-coff ;; c8051-*) os=-elf ;; hexagon-*) os=-elf ;; tic54x-*) os=-coff ;; tic55x-*) os=-coff ;; tic6x-*) os=-coff ;; # This must come before the *-dec entry. pdp10-*) os=-tops20 ;; pdp11-*) os=-none ;; *-dec | vax-*) os=-ultrix4.2 ;; m68*-apollo) os=-domain ;; i386-sun) os=-sunos4.0.2 ;; m68000-sun) os=-sunos3 ;; m68*-cisco) os=-aout ;; mep-*) os=-elf ;; mips*-cisco) os=-elf ;; mips*-*) os=-elf ;; or32-*) os=-coff ;; *-tti) # must be before sparc entry or we get the wrong os. os=-sysv3 ;; sparc-* | *-sun) os=-sunos4.1.1 ;; *-be) os=-beos ;; *-haiku) os=-haiku ;; *-ibm) os=-aix ;; *-knuth) os=-mmixware ;; *-wec) os=-proelf ;; *-winbond) os=-proelf ;; *-oki) os=-proelf ;; *-hp) os=-hpux ;; *-hitachi) os=-hiux ;; i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent) os=-sysv ;; *-cbm) os=-amigaos ;; *-dg) os=-dgux ;; *-dolphin) os=-sysv3 ;; m68k-ccur) os=-rtu ;; m88k-omron*) os=-luna ;; *-next ) os=-nextstep ;; *-sequent) os=-ptx ;; *-crds) os=-unos ;; *-ns) os=-genix ;; i370-*) os=-mvs ;; *-next) os=-nextstep3 ;; *-gould) os=-sysv ;; *-highlevel) os=-bsd ;; *-encore) os=-bsd ;; *-sgi) os=-irix ;; *-siemens) os=-sysv4 ;; *-masscomp) os=-rtu ;; f30[01]-fujitsu | f700-fujitsu) os=-uxpv ;; *-rom68k) os=-coff ;; *-*bug) os=-coff ;; *-apple) os=-macos ;; *-atari*) os=-mint ;; *) os=-none ;; esac fi # Here we handle the case where we know the os, and the CPU type, but not the # manufacturer. We pick the logical manufacturer. vendor=unknown case $basic_machine in *-unknown) case $os in -riscix*) vendor=acorn ;; -sunos*) vendor=sun ;; -cnk*|-aix*) vendor=ibm ;; -beos*) vendor=be ;; -hpux*) vendor=hp ;; -mpeix*) vendor=hp ;; -hiux*) vendor=hitachi ;; -unos*) vendor=crds ;; -dgux*) vendor=dg ;; -luna*) vendor=omron ;; -genix*) vendor=ns ;; -mvs* | -opened*) vendor=ibm ;; -os400*) vendor=ibm ;; -ptx*) vendor=sequent ;; -tpf*) vendor=ibm ;; -vxsim* | -vxworks* | -windiss*) vendor=wrs ;; -aux*) vendor=apple ;; -hms*) vendor=hitachi ;; -mpw* | -macos*) vendor=apple ;; -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) vendor=atari ;; -vos*) vendor=stratus ;; esac basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"` ;; esac echo $basic_machine$os exit # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'" # End: eztrace-1.1-2/configure000077500000000000000000027141421265506773700151130ustar00rootroot00000000000000#! /bin/sh # Guess values for system-dependent variables and create Makefiles. # Generated by GNU Autoconf 2.69 for eztrace 1.1-2. # # Report bugs to . # # # Copyright (C) 1992-1996, 1998-2012 Free Software Foundation, Inc. # # # This configure script is free software; the Free Software Foundation # gives unlimited permission to copy, distribute and modify it. ## -------------------- ## ## M4sh Initialization. ## ## -------------------- ## # Be more Bourne compatible DUALCASE=1; export DUALCASE # for MKS sh if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi as_nl=' ' export as_nl # Printing a long string crashes Solaris 7 /usr/bin/printf. as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo # Prefer a ksh shell builtin over an external printf program on Solaris, # but without wasting forks for bash or zsh. if test -z "$BASH_VERSION$ZSH_VERSION" \ && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='print -r --' as_echo_n='print -rn --' elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='printf %s\n' as_echo_n='printf %s' else if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' as_echo_n='/usr/ucb/echo -n' else as_echo_body='eval expr "X$1" : "X\\(.*\\)"' as_echo_n_body='eval arg=$1; case $arg in #( *"$as_nl"*) expr "X$arg" : "X\\(.*\\)$as_nl"; arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; esac; expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" ' export as_echo_n_body as_echo_n='sh -c $as_echo_n_body as_echo' fi export as_echo_body as_echo='sh -c $as_echo_body as_echo' fi # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi # IFS # We need space, tab and new line, in precisely that order. Quoting is # there to prevent editors from complaining about space-tab. # (If _AS_PATH_WALK were called with IFS unset, it would disable word # splitting by setting IFS to empty value.) IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break done IFS=$as_save_IFS ;; esac # We did not find ourselves, most probably we were run as `sh COMMAND' # in which case we are not to be found in the path. if test "x$as_myself" = x; then as_myself=$0 fi if test ! -f "$as_myself"; then $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 exit 1 fi # Unset variables that we do not need and which cause bugs (e.g. in # pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" # suppresses any "Segmentation fault" message there. '((' could # trigger a bug in pdksh 5.2.14. for as_var in BASH_ENV ENV MAIL MAILPATH do eval test x\${$as_var+set} = xset \ && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : done PS1='$ ' PS2='> ' PS4='+ ' # NLS nuisances. LC_ALL=C export LC_ALL LANGUAGE=C export LANGUAGE # CDPATH. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH # Use a proper internal environment variable to ensure we don't fall # into an infinite loop, continuously re-executing ourselves. if test x"${_as_can_reexec}" != xno && test "x$CONFIG_SHELL" != x; then _as_can_reexec=no; export _as_can_reexec; # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV case $- in # (((( *v*x* | *x*v* ) as_opts=-vx ;; *v* ) as_opts=-v ;; *x* ) as_opts=-x ;; * ) as_opts= ;; esac exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} # Admittedly, this is quite paranoid, since all the known shells bail # out after a failed `exec'. $as_echo "$0: could not re-execute with $CONFIG_SHELL" >&2 as_fn_exit 255 fi # We don't want this to propagate to other subprocesses. { _as_can_reexec=; unset _as_can_reexec;} if test "x$CONFIG_SHELL" = x; then as_bourne_compatible="if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on \${1+\"\$@\"}, which # is contrary to our usage. Disable this feature. alias -g '\${1+\"\$@\"}'='\"\$@\"' setopt NO_GLOB_SUBST else case \`(set -o) 2>/dev/null\` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi " as_required="as_fn_return () { (exit \$1); } as_fn_success () { as_fn_return 0; } as_fn_failure () { as_fn_return 1; } as_fn_ret_success () { return 0; } as_fn_ret_failure () { return 1; } exitcode=0 as_fn_success || { exitcode=1; echo as_fn_success failed.; } as_fn_failure && { exitcode=1; echo as_fn_failure succeeded.; } as_fn_ret_success || { exitcode=1; echo as_fn_ret_success failed.; } as_fn_ret_failure && { exitcode=1; echo as_fn_ret_failure succeeded.; } if ( set x; as_fn_ret_success y && test x = \"\$1\" ); then : else exitcode=1; echo positional parameters were not saved. fi test x\$exitcode = x0 || exit 1 test -x / || exit 1" as_suggested=" as_lineno_1=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_1a=\$LINENO as_lineno_2=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_2a=\$LINENO eval 'test \"x\$as_lineno_1'\$as_run'\" != \"x\$as_lineno_2'\$as_run'\" && test \"x\`expr \$as_lineno_1'\$as_run' + 1\`\" = \"x\$as_lineno_2'\$as_run'\"' || exit 1 test -n \"\${ZSH_VERSION+set}\${BASH_VERSION+set}\" || ( ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO ECHO=\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO PATH=/empty FPATH=/empty; export PATH FPATH test \"X\`printf %s \$ECHO\`\" = \"X\$ECHO\" \\ || test \"X\`print -r -- \$ECHO\`\" = \"X\$ECHO\" ) || exit 1 test \$(( 1 + 1 )) = 2 || exit 1" if (eval "$as_required") 2>/dev/null; then : as_have_required=yes else as_have_required=no fi if test x$as_have_required = xyes && (eval "$as_suggested") 2>/dev/null; then : else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR as_found=false for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. as_found=: case $as_dir in #( /*) for as_base in sh bash ksh sh5; do # Try only shells that exist, to save several forks. as_shell=$as_dir/$as_base if { test -f "$as_shell" || test -f "$as_shell.exe"; } && { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$as_shell"; } 2>/dev/null; then : CONFIG_SHELL=$as_shell as_have_required=yes if { $as_echo "$as_bourne_compatible""$as_suggested" | as_run=a "$as_shell"; } 2>/dev/null; then : break 2 fi fi done;; esac as_found=false done $as_found || { if { test -f "$SHELL" || test -f "$SHELL.exe"; } && { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$SHELL"; } 2>/dev/null; then : CONFIG_SHELL=$SHELL as_have_required=yes fi; } IFS=$as_save_IFS if test "x$CONFIG_SHELL" != x; then : export CONFIG_SHELL # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV case $- in # (((( *v*x* | *x*v* ) as_opts=-vx ;; *v* ) as_opts=-v ;; *x* ) as_opts=-x ;; * ) as_opts= ;; esac exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} # Admittedly, this is quite paranoid, since all the known shells bail # out after a failed `exec'. $as_echo "$0: could not re-execute with $CONFIG_SHELL" >&2 exit 255 fi if test x$as_have_required = xno; then : $as_echo "$0: This script requires a shell more modern than all" $as_echo "$0: the shells that I found on your system." if test x${ZSH_VERSION+set} = xset ; then $as_echo "$0: In particular, zsh $ZSH_VERSION has bugs and should" $as_echo "$0: be upgraded to zsh 4.3.4 or later." else $as_echo "$0: Please tell bug-autoconf@gnu.org and $0: eztrace-devel@lists.gforge.inria.fr about your system, $0: including any error possibly output before this $0: message. Then install a modern shell, or manually run $0: the script under such a shell if you do have one." fi exit 1 fi fi fi SHELL=${CONFIG_SHELL-/bin/sh} export SHELL # Unset more variables known to interfere with behavior of common tools. CLICOLOR_FORCE= GREP_OPTIONS= unset CLICOLOR_FORCE GREP_OPTIONS ## --------------------- ## ## M4sh Shell Functions. ## ## --------------------- ## # as_fn_unset VAR # --------------- # Portably unset VAR. as_fn_unset () { { eval $1=; unset $1;} } as_unset=as_fn_unset # as_fn_set_status STATUS # ----------------------- # Set $? to STATUS, without forking. as_fn_set_status () { return $1 } # as_fn_set_status # as_fn_exit STATUS # ----------------- # Exit the shell with STATUS, even in a "trap 0" or "set -e" context. as_fn_exit () { set +e as_fn_set_status $1 exit $1 } # as_fn_exit # as_fn_mkdir_p # ------------- # Create "$as_dir" as a directory, including parents if necessary. as_fn_mkdir_p () { case $as_dir in #( -*) as_dir=./$as_dir;; esac test -d "$as_dir" || eval $as_mkdir_p || { as_dirs= while :; do case $as_dir in #( *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( *) as_qdir=$as_dir;; esac as_dirs="'$as_qdir' $as_dirs" as_dir=`$as_dirname -- "$as_dir" || $as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_dir" : 'X\(//\)[^/]' \| \ X"$as_dir" : 'X\(//\)$' \| \ X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$as_dir" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` test -d "$as_dir" && break done test -z "$as_dirs" || eval "mkdir $as_dirs" } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" } # as_fn_mkdir_p # as_fn_executable_p FILE # ----------------------- # Test if FILE is an executable regular file. as_fn_executable_p () { test -f "$1" && test -x "$1" } # as_fn_executable_p # as_fn_append VAR VALUE # ---------------------- # Append the text in VALUE to the end of the definition contained in VAR. Take # advantage of any shell optimizations that allow amortized linear growth over # repeated appends, instead of the typical quadratic growth present in naive # implementations. if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : eval 'as_fn_append () { eval $1+=\$2 }' else as_fn_append () { eval $1=\$$1\$2 } fi # as_fn_append # as_fn_arith ARG... # ------------------ # Perform arithmetic evaluation on the ARGs, and store the result in the # global $as_val. Take advantage of shells that can avoid forks. The arguments # must be portable across $(()) and expr. if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : eval 'as_fn_arith () { as_val=$(( $* )) }' else as_fn_arith () { as_val=`expr "$@" || test $? -eq 1` } fi # as_fn_arith # as_fn_error STATUS ERROR [LINENO LOG_FD] # ---------------------------------------- # Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are # provided, also output the error to LOG_FD, referencing LINENO. Then exit the # script with STATUS, using 1 if that was 0. as_fn_error () { as_status=$1; test $as_status -eq 0 && as_status=1 if test "$4"; then as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack $as_echo "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 fi $as_echo "$as_me: error: $2" >&2 as_fn_exit $as_status } # as_fn_error if expr a : '\(a\)' >/dev/null 2>&1 && test "X`expr 00001 : '.*\(...\)'`" = X001; then as_expr=expr else as_expr=false fi if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then as_basename=basename else as_basename=false fi if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then as_dirname=dirname else as_dirname=false fi as_me=`$as_basename -- "$0" || $as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ X"$0" : 'X\(//\)$' \| \ X"$0" : 'X\(/\)' \| . 2>/dev/null || $as_echo X/"$0" | sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/ q } /^X\/\(\/\/\)$/{ s//\1/ q } /^X\/\(\/\).*/{ s//\1/ q } s/.*/./; q'` # Avoid depending upon Character Ranges. as_cr_letters='abcdefghijklmnopqrstuvwxyz' as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' as_cr_Letters=$as_cr_letters$as_cr_LETTERS as_cr_digits='0123456789' as_cr_alnum=$as_cr_Letters$as_cr_digits as_lineno_1=$LINENO as_lineno_1a=$LINENO as_lineno_2=$LINENO as_lineno_2a=$LINENO eval 'test "x$as_lineno_1'$as_run'" != "x$as_lineno_2'$as_run'" && test "x`expr $as_lineno_1'$as_run' + 1`" = "x$as_lineno_2'$as_run'"' || { # Blame Lee E. McMahon (1931-1989) for sed's syntax. :-) sed -n ' p /[$]LINENO/= ' <$as_myself | sed ' s/[$]LINENO.*/&-/ t lineno b :lineno N :loop s/[$]LINENO\([^'$as_cr_alnum'_].*\n\)\(.*\)/\2\1\2/ t loop s/-\n.*// ' >$as_me.lineno && chmod +x "$as_me.lineno" || { $as_echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2; as_fn_exit 1; } # If we had to re-execute with $CONFIG_SHELL, we're ensured to have # already done that, so ensure we don't try to do so again and fall # in an infinite loop. This has already happened in practice. _as_can_reexec=no; export _as_can_reexec # Don't try to exec as it changes $[0], causing all sort of problems # (the dirname of $[0] is not the place where we might find the # original and so on. Autoconf is especially sensitive to this). . "./$as_me.lineno" # Exit status is that of the last command. exit } ECHO_C= ECHO_N= ECHO_T= case `echo -n x` in #((((( -n*) case `echo 'xy\c'` in *c*) ECHO_T=' ';; # ECHO_T is single tab character. xy) ECHO_C='\c';; *) echo `echo ksh88 bug on AIX 6.1` > /dev/null ECHO_T=' ';; esac;; *) ECHO_N='-n';; esac rm -f conf$$ conf$$.exe conf$$.file if test -d conf$$.dir; then rm -f conf$$.dir/conf$$.file else rm -f conf$$.dir mkdir conf$$.dir 2>/dev/null fi if (echo >conf$$.file) 2>/dev/null; then if ln -s conf$$.file conf$$ 2>/dev/null; then as_ln_s='ln -s' # ... but there are two gotchas: # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. # In both cases, we have to default to `cp -pR'. ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || as_ln_s='cp -pR' elif ln conf$$.file conf$$ 2>/dev/null; then as_ln_s=ln else as_ln_s='cp -pR' fi else as_ln_s='cp -pR' fi rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file rmdir conf$$.dir 2>/dev/null if mkdir -p . 2>/dev/null; then as_mkdir_p='mkdir -p "$as_dir"' else test -d ./-p && rmdir ./-p as_mkdir_p=false fi as_test_x='test -x' as_executable_p=as_fn_executable_p # Sed expression to map a string onto a valid CPP name. as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" # Sed expression to map a string onto a valid variable name. as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" SHELL=${CONFIG_SHELL-/bin/sh} test -n "$DJDIR" || exec 7<&0 &1 # Name of the host. # hostname on some systems (SVR3.2, old GNU/Linux) returns a bogus exit status, # so uname gets run too. ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` # # Initializations. # ac_default_prefix=/usr/local ac_clean_files= ac_config_libobj_dir=. LIBOBJS= cross_compiling=no subdirs= MFLAGS= MAKEFLAGS= # Identity of this package. PACKAGE_NAME='eztrace' PACKAGE_TARNAME='eztrace' PACKAGE_VERSION='1.1-2' PACKAGE_STRING='eztrace 1.1-2' PACKAGE_BUGREPORT='eztrace-devel@lists.gforge.inria.fr' PACKAGE_URL='' # Factoring default headers for most tests. ac_includes_default="\ #include #ifdef HAVE_SYS_TYPES_H # include #endif #ifdef HAVE_SYS_STAT_H # include #endif #ifdef STDC_HEADERS # include # include #else # ifdef HAVE_STDLIB_H # include # endif #endif #ifdef HAVE_STRING_H # if !defined STDC_HEADERS && defined HAVE_MEMORY_H # include # endif # include #endif #ifdef HAVE_STRINGS_H # include #endif #ifdef HAVE_INTTYPES_H # include #endif #ifdef HAVE_STDINT_H # include #endif #ifdef HAVE_UNISTD_H # include #endif" enable_option_checking=no ac_subst_vars='am__EXEEXT_FALSE am__EXEEXT_TRUE LTLIBOBJS subdirs WITHDOC_FALSE WITHDOC_TRUE ARM_FALSE ARM_TRUE X86_64_FALSE X86_64_TRUE AMEXTERNGTG_FALSE AMEXTERNGTG_TRUE AMEXTERNLITL_FALSE AMEXTERNLITL_TRUE USE_LITL_FALSE USE_LITL_TRUE USE_STARPU_FALSE USE_STARPU_TRUE USE_PTHREAD_FALSE USE_PTHREAD_TRUE USE_MPI3_FALSE USE_MPI3_TRUE USE_MPI_FALSE USE_MPI_TRUE USE_CUDA_FALSE USE_CUDA_TRUE LD_LIBRARY_PATH_NAME LD_PRELOAD_NAME DYNLIB_EXT USE_PAPI_FALSE USE_PAPI_TRUE PAPI_ENABLED PAPI_LIBDIR PAPI_LDFLAGS PAPI_CPPFLAGS LITL_PRINT OPENMP_FOUND_FALSE OPENMP_FOUND_TRUE GTG_OUT_OF_ORDER_FALSE GTG_OUT_OF_ORDER_TRUE GTG_OUT_OF_ORDER GTG_EXT_LIB GTG_EXT_LDFLAGS GTG_EXT_CPPFLAGS GTG_DEPENDENCIES GTG_LIB GTG_LDFLAGS GTG_CPPFLAGS TL_EXT_LIB TL_EXT_LDFLAGS TL_EXT_CPPFLAGS TL_LIB TL_LDFLAGS TL_CPPFLAGS NVCCFLAGS NVCC CUPTI_LIBS CUPTI_LDFLAGS CUPTI_CFLAGS CUDA_LIBS CUDA_LDFLAGS CUDA_CFLAGS USE_CUDADIR_FROM_USER CUDA_ROOT HAVE_LATEXMK_FALSE HAVE_LATEXMK_TRUE LATEXMK HAVE_PDFLATEX_FALSE HAVE_PDFLATEX_TRUE PDFLATEX GTGDIR MPI_EVENT_ID MPI_MODULE_NAME USE_MPIDIR_FROM_USER MPI_LDFLAGS MPI_INC MPI_ROOT USE_PAPIDIR_FROM_USER PAPIDIR LITL_ROOT STARPU_LDFLAGS STARPU_CPPFLAGS STARPU_LIBS STARPU_CFLAGS PKG_CONFIG_LIBDIR PKG_CONFIG_PATH PKG_CONFIG STARPU_ROOT TARGET_BITS HAVE_PRCTL_H PPTRACE_BINARY_TYPE USE_PPTRACE_FALSE USE_PPTRACE_TRUE HAVE_LIBOPCODE_FALSE HAVE_LIBOPCODE_TRUE HAVE_LIBOPCODE LIBOBJS HAVE_DEMANGLE_FALSE HAVE_DEMANGLE_TRUE HAVE_ENV PERL MPICC CXXCPP CPP OTOOL64 OTOOL LIPO NMEDIT DSYMUTIL MANIFEST_TOOL RANLIB ac_ct_AR AR DLLTOOL OBJDUMP LN_S NM ac_ct_DUMPBIN DUMPBIN LD FGREP EGREP GREP SED host_os host_vendor host_cpu host build_os build_vendor build_cpu build LIBTOOL am__fastdepCXX_FALSE am__fastdepCXX_TRUE CXXDEPMODE ac_ct_CXX CXXFLAGS CXX ac_ct_FC FCFLAGS FC am__fastdepCC_FALSE am__fastdepCC_TRUE CCDEPMODE am__nodep AMDEPBACKSLASH AMDEP_FALSE AMDEP_TRUE am__quote am__include DEPDIR OBJEXT EXEEXT ac_ct_CC CPPFLAGS LDFLAGS CFLAGS CC AM_BACKSLASH AM_DEFAULT_VERBOSITY AM_DEFAULT_V AM_V am__untar am__tar AMTAR am__leading_dot SET_MAKE AWK mkdir_p MKDIR_P INSTALL_STRIP_PROGRAM STRIP install_sh MAKEINFO AUTOHEADER AUTOMAKE AUTOCONF ACLOCAL VERSION PACKAGE CYGPATH_W am__isrc INSTALL_DATA INSTALL_SCRIPT INSTALL_PROGRAM target_alias host_alias build_alias LIBS ECHO_T ECHO_N ECHO_C DEFS mandir localedir libdir psdir pdfdir dvidir htmldir infodir docdir oldincludedir includedir runstatedir localstatedir sharedstatedir sysconfdir datadir datarootdir libexecdir sbindir bindir program_transform_name prefix exec_prefix PACKAGE_URL PACKAGE_BUGREPORT PACKAGE_STRING PACKAGE_VERSION PACKAGE_TARNAME PACKAGE_NAME PATH_SEPARATOR SHELL' ac_subst_files='' ac_user_opts=' enable_option_checking enable_silent_rules enable_dependency_tracking enable_shared enable_static with_pic enable_fast_install with_gnu_ld with_sysroot enable_libtool_lock with_doc enable_pptrace with_starpu with_litl with_papi with_mpi with_mpi_include with_mpi_ldflags with_mpi_module_name with_mpi_event_id with_gtg with_cuda enable_gettid ' ac_precious_vars='build_alias host_alias target_alias CC CFLAGS LDFLAGS LIBS CPPFLAGS FC FCFLAGS CXX CXXFLAGS CCC CPP CXXCPP PKG_CONFIG PKG_CONFIG_PATH PKG_CONFIG_LIBDIR STARPU_CFLAGS STARPU_LIBS' ac_subdirs_all='extlib/opari2 extlib/litl' # Initialize some variables set by options. ac_init_help= ac_init_version=false ac_unrecognized_opts= ac_unrecognized_sep= # The variables have the same names as the options, with # dashes changed to underlines. cache_file=/dev/null exec_prefix=NONE no_create= no_recursion= prefix=NONE program_prefix=NONE program_suffix=NONE program_transform_name=s,x,x, silent= site= srcdir= verbose= x_includes=NONE x_libraries=NONE # Installation directory options. # These are left unexpanded so users can "make install exec_prefix=/foo" # and all the variables that are supposed to be based on exec_prefix # by default will actually change. # Use braces instead of parens because sh, perl, etc. also accept them. # (The list follows the same order as the GNU Coding Standards.) bindir='${exec_prefix}/bin' sbindir='${exec_prefix}/sbin' libexecdir='${exec_prefix}/libexec' datarootdir='${prefix}/share' datadir='${datarootdir}' sysconfdir='${prefix}/etc' sharedstatedir='${prefix}/com' localstatedir='${prefix}/var' runstatedir='${localstatedir}/run' includedir='${prefix}/include' oldincludedir='/usr/include' docdir='${datarootdir}/doc/${PACKAGE_TARNAME}' infodir='${datarootdir}/info' htmldir='${docdir}' dvidir='${docdir}' pdfdir='${docdir}' psdir='${docdir}' libdir='${exec_prefix}/lib' localedir='${datarootdir}/locale' mandir='${datarootdir}/man' ac_prev= ac_dashdash= for ac_option do # If the previous option needs an argument, assign it. if test -n "$ac_prev"; then eval $ac_prev=\$ac_option ac_prev= continue fi case $ac_option in *=?*) ac_optarg=`expr "X$ac_option" : '[^=]*=\(.*\)'` ;; *=) ac_optarg= ;; *) ac_optarg=yes ;; esac # Accept the important Cygnus configure options, so we can diagnose typos. case $ac_dashdash$ac_option in --) ac_dashdash=yes ;; -bindir | --bindir | --bindi | --bind | --bin | --bi) ac_prev=bindir ;; -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) bindir=$ac_optarg ;; -build | --build | --buil | --bui | --bu) ac_prev=build_alias ;; -build=* | --build=* | --buil=* | --bui=* | --bu=*) build_alias=$ac_optarg ;; -cache-file | --cache-file | --cache-fil | --cache-fi \ | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) ac_prev=cache_file ;; -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) cache_file=$ac_optarg ;; --config-cache | -C) cache_file=config.cache ;; -datadir | --datadir | --datadi | --datad) ac_prev=datadir ;; -datadir=* | --datadir=* | --datadi=* | --datad=*) datadir=$ac_optarg ;; -datarootdir | --datarootdir | --datarootdi | --datarootd | --dataroot \ | --dataroo | --dataro | --datar) ac_prev=datarootdir ;; -datarootdir=* | --datarootdir=* | --datarootdi=* | --datarootd=* \ | --dataroot=* | --dataroo=* | --dataro=* | --datar=*) datarootdir=$ac_optarg ;; -disable-* | --disable-*) ac_useropt=`expr "x$ac_option" : 'x-*disable-\(.*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid feature name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "enable_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--disable-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval enable_$ac_useropt=no ;; -docdir | --docdir | --docdi | --doc | --do) ac_prev=docdir ;; -docdir=* | --docdir=* | --docdi=* | --doc=* | --do=*) docdir=$ac_optarg ;; -dvidir | --dvidir | --dvidi | --dvid | --dvi | --dv) ac_prev=dvidir ;; -dvidir=* | --dvidir=* | --dvidi=* | --dvid=* | --dvi=* | --dv=*) dvidir=$ac_optarg ;; -enable-* | --enable-*) ac_useropt=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid feature name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "enable_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--enable-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval enable_$ac_useropt=\$ac_optarg ;; -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ | --exec | --exe | --ex) ac_prev=exec_prefix ;; -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ | --exec=* | --exe=* | --ex=*) exec_prefix=$ac_optarg ;; -gas | --gas | --ga | --g) # Obsolete; use --with-gas. with_gas=yes ;; -help | --help | --hel | --he | -h) ac_init_help=long ;; -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) ac_init_help=recursive ;; -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) ac_init_help=short ;; -host | --host | --hos | --ho) ac_prev=host_alias ;; -host=* | --host=* | --hos=* | --ho=*) host_alias=$ac_optarg ;; -htmldir | --htmldir | --htmldi | --htmld | --html | --htm | --ht) ac_prev=htmldir ;; -htmldir=* | --htmldir=* | --htmldi=* | --htmld=* | --html=* | --htm=* \ | --ht=*) htmldir=$ac_optarg ;; -includedir | --includedir | --includedi | --included | --include \ | --includ | --inclu | --incl | --inc) ac_prev=includedir ;; -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ | --includ=* | --inclu=* | --incl=* | --inc=*) includedir=$ac_optarg ;; -infodir | --infodir | --infodi | --infod | --info | --inf) ac_prev=infodir ;; -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) infodir=$ac_optarg ;; -libdir | --libdir | --libdi | --libd) ac_prev=libdir ;; -libdir=* | --libdir=* | --libdi=* | --libd=*) libdir=$ac_optarg ;; -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ | --libexe | --libex | --libe) ac_prev=libexecdir ;; -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ | --libexe=* | --libex=* | --libe=*) libexecdir=$ac_optarg ;; -localedir | --localedir | --localedi | --localed | --locale) ac_prev=localedir ;; -localedir=* | --localedir=* | --localedi=* | --localed=* | --locale=*) localedir=$ac_optarg ;; -localstatedir | --localstatedir | --localstatedi | --localstated \ | --localstate | --localstat | --localsta | --localst | --locals) ac_prev=localstatedir ;; -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ | --localstate=* | --localstat=* | --localsta=* | --localst=* | --locals=*) localstatedir=$ac_optarg ;; -mandir | --mandir | --mandi | --mand | --man | --ma | --m) ac_prev=mandir ;; -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) mandir=$ac_optarg ;; -nfp | --nfp | --nf) # Obsolete; use --without-fp. with_fp=no ;; -no-create | --no-create | --no-creat | --no-crea | --no-cre \ | --no-cr | --no-c | -n) no_create=yes ;; -no-recursion | --no-recursion | --no-recursio | --no-recursi \ | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) no_recursion=yes ;; -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ | --oldin | --oldi | --old | --ol | --o) ac_prev=oldincludedir ;; -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) oldincludedir=$ac_optarg ;; -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) ac_prev=prefix ;; -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) prefix=$ac_optarg ;; -program-prefix | --program-prefix | --program-prefi | --program-pref \ | --program-pre | --program-pr | --program-p) ac_prev=program_prefix ;; -program-prefix=* | --program-prefix=* | --program-prefi=* \ | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) program_prefix=$ac_optarg ;; -program-suffix | --program-suffix | --program-suffi | --program-suff \ | --program-suf | --program-su | --program-s) ac_prev=program_suffix ;; -program-suffix=* | --program-suffix=* | --program-suffi=* \ | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) program_suffix=$ac_optarg ;; -program-transform-name | --program-transform-name \ | --program-transform-nam | --program-transform-na \ | --program-transform-n | --program-transform- \ | --program-transform | --program-transfor \ | --program-transfo | --program-transf \ | --program-trans | --program-tran \ | --progr-tra | --program-tr | --program-t) ac_prev=program_transform_name ;; -program-transform-name=* | --program-transform-name=* \ | --program-transform-nam=* | --program-transform-na=* \ | --program-transform-n=* | --program-transform-=* \ | --program-transform=* | --program-transfor=* \ | --program-transfo=* | --program-transf=* \ | --program-trans=* | --program-tran=* \ | --progr-tra=* | --program-tr=* | --program-t=*) program_transform_name=$ac_optarg ;; -pdfdir | --pdfdir | --pdfdi | --pdfd | --pdf | --pd) ac_prev=pdfdir ;; -pdfdir=* | --pdfdir=* | --pdfdi=* | --pdfd=* | --pdf=* | --pd=*) pdfdir=$ac_optarg ;; -psdir | --psdir | --psdi | --psd | --ps) ac_prev=psdir ;; -psdir=* | --psdir=* | --psdi=* | --psd=* | --ps=*) psdir=$ac_optarg ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil) silent=yes ;; -runstatedir | --runstatedir | --runstatedi | --runstated \ | --runstate | --runstat | --runsta | --runst | --runs \ | --run | --ru | --r) ac_prev=runstatedir ;; -runstatedir=* | --runstatedir=* | --runstatedi=* | --runstated=* \ | --runstate=* | --runstat=* | --runsta=* | --runst=* | --runs=* \ | --run=* | --ru=* | --r=*) runstatedir=$ac_optarg ;; -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) ac_prev=sbindir ;; -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ | --sbi=* | --sb=*) sbindir=$ac_optarg ;; -sharedstatedir | --sharedstatedir | --sharedstatedi \ | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ | --sharedst | --shareds | --shared | --share | --shar \ | --sha | --sh) ac_prev=sharedstatedir ;; -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ | --sha=* | --sh=*) sharedstatedir=$ac_optarg ;; -site | --site | --sit) ac_prev=site ;; -site=* | --site=* | --sit=*) site=$ac_optarg ;; -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) ac_prev=srcdir ;; -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) srcdir=$ac_optarg ;; -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ | --syscon | --sysco | --sysc | --sys | --sy) ac_prev=sysconfdir ;; -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) sysconfdir=$ac_optarg ;; -target | --target | --targe | --targ | --tar | --ta | --t) ac_prev=target_alias ;; -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) target_alias=$ac_optarg ;; -v | -verbose | --verbose | --verbos | --verbo | --verb) verbose=yes ;; -version | --version | --versio | --versi | --vers | -V) ac_init_version=: ;; -with-* | --with-*) ac_useropt=`expr "x$ac_option" : 'x-*with-\([^=]*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid package name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "with_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--with-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval with_$ac_useropt=\$ac_optarg ;; -without-* | --without-*) ac_useropt=`expr "x$ac_option" : 'x-*without-\(.*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid package name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "with_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--without-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval with_$ac_useropt=no ;; --x) # Obsolete; use --with-x. with_x=yes ;; -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ | --x-incl | --x-inc | --x-in | --x-i) ac_prev=x_includes ;; -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) x_includes=$ac_optarg ;; -x-libraries | --x-libraries | --x-librarie | --x-librari \ | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) ac_prev=x_libraries ;; -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) x_libraries=$ac_optarg ;; -*) as_fn_error $? "unrecognized option: \`$ac_option' Try \`$0 --help' for more information" ;; *=*) ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='` # Reject names that are not valid shell variable names. case $ac_envvar in #( '' | [0-9]* | *[!_$as_cr_alnum]* ) as_fn_error $? "invalid variable name: \`$ac_envvar'" ;; esac eval $ac_envvar=\$ac_optarg export $ac_envvar ;; *) # FIXME: should be removed in autoconf 3.0. $as_echo "$as_me: WARNING: you should use --build, --host, --target" >&2 expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && $as_echo "$as_me: WARNING: invalid host type: $ac_option" >&2 : "${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option}" ;; esac done if test -n "$ac_prev"; then ac_option=--`echo $ac_prev | sed 's/_/-/g'` as_fn_error $? "missing argument to $ac_option" fi if test -n "$ac_unrecognized_opts"; then case $enable_option_checking in no) ;; fatal) as_fn_error $? "unrecognized options: $ac_unrecognized_opts" ;; *) $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2 ;; esac fi # Check all directory arguments for consistency. for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ datadir sysconfdir sharedstatedir localstatedir includedir \ oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ libdir localedir mandir runstatedir do eval ac_val=\$$ac_var # Remove trailing slashes. case $ac_val in */ ) ac_val=`expr "X$ac_val" : 'X\(.*[^/]\)' \| "X$ac_val" : 'X\(.*\)'` eval $ac_var=\$ac_val;; esac # Be sure to have absolute directory names. case $ac_val in [\\/$]* | ?:[\\/]* ) continue;; NONE | '' ) case $ac_var in *prefix ) continue;; esac;; esac as_fn_error $? "expected an absolute directory name for --$ac_var: $ac_val" done # There might be people who depend on the old broken behavior: `$host' # used to hold the argument of --host etc. # FIXME: To remove some day. build=$build_alias host=$host_alias target=$target_alias # FIXME: To remove some day. if test "x$host_alias" != x; then if test "x$build_alias" = x; then cross_compiling=maybe elif test "x$build_alias" != "x$host_alias"; then cross_compiling=yes fi fi ac_tool_prefix= test -n "$host_alias" && ac_tool_prefix=$host_alias- test "$silent" = yes && exec 6>/dev/null ac_pwd=`pwd` && test -n "$ac_pwd" && ac_ls_di=`ls -di .` && ac_pwd_ls_di=`cd "$ac_pwd" && ls -di .` || as_fn_error $? "working directory cannot be determined" test "X$ac_ls_di" = "X$ac_pwd_ls_di" || as_fn_error $? "pwd does not report name of working directory" # Find the source files, if location was not specified. if test -z "$srcdir"; then ac_srcdir_defaulted=yes # Try the directory containing this script, then the parent directory. ac_confdir=`$as_dirname -- "$as_myself" || $as_expr X"$as_myself" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_myself" : 'X\(//\)[^/]' \| \ X"$as_myself" : 'X\(//\)$' \| \ X"$as_myself" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$as_myself" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` srcdir=$ac_confdir if test ! -r "$srcdir/$ac_unique_file"; then srcdir=.. fi else ac_srcdir_defaulted=no fi if test ! -r "$srcdir/$ac_unique_file"; then test "$ac_srcdir_defaulted" = yes && srcdir="$ac_confdir or .." as_fn_error $? "cannot find sources ($ac_unique_file) in $srcdir" fi ac_msg="sources are in $srcdir, but \`cd $srcdir' does not work" ac_abs_confdir=`( cd "$srcdir" && test -r "./$ac_unique_file" || as_fn_error $? "$ac_msg" pwd)` # When building in place, set srcdir=. if test "$ac_abs_confdir" = "$ac_pwd"; then srcdir=. fi # Remove unnecessary trailing slashes from srcdir. # Double slashes in file names in object file debugging info # mess up M-x gdb in Emacs. case $srcdir in */) srcdir=`expr "X$srcdir" : 'X\(.*[^/]\)' \| "X$srcdir" : 'X\(.*\)'`;; esac for ac_var in $ac_precious_vars; do eval ac_env_${ac_var}_set=\${${ac_var}+set} eval ac_env_${ac_var}_value=\$${ac_var} eval ac_cv_env_${ac_var}_set=\${${ac_var}+set} eval ac_cv_env_${ac_var}_value=\$${ac_var} done # # Report the --help message. # if test "$ac_init_help" = "long"; then # Omit some internal or obsolete options to make the list less imposing. # This message is too long to be a string in the A/UX 3.1 sh. cat <<_ACEOF \`configure' configures eztrace 1.1-2 to adapt to many kinds of systems. Usage: $0 [OPTION]... [VAR=VALUE]... To assign environment variables (e.g., CC, CFLAGS...), specify them as VAR=VALUE. See below for descriptions of some of the useful variables. Defaults for the options are specified in brackets. Configuration: -h, --help display this help and exit --help=short display options specific to this package --help=recursive display the short help of all the included packages -V, --version display version information and exit -q, --quiet, --silent do not print \`checking ...' messages --cache-file=FILE cache test results in FILE [disabled] -C, --config-cache alias for \`--cache-file=config.cache' -n, --no-create do not create output files --srcdir=DIR find the sources in DIR [configure dir or \`..'] Installation directories: --prefix=PREFIX install architecture-independent files in PREFIX [$ac_default_prefix] --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX [PREFIX] By default, \`make install' will install all the files in \`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify an installation prefix other than \`$ac_default_prefix' using \`--prefix', for instance \`--prefix=\$HOME'. For better control, use the options below. Fine tuning of the installation directories: --bindir=DIR user executables [EPREFIX/bin] --sbindir=DIR system admin executables [EPREFIX/sbin] --libexecdir=DIR program executables [EPREFIX/libexec] --sysconfdir=DIR read-only single-machine data [PREFIX/etc] --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] --localstatedir=DIR modifiable single-machine data [PREFIX/var] --runstatedir=DIR modifiable per-process data [LOCALSTATEDIR/run] --libdir=DIR object code libraries [EPREFIX/lib] --includedir=DIR C header files [PREFIX/include] --oldincludedir=DIR C header files for non-gcc [/usr/include] --datarootdir=DIR read-only arch.-independent data root [PREFIX/share] --datadir=DIR read-only architecture-independent data [DATAROOTDIR] --infodir=DIR info documentation [DATAROOTDIR/info] --localedir=DIR locale-dependent data [DATAROOTDIR/locale] --mandir=DIR man documentation [DATAROOTDIR/man] --docdir=DIR documentation root [DATAROOTDIR/doc/eztrace] --htmldir=DIR html documentation [DOCDIR] --dvidir=DIR dvi documentation [DOCDIR] --pdfdir=DIR pdf documentation [DOCDIR] --psdir=DIR ps documentation [DOCDIR] _ACEOF cat <<\_ACEOF Program names: --program-prefix=PREFIX prepend PREFIX to installed program names --program-suffix=SUFFIX append SUFFIX to installed program names --program-transform-name=PROGRAM run sed PROGRAM on installed program names System types: --build=BUILD configure for building on BUILD [guessed] --host=HOST cross-compile to build programs to run on HOST [BUILD] _ACEOF fi if test -n "$ac_init_help"; then case $ac_init_help in short | recursive ) echo "Configuration of eztrace 1.1-2:";; esac cat <<\_ACEOF Optional Features: --disable-option-checking ignore unrecognized --enable/--with options --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) --enable-FEATURE[=ARG] include FEATURE [ARG=yes] --enable-silent-rules less verbose build output (undo: "make V=1") --disable-silent-rules verbose build output (undo: "make V=0") --enable-dependency-tracking do not reject slow dependency extractors --disable-dependency-tracking speeds up one-time build --enable-shared[=PKGS] build shared libraries [default=yes] --enable-static[=PKGS] build static libraries [default=yes] --enable-fast-install[=PKGS] optimize for fast installation [default=yes] --disable-libtool-lock avoid locking (might break parallel builds) --enable-pptrace Enable pptrace --enable-gettid Use syscall(SYS_gettid) to get the thread ID instead of pthread_self(). This however costs a system call for each trace entry Optional Packages: --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) --with-pic[=PKGS] try to use only PIC/non-PIC objects [default=use both] --with-gnu-ld assume the C compiler uses GNU ld [default=no] --with-sysroot=DIR Search for dependent libraries within DIR (or the compiler's sysroot if not specified). --with-doc Generate documentation --with-starpu= generate traces for StarPU --with-litl= or = generate LiTL traces [ARG=yes] --with-papi= PAPI --with-mpi= Use a specific MPI installation --with-mpi-include= Use a specific MPI header --with-mpi-ldflags= Use a specific LDFLAGS when compiling MPI files --with-mpi-module-name= Change the name of the MPI module --with-mpi-event-id=id> Change the ID of the MPI events --with-gtg= path to libgtg --with-cuda= Use a specific CUDA installation Some influential environment variables: CC C compiler command CFLAGS C compiler flags LDFLAGS linker flags, e.g. -L if you have libraries in a nonstandard directory LIBS libraries to pass to the linker, e.g. -l CPPFLAGS (Objective) C/C++ preprocessor flags, e.g. -I if you have headers in a nonstandard directory FC Fortran compiler command FCFLAGS Fortran compiler flags CXX C++ compiler command CXXFLAGS C++ compiler flags CPP C preprocessor CXXCPP C++ preprocessor PKG_CONFIG path to pkg-config utility PKG_CONFIG_PATH directories to add to pkg-config's search path PKG_CONFIG_LIBDIR path overriding pkg-config's built-in search path STARPU_CFLAGS C compiler flags for STARPU, overriding pkg-config STARPU_LIBS linker flags for STARPU, overriding pkg-config Use these variables to override the choices made by `configure' or to help it to find libraries and programs with nonstandard names/locations. Report bugs to . _ACEOF ac_status=$? fi if test "$ac_init_help" = "recursive"; then # If there are subdirs, report their specific --help. for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue test -d "$ac_dir" || { cd "$srcdir" && ac_pwd=`pwd` && srcdir=. && test -d "$ac_dir"; } || continue ac_builddir=. case "$ac_dir" in .) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` # A ".." for each directory in $ac_dir_suffix. ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` case $ac_top_builddir_sub in "") ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; esac ;; esac ac_abs_top_builddir=$ac_pwd ac_abs_builddir=$ac_pwd$ac_dir_suffix # for backward compatibility: ac_top_builddir=$ac_top_build_prefix case $srcdir in .) # We are building in place. ac_srcdir=. ac_top_srcdir=$ac_top_builddir_sub ac_abs_top_srcdir=$ac_pwd ;; [\\/]* | ?:[\\/]* ) # Absolute name. ac_srcdir=$srcdir$ac_dir_suffix; ac_top_srcdir=$srcdir ac_abs_top_srcdir=$srcdir ;; *) # Relative name. ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix ac_top_srcdir=$ac_top_build_prefix$srcdir ac_abs_top_srcdir=$ac_pwd/$srcdir ;; esac ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix cd "$ac_dir" || { ac_status=$?; continue; } # Check for guested configure. if test -f "$ac_srcdir/configure.gnu"; then echo && $SHELL "$ac_srcdir/configure.gnu" --help=recursive elif test -f "$ac_srcdir/configure"; then echo && $SHELL "$ac_srcdir/configure" --help=recursive else $as_echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2 fi || ac_status=$? cd "$ac_pwd" || { ac_status=$?; break; } done fi test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF eztrace configure 1.1-2 generated by GNU Autoconf 2.69 Copyright (C) 2012 Free Software Foundation, Inc. This configure script is free software; the Free Software Foundation gives unlimited permission to copy, distribute and modify it. _ACEOF exit fi ## ------------------------ ## ## Autoconf initialization. ## ## ------------------------ ## # ac_fn_c_try_compile LINENO # -------------------------- # Try to compile conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_c_werror_flag" || test ! -s conftest.err } && test -s conftest.$ac_objext; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_compile # ac_fn_fc_try_compile LINENO # --------------------------- # Try to compile conftest.$ac_ext, and return whether this succeeded. ac_fn_fc_try_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_fc_werror_flag" || test ! -s conftest.err } && test -s conftest.$ac_objext; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_fc_try_compile # ac_fn_cxx_try_compile LINENO # ---------------------------- # Try to compile conftest.$ac_ext, and return whether this succeeded. ac_fn_cxx_try_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_cxx_werror_flag" || test ! -s conftest.err } && test -s conftest.$ac_objext; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_compile # ac_fn_c_try_link LINENO # ----------------------- # Try to link conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_link () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext conftest$ac_exeext if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_c_werror_flag" || test ! -s conftest.err } && test -s conftest$ac_exeext && { test "$cross_compiling" = yes || test -x conftest$ac_exeext }; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would # interfere with the next link command; also delete a directory that is # left behind by Apple's compiler. We do this before executing the actions. rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_link # ac_fn_c_check_header_compile LINENO HEADER VAR INCLUDES # ------------------------------------------------------- # Tests whether HEADER exists and can be compiled using the include files in # INCLUDES, setting the cache variable VAR accordingly. ac_fn_c_check_header_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 #include <$2> _ACEOF if ac_fn_c_try_compile "$LINENO"; then : eval "$3=yes" else eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_header_compile # ac_fn_c_try_cpp LINENO # ---------------------- # Try to preprocess conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_cpp () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_cpp conftest.$ac_ext" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_cpp conftest.$ac_ext") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } > conftest.i && { test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || test ! -s conftest.err }; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_cpp # ac_fn_c_try_run LINENO # ---------------------- # Try to link conftest.$ac_ext, and return whether this succeeded. Assumes # that executables *can* be run. ac_fn_c_try_run () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { ac_try='./conftest$ac_exeext' { { case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_try") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; }; then : ac_retval=0 else $as_echo "$as_me: program exited with status $ac_status" >&5 $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=$ac_status fi rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_run # ac_fn_c_check_func LINENO FUNC VAR # ---------------------------------- # Tests whether FUNC exists, setting the cache variable VAR accordingly ac_fn_c_check_func () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Define $2 to an innocuous variant, in case declares $2. For example, HP-UX 11i declares gettimeofday. */ #define $2 innocuous_$2 /* System header to define __stub macros and hopefully few prototypes, which can conflict with char $2 (); below. Prefer to if __STDC__ is defined, since exists even on freestanding compilers. */ #ifdef __STDC__ # include #else # include #endif #undef $2 /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char $2 (); /* The GNU C library defines this for functions which it implements to always fail with ENOSYS. Some functions are actually named something starting with __ and the normal name is an alias. */ #if defined __stub_$2 || defined __stub___$2 choke me #endif int main () { return $2 (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : eval "$3=yes" else eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_func # ac_fn_cxx_try_cpp LINENO # ------------------------ # Try to preprocess conftest.$ac_ext, and return whether this succeeded. ac_fn_cxx_try_cpp () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_cpp conftest.$ac_ext" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_cpp conftest.$ac_ext") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } > conftest.i && { test -z "$ac_cxx_preproc_warn_flag$ac_cxx_werror_flag" || test ! -s conftest.err }; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_cpp # ac_fn_cxx_try_link LINENO # ------------------------- # Try to link conftest.$ac_ext, and return whether this succeeded. ac_fn_cxx_try_link () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext conftest$ac_exeext if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_cxx_werror_flag" || test ! -s conftest.err } && test -s conftest$ac_exeext && { test "$cross_compiling" = yes || test -x conftest$ac_exeext }; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would # interfere with the next link command; also delete a directory that is # left behind by Apple's compiler. We do this before executing the actions. rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_link # ac_fn_fc_try_link LINENO # ------------------------ # Try to link conftest.$ac_ext, and return whether this succeeded. ac_fn_fc_try_link () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext conftest$ac_exeext if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_fc_werror_flag" || test ! -s conftest.err } && test -s conftest$ac_exeext && { test "$cross_compiling" = yes || test -x conftest$ac_exeext }; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would # interfere with the next link command; also delete a directory that is # left behind by Apple's compiler. We do this before executing the actions. rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_fc_try_link # ac_fn_cxx_check_decl LINENO SYMBOL VAR INCLUDES # ----------------------------------------------- # Tests whether SYMBOL is declared in INCLUDES, setting cache variable VAR # accordingly. ac_fn_cxx_check_decl () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack as_decl_name=`echo $2|sed 's/ *(.*//'` as_decl_use=`echo $2|sed -e 's/(/((/' -e 's/)/) 0&/' -e 's/,/) 0& (/g'` { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $as_decl_name is declared" >&5 $as_echo_n "checking whether $as_decl_name is declared... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 int main () { #ifndef $as_decl_name #ifdef __cplusplus (void) $as_decl_use; #else (void) $as_decl_name; #endif #endif ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO"; then : eval "$3=yes" else eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_cxx_check_decl # ac_fn_cxx_check_header_mongrel LINENO HEADER VAR INCLUDES # --------------------------------------------------------- # Tests whether HEADER exists, giving a warning if it cannot be compiled using # the include files in INCLUDES and setting the cache variable VAR # accordingly. ac_fn_cxx_check_header_mongrel () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if eval \${$3+:} false; then : { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } else # Is the header compilable? { $as_echo "$as_me:${as_lineno-$LINENO}: checking $2 usability" >&5 $as_echo_n "checking $2 usability... " >&6; } cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 #include <$2> _ACEOF if ac_fn_cxx_try_compile "$LINENO"; then : ac_header_compiler=yes else ac_header_compiler=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_header_compiler" >&5 $as_echo "$ac_header_compiler" >&6; } # Is the header present? { $as_echo "$as_me:${as_lineno-$LINENO}: checking $2 presence" >&5 $as_echo_n "checking $2 presence... " >&6; } cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include <$2> _ACEOF if ac_fn_cxx_try_cpp "$LINENO"; then : ac_header_preproc=yes else ac_header_preproc=no fi rm -f conftest.err conftest.i conftest.$ac_ext { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_header_preproc" >&5 $as_echo "$ac_header_preproc" >&6; } # So? What about this header? case $ac_header_compiler:$ac_header_preproc:$ac_cxx_preproc_warn_flag in #(( yes:no: ) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: accepted by the compiler, rejected by the preprocessor!" >&5 $as_echo "$as_me: WARNING: $2: accepted by the compiler, rejected by the preprocessor!" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: proceeding with the compiler's result" >&5 $as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} ;; no:yes:* ) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: present but cannot be compiled" >&5 $as_echo "$as_me: WARNING: $2: present but cannot be compiled" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: check for missing prerequisite headers?" >&5 $as_echo "$as_me: WARNING: $2: check for missing prerequisite headers?" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: see the Autoconf documentation" >&5 $as_echo "$as_me: WARNING: $2: see the Autoconf documentation" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: section \"Present But Cannot Be Compiled\"" >&5 $as_echo "$as_me: WARNING: $2: section \"Present But Cannot Be Compiled\"" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: proceeding with the compiler's result" >&5 $as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} ( $as_echo "## -------------------------------------------------- ## ## Report this to eztrace-devel@lists.gforge.inria.fr ## ## -------------------------------------------------- ##" ) | sed "s/^/$as_me: WARNING: /" >&2 ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else eval "$3=\$ac_header_compiler" fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_cxx_check_header_mongrel # ac_fn_cxx_check_type LINENO TYPE VAR INCLUDES # --------------------------------------------- # Tests whether TYPE exists after having included INCLUDES, setting cache # variable VAR accordingly. ac_fn_cxx_check_type () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else eval "$3=no" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 int main () { if (sizeof ($2)) return 0; ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO"; then : cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 int main () { if (sizeof (($2))) return 0; ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO"; then : else eval "$3=yes" fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_cxx_check_type # ac_fn_c_find_uintX_t LINENO BITS VAR # ------------------------------------ # Finds an unsigned integer type with width BITS, setting cache variable VAR # accordingly. ac_fn_c_find_uintX_t () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for uint$2_t" >&5 $as_echo_n "checking for uint$2_t... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else eval "$3=no" # Order is important - never check a type that is potentially smaller # than half of the expected target width. for ac_type in uint$2_t 'unsigned int' 'unsigned long int' \ 'unsigned long long int' 'unsigned short int' 'unsigned char'; do cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $ac_includes_default int main () { static int test_array [1 - 2 * !((($ac_type) -1 >> ($2 / 2 - 1)) >> ($2 / 2 - 1) == 3)]; test_array [0] = 0; return test_array [0]; ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO"; then : case $ac_type in #( uint$2_t) : eval "$3=yes" ;; #( *) : eval "$3=\$ac_type" ;; esac fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext if eval test \"x\$"$3"\" = x"no"; then : else break fi done fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_find_uintX_t # ac_fn_cxx_try_run LINENO # ------------------------ # Try to link conftest.$ac_ext, and return whether this succeeded. Assumes # that executables *can* be run. ac_fn_cxx_try_run () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { ac_try='./conftest$ac_exeext' { { case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_try") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; }; then : ac_retval=0 else $as_echo "$as_me: program exited with status $ac_status" >&5 $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=$ac_status fi rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_run # ac_fn_cxx_check_func LINENO FUNC VAR # ------------------------------------ # Tests whether FUNC exists, setting the cache variable VAR accordingly ac_fn_cxx_check_func () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Define $2 to an innocuous variant, in case declares $2. For example, HP-UX 11i declares gettimeofday. */ #define $2 innocuous_$2 /* System header to define __stub macros and hopefully few prototypes, which can conflict with char $2 (); below. Prefer to if __STDC__ is defined, since exists even on freestanding compilers. */ #ifdef __STDC__ # include #else # include #endif #undef $2 /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char $2 (); /* The GNU C library defines this for functions which it implements to always fail with ENOSYS. Some functions are actually named something starting with __ and the normal name is an alias. */ #if defined __stub_$2 || defined __stub___$2 choke me #endif int main () { return $2 (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : eval "$3=yes" else eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_cxx_check_func cat >config.log <<_ACEOF This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. It was created by eztrace $as_me 1.1-2, which was generated by GNU Autoconf 2.69. Invocation command line was $ $0 $@ _ACEOF exec 5>>config.log { cat <<_ASUNAME ## --------- ## ## Platform. ## ## --------- ## hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` uname -m = `(uname -m) 2>/dev/null || echo unknown` uname -r = `(uname -r) 2>/dev/null || echo unknown` uname -s = `(uname -s) 2>/dev/null || echo unknown` uname -v = `(uname -v) 2>/dev/null || echo unknown` /usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` /bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` /bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` /usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` /usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` /usr/bin/hostinfo = `(/usr/bin/hostinfo) 2>/dev/null || echo unknown` /bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` /usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` /bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` _ASUNAME as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. $as_echo "PATH: $as_dir" done IFS=$as_save_IFS } >&5 cat >&5 <<_ACEOF ## ----------- ## ## Core tests. ## ## ----------- ## _ACEOF # Keep a trace of the command line. # Strip out --no-create and --no-recursion so they do not pile up. # Strip out --silent because we don't want to record it for future runs. # Also quote any args containing shell meta-characters. # Make two passes to allow for proper duplicate-argument suppression. ac_configure_args= ac_configure_args0= ac_configure_args1= ac_must_keep_next=false for ac_pass in 1 2 do for ac_arg do case $ac_arg in -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil) continue ;; *\'*) ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; esac case $ac_pass in 1) as_fn_append ac_configure_args0 " '$ac_arg'" ;; 2) as_fn_append ac_configure_args1 " '$ac_arg'" if test $ac_must_keep_next = true; then ac_must_keep_next=false # Got value, back to normal. else case $ac_arg in *=* | --config-cache | -C | -disable-* | --disable-* \ | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ | -with-* | --with-* | -without-* | --without-* | --x) case "$ac_configure_args0 " in "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; esac ;; -* ) ac_must_keep_next=true ;; esac fi as_fn_append ac_configure_args " '$ac_arg'" ;; esac done done { ac_configure_args0=; unset ac_configure_args0;} { ac_configure_args1=; unset ac_configure_args1;} # When interrupted or exit'd, cleanup temporary files, and complete # config.log. We remove comments because anyway the quotes in there # would cause problems or look ugly. # WARNING: Use '\'' to represent an apostrophe within the trap. # WARNING: Do not start the trap code with a newline, due to a FreeBSD 4.0 bug. trap 'exit_status=$? # Save into config.log some information that might help in debugging. { echo $as_echo "## ---------------- ## ## Cache variables. ## ## ---------------- ##" echo # The following way of writing the cache mishandles newlines in values, ( for ac_var in `(set) 2>&1 | sed -n '\''s/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'\''`; do eval ac_val=\$$ac_var case $ac_val in #( *${as_nl}*) case $ac_var in #( *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 $as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; esac case $ac_var in #( _ | IFS | as_nl) ;; #( BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( *) { eval $ac_var=; unset $ac_var;} ;; esac ;; esac done (set) 2>&1 | case $as_nl`(ac_space='\'' '\''; set) 2>&1` in #( *${as_nl}ac_space=\ *) sed -n \ "s/'\''/'\''\\\\'\'''\''/g; s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\''\\2'\''/p" ;; #( *) sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" ;; esac | sort ) echo $as_echo "## ----------------- ## ## Output variables. ## ## ----------------- ##" echo for ac_var in $ac_subst_vars do eval ac_val=\$$ac_var case $ac_val in *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; esac $as_echo "$ac_var='\''$ac_val'\''" done | sort echo if test -n "$ac_subst_files"; then $as_echo "## ------------------- ## ## File substitutions. ## ## ------------------- ##" echo for ac_var in $ac_subst_files do eval ac_val=\$$ac_var case $ac_val in *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; esac $as_echo "$ac_var='\''$ac_val'\''" done | sort echo fi if test -s confdefs.h; then $as_echo "## ----------- ## ## confdefs.h. ## ## ----------- ##" echo cat confdefs.h echo fi test "$ac_signal" != 0 && $as_echo "$as_me: caught signal $ac_signal" $as_echo "$as_me: exit $exit_status" } >&5 rm -f core *.core core.conftest.* && rm -f -r conftest* confdefs* conf$$* $ac_clean_files && exit $exit_status ' 0 for ac_signal in 1 2 13 15; do trap 'ac_signal='$ac_signal'; as_fn_exit 1' $ac_signal done ac_signal=0 # confdefs.h avoids OS command line length limits that DEFS can exceed. rm -f -r conftest* confdefs.h $as_echo "/* confdefs.h */" > confdefs.h # Predefined preprocessor variables. cat >>confdefs.h <<_ACEOF #define PACKAGE_NAME "$PACKAGE_NAME" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_TARNAME "$PACKAGE_TARNAME" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_VERSION "$PACKAGE_VERSION" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_STRING "$PACKAGE_STRING" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_URL "$PACKAGE_URL" _ACEOF # Let the site file select an alternate cache file if it wants to. # Prefer an explicitly selected file to automatically selected ones. ac_site_file1=NONE ac_site_file2=NONE if test -n "$CONFIG_SITE"; then # We do not want a PATH search for config.site. case $CONFIG_SITE in #(( -*) ac_site_file1=./$CONFIG_SITE;; */*) ac_site_file1=$CONFIG_SITE;; *) ac_site_file1=./$CONFIG_SITE;; esac elif test "x$prefix" != xNONE; then ac_site_file1=$prefix/share/config.site ac_site_file2=$prefix/etc/config.site else ac_site_file1=$ac_default_prefix/share/config.site ac_site_file2=$ac_default_prefix/etc/config.site fi for ac_site_file in "$ac_site_file1" "$ac_site_file2" do test "x$ac_site_file" = xNONE && continue if test /dev/null != "$ac_site_file" && test -r "$ac_site_file"; then { $as_echo "$as_me:${as_lineno-$LINENO}: loading site script $ac_site_file" >&5 $as_echo "$as_me: loading site script $ac_site_file" >&6;} sed 's/^/| /' "$ac_site_file" >&5 . "$ac_site_file" \ || { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "failed to load site script $ac_site_file See \`config.log' for more details" "$LINENO" 5; } fi done if test -r "$cache_file"; then # Some versions of bash will fail to source /dev/null (special files # actually), so we avoid doing that. DJGPP emulates it as a regular file. if test /dev/null != "$cache_file" && test -f "$cache_file"; then { $as_echo "$as_me:${as_lineno-$LINENO}: loading cache $cache_file" >&5 $as_echo "$as_me: loading cache $cache_file" >&6;} case $cache_file in [\\/]* | ?:[\\/]* ) . "$cache_file";; *) . "./$cache_file";; esac fi else { $as_echo "$as_me:${as_lineno-$LINENO}: creating cache $cache_file" >&5 $as_echo "$as_me: creating cache $cache_file" >&6;} >$cache_file fi # Check that the precious variables saved in the cache have kept the same # value. ac_cache_corrupted=false for ac_var in $ac_precious_vars; do eval ac_old_set=\$ac_cv_env_${ac_var}_set eval ac_new_set=\$ac_env_${ac_var}_set eval ac_old_val=\$ac_cv_env_${ac_var}_value eval ac_new_val=\$ac_env_${ac_var}_value case $ac_old_set,$ac_new_set in set,) { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 $as_echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} ac_cache_corrupted=: ;; ,set) { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was not set in the previous run" >&5 $as_echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} ac_cache_corrupted=: ;; ,);; *) if test "x$ac_old_val" != "x$ac_new_val"; then # differences in whitespace do not lead to failure. ac_old_val_w=`echo x $ac_old_val` ac_new_val_w=`echo x $ac_new_val` if test "$ac_old_val_w" != "$ac_new_val_w"; then { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' has changed since the previous run:" >&5 $as_echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} ac_cache_corrupted=: else { $as_echo "$as_me:${as_lineno-$LINENO}: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&5 $as_echo "$as_me: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&2;} eval $ac_var=\$ac_old_val fi { $as_echo "$as_me:${as_lineno-$LINENO}: former value: \`$ac_old_val'" >&5 $as_echo "$as_me: former value: \`$ac_old_val'" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: current value: \`$ac_new_val'" >&5 $as_echo "$as_me: current value: \`$ac_new_val'" >&2;} fi;; esac # Pass precious variables to config.status. if test "$ac_new_set" = set; then case $ac_new_val in *\'*) ac_arg=$ac_var=`$as_echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; *) ac_arg=$ac_var=$ac_new_val ;; esac case " $ac_configure_args " in *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. *) as_fn_append ac_configure_args " '$ac_arg'" ;; esac fi done if $ac_cache_corrupted; then { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: error: changes in the environment can compromise the build" >&5 $as_echo "$as_me: error: changes in the environment can compromise the build" >&2;} as_fn_error $? "run \`make distclean' and/or \`rm $cache_file' and start over" "$LINENO" 5 fi ## -------------------- ## ## Main body of script. ## ## -------------------- ## ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu am__api_version='1.15' ac_aux_dir= for ac_dir in "$srcdir" "$srcdir/.." "$srcdir/../.."; do if test -f "$ac_dir/install-sh"; then ac_aux_dir=$ac_dir ac_install_sh="$ac_aux_dir/install-sh -c" break elif test -f "$ac_dir/install.sh"; then ac_aux_dir=$ac_dir ac_install_sh="$ac_aux_dir/install.sh -c" break elif test -f "$ac_dir/shtool"; then ac_aux_dir=$ac_dir ac_install_sh="$ac_aux_dir/shtool install -c" break fi done if test -z "$ac_aux_dir"; then as_fn_error $? "cannot find install-sh, install.sh, or shtool in \"$srcdir\" \"$srcdir/..\" \"$srcdir/../..\"" "$LINENO" 5 fi # These three variables are undocumented and unsupported, # and are intended to be withdrawn in a future Autoconf release. # They can cause serious problems if a builder's source tree is in a directory # whose full name contains unusual characters. ac_config_guess="$SHELL $ac_aux_dir/config.guess" # Please don't use this var. ac_config_sub="$SHELL $ac_aux_dir/config.sub" # Please don't use this var. ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. # Find a good install program. We prefer a C program (faster), # so one script is as good as another. But avoid the broken or # incompatible versions: # SysV /etc/install, /usr/sbin/install # SunOS /usr/etc/install # IRIX /sbin/install # AIX /bin/install # AmigaOS /C/install, which installs bootblocks on floppy discs # AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag # AFS /usr/afsws/bin/install, which mishandles nonexistent args # SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" # OS/2's system install, which has a completely different semantic # ./install, which can be erroneously created by make from ./install.sh. # Reject install programs that cannot install multiple files. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a BSD-compatible install" >&5 $as_echo_n "checking for a BSD-compatible install... " >&6; } if test -z "$INSTALL"; then if ${ac_cv_path_install+:} false; then : $as_echo_n "(cached) " >&6 else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. # Account for people who put trailing slashes in PATH elements. case $as_dir/ in #(( ./ | .// | /[cC]/* | \ /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ ?:[\\/]os2[\\/]install[\\/]* | ?:[\\/]OS2[\\/]INSTALL[\\/]* | \ /usr/ucb/* ) ;; *) # OSF1 and SCO ODT 3.0 have their own names for install. # Don't use installbsd from OSF since it installs stuff as root # by default. for ac_prog in ginstall scoinst install; do for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then if test $ac_prog = install && grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then # AIX install. It has an incompatible calling convention. : elif test $ac_prog = install && grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then # program-specific install script used by HP pwplus--don't use. : else rm -rf conftest.one conftest.two conftest.dir echo one > conftest.one echo two > conftest.two mkdir conftest.dir if "$as_dir/$ac_prog$ac_exec_ext" -c conftest.one conftest.two "`pwd`/conftest.dir" && test -s conftest.one && test -s conftest.two && test -s conftest.dir/conftest.one && test -s conftest.dir/conftest.two then ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" break 3 fi fi fi done done ;; esac done IFS=$as_save_IFS rm -rf conftest.one conftest.two conftest.dir fi if test "${ac_cv_path_install+set}" = set; then INSTALL=$ac_cv_path_install else # As a last resort, use the slow shell script. Don't cache a # value for INSTALL within a source directory, because that will # break other packages using the cache if that directory is # removed, or if the value is a relative name. INSTALL=$ac_install_sh fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $INSTALL" >&5 $as_echo "$INSTALL" >&6; } # Use test -z because SunOS4 sh mishandles braces in ${var-val}. # It thinks the first close brace ends the variable substitution. test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether build environment is sane" >&5 $as_echo_n "checking whether build environment is sane... " >&6; } # Reject unsafe characters in $srcdir or the absolute working directory # name. Accept space and tab only in the latter. am_lf=' ' case `pwd` in *[\\\"\#\$\&\'\`$am_lf]*) as_fn_error $? "unsafe absolute working directory name" "$LINENO" 5;; esac case $srcdir in *[\\\"\#\$\&\'\`$am_lf\ \ ]*) as_fn_error $? "unsafe srcdir value: '$srcdir'" "$LINENO" 5;; esac # Do 'set' in a subshell so we don't clobber the current shell's # arguments. Must try -L first in case configure is actually a # symlink; some systems play weird games with the mod time of symlinks # (eg FreeBSD returns the mod time of the symlink's containing # directory). if ( am_has_slept=no for am_try in 1 2; do echo "timestamp, slept: $am_has_slept" > conftest.file set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` if test "$*" = "X"; then # -L didn't work. set X `ls -t "$srcdir/configure" conftest.file` fi if test "$*" != "X $srcdir/configure conftest.file" \ && test "$*" != "X conftest.file $srcdir/configure"; then # If neither matched, then we have a broken ls. This can happen # if, for instance, CONFIG_SHELL is bash and it inherits a # broken ls alias from the environment. This has actually # happened. Such a system could not be considered "sane". as_fn_error $? "ls -t appears to fail. Make sure there is not a broken alias in your environment" "$LINENO" 5 fi if test "$2" = conftest.file || test $am_try -eq 2; then break fi # Just in case. sleep 1 am_has_slept=yes done test "$2" = conftest.file ) then # Ok. : else as_fn_error $? "newly created file is older than distributed files! Check your system clock" "$LINENO" 5 fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } # If we didn't sleep, we still need to ensure time stamps of config.status and # generated files are strictly newer. am_sleep_pid= if grep 'slept: no' conftest.file >/dev/null 2>&1; then ( sleep 1 ) & am_sleep_pid=$! fi rm -f conftest.file test "$program_prefix" != NONE && program_transform_name="s&^&$program_prefix&;$program_transform_name" # Use a double $ so make ignores it. test "$program_suffix" != NONE && program_transform_name="s&\$&$program_suffix&;$program_transform_name" # Double any \ or $. # By default was `s,x,x', remove it if useless. ac_script='s/[\\$]/&&/g;s/;s,x,x,$//' program_transform_name=`$as_echo "$program_transform_name" | sed "$ac_script"` # Expand $ac_aux_dir to an absolute path. am_aux_dir=`cd "$ac_aux_dir" && pwd` if test x"${MISSING+set}" != xset; then case $am_aux_dir in *\ * | *\ *) MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; *) MISSING="\${SHELL} $am_aux_dir/missing" ;; esac fi # Use eval to expand $SHELL if eval "$MISSING --is-lightweight"; then am_missing_run="$MISSING " else am_missing_run= { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: 'missing' script is too old or missing" >&5 $as_echo "$as_me: WARNING: 'missing' script is too old or missing" >&2;} fi if test x"${install_sh+set}" != xset; then case $am_aux_dir in *\ * | *\ *) install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; *) install_sh="\${SHELL} $am_aux_dir/install-sh" esac fi # Installed binaries are usually stripped using 'strip' when the user # run "make install-strip". However 'strip' might not be the right # tool to use in cross-compilation environments, therefore Automake # will honor the 'STRIP' environment variable to overrule this program. if test "$cross_compiling" != no; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. set dummy ${ac_tool_prefix}strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$STRIP"; then ac_cv_prog_STRIP="$STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_STRIP="${ac_tool_prefix}strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi STRIP=$ac_cv_prog_STRIP if test -n "$STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 $as_echo "$STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_STRIP"; then ac_ct_STRIP=$STRIP # Extract the first word of "strip", so it can be a program name with args. set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_STRIP"; then ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_STRIP="strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP if test -n "$ac_ct_STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 $as_echo "$ac_ct_STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_STRIP" = x; then STRIP=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac STRIP=$ac_ct_STRIP fi else STRIP="$ac_cv_prog_STRIP" fi fi INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a thread-safe mkdir -p" >&5 $as_echo_n "checking for a thread-safe mkdir -p... " >&6; } if test -z "$MKDIR_P"; then if ${ac_cv_path_mkdir+:} false; then : $as_echo_n "(cached) " >&6 else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/opt/sfw/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in mkdir gmkdir; do for ac_exec_ext in '' $ac_executable_extensions; do as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext" || continue case `"$as_dir/$ac_prog$ac_exec_ext" --version 2>&1` in #( 'mkdir (GNU coreutils) '* | \ 'mkdir (coreutils) '* | \ 'mkdir (fileutils) '4.1*) ac_cv_path_mkdir=$as_dir/$ac_prog$ac_exec_ext break 3;; esac done done done IFS=$as_save_IFS fi test -d ./--version && rmdir ./--version if test "${ac_cv_path_mkdir+set}" = set; then MKDIR_P="$ac_cv_path_mkdir -p" else # As a last resort, use the slow shell script. Don't cache a # value for MKDIR_P within a source directory, because that will # break other packages using the cache if that directory is # removed, or if the value is a relative name. MKDIR_P="$ac_install_sh -d" fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MKDIR_P" >&5 $as_echo "$MKDIR_P" >&6; } for ac_prog in gawk mawk nawk awk do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_AWK+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$AWK"; then ac_cv_prog_AWK="$AWK" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_AWK="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi AWK=$ac_cv_prog_AWK if test -n "$AWK"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AWK" >&5 $as_echo "$AWK" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$AWK" && break done { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} sets \$(MAKE)" >&5 $as_echo_n "checking whether ${MAKE-make} sets \$(MAKE)... " >&6; } set x ${MAKE-make} ac_make=`$as_echo "$2" | sed 's/+/p/g; s/[^a-zA-Z0-9_]/_/g'` if eval \${ac_cv_prog_make_${ac_make}_set+:} false; then : $as_echo_n "(cached) " >&6 else cat >conftest.make <<\_ACEOF SHELL = /bin/sh all: @echo '@@@%%%=$(MAKE)=@@@%%%' _ACEOF # GNU make sometimes prints "make[1]: Entering ...", which would confuse us. case `${MAKE-make} -f conftest.make 2>/dev/null` in *@@@%%%=?*=@@@%%%*) eval ac_cv_prog_make_${ac_make}_set=yes;; *) eval ac_cv_prog_make_${ac_make}_set=no;; esac rm -f conftest.make fi if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } SET_MAKE= else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } SET_MAKE="MAKE=${MAKE-make}" fi rm -rf .tst 2>/dev/null mkdir .tst 2>/dev/null if test -d .tst; then am__leading_dot=. else am__leading_dot=_ fi rmdir .tst 2>/dev/null # Check whether --enable-silent-rules was given. if test "${enable_silent_rules+set}" = set; then : enableval=$enable_silent_rules; fi case $enable_silent_rules in # ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=1;; esac am_make=${MAKE-make} { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 $as_echo_n "checking whether $am_make supports nested variables... " >&6; } if ${am_cv_make_support_nested_variables+:} false; then : $as_echo_n "(cached) " >&6 else if $as_echo 'TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit' | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_make_support_nested_variables" >&5 $as_echo "$am_cv_make_support_nested_variables" >&6; } if test $am_cv_make_support_nested_variables = yes; then AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AM_BACKSLASH='\' if test "`cd $srcdir && pwd`" != "`pwd`"; then # Use -I$(srcdir) only when $(srcdir) != ., so that make's output # is not polluted with repeated "-I." am__isrc=' -I$(srcdir)' # test to see if srcdir already configured if test -f $srcdir/config.status; then as_fn_error $? "source directory already configured; run \"make distclean\" there first" "$LINENO" 5 fi fi # test whether we have cygpath if test -z "$CYGPATH_W"; then if (cygpath --version) >/dev/null 2>/dev/null; then CYGPATH_W='cygpath -w' else CYGPATH_W=echo fi fi # Define the identity of the package. PACKAGE='eztrace' VERSION='1.1-2' cat >>confdefs.h <<_ACEOF #define PACKAGE "$PACKAGE" _ACEOF cat >>confdefs.h <<_ACEOF #define VERSION "$VERSION" _ACEOF # Some tools Automake needs. ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"} AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"} AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"} AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"} MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"} # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: # # mkdir_p='$(MKDIR_P)' # We need awk for the "check" target (and possibly the TAP driver). The # system "awk" is bad on some platforms. # Always define AMTAR for backward compatibility. Yes, it's still used # in the wild :-( We should find a proper way to deprecate it ... AMTAR='$${TAR-tar}' # We'll loop over all known methods to create a tar archive until one works. _am_tools='gnutar pax cpio none' { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to create a pax tar archive" >&5 $as_echo_n "checking how to create a pax tar archive... " >&6; } # Go ahead even if we have the value already cached. We do so because we # need to set the values for the 'am__tar' and 'am__untar' variables. _am_tools=${am_cv_prog_tar_pax-$_am_tools} for _am_tool in $_am_tools; do case $_am_tool in gnutar) for _am_tar in tar gnutar gtar; do { echo "$as_me:$LINENO: $_am_tar --version" >&5 ($_am_tar --version) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } && break done am__tar="$_am_tar --format=posix -chf - "'"$$tardir"' am__tar_="$_am_tar --format=posix -chf - "'"$tardir"' am__untar="$_am_tar -xf -" ;; plaintar) # Must skip GNU tar: if it does not support --format= it doesn't create # ustar tarball either. (tar --version) >/dev/null 2>&1 && continue am__tar='tar chf - "$$tardir"' am__tar_='tar chf - "$tardir"' am__untar='tar xf -' ;; pax) am__tar='pax -L -x pax -w "$$tardir"' am__tar_='pax -L -x pax -w "$tardir"' am__untar='pax -r' ;; cpio) am__tar='find "$$tardir" -print | cpio -o -H pax -L' am__tar_='find "$tardir" -print | cpio -o -H pax -L' am__untar='cpio -i -H pax -d' ;; none) am__tar=false am__tar_=false am__untar=false ;; esac # If the value was cached, stop now. We just wanted to have am__tar # and am__untar set. test -n "${am_cv_prog_tar_pax}" && break # tar/untar a dummy directory, and stop if the command works. rm -rf conftest.dir mkdir conftest.dir echo GrepMe > conftest.dir/file { echo "$as_me:$LINENO: tardir=conftest.dir && eval $am__tar_ >conftest.tar" >&5 (tardir=conftest.dir && eval $am__tar_ >conftest.tar) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } rm -rf conftest.dir if test -s conftest.tar; then { echo "$as_me:$LINENO: $am__untar &5 ($am__untar &5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } { echo "$as_me:$LINENO: cat conftest.dir/file" >&5 (cat conftest.dir/file) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } grep GrepMe conftest.dir/file >/dev/null 2>&1 && break fi done rm -rf conftest.dir if ${am_cv_prog_tar_pax+:} false; then : $as_echo_n "(cached) " >&6 else am_cv_prog_tar_pax=$_am_tool fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_prog_tar_pax" >&5 $as_echo "$am_cv_prog_tar_pax" >&6; } # POSIX will say in a future version that running "rm -f" with no argument # is OK; and we want to be able to make that assumption in our Makefile # recipes. So use an aggressive probe to check that the usage we want is # actually supported "in the wild" to an acceptable degree. # See automake bug#10828. # To make any issue more visible, cause the running configure to be aborted # by default if the 'rm' program in use doesn't match our expectations; the # user can still override this though. if rm -f && rm -fr && rm -rf; then : OK; else cat >&2 <<'END' Oops! Your 'rm' program seems unable to run without file operands specified on the command line, even when the '-f' option is present. This is contrary to the behaviour of most rm programs out there, and not conforming with the upcoming POSIX standard: Please tell bug-automake@gnu.org about your system, including the value of your $PATH and any error possibly output before this message. This can help us improve future automake versions. END if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then echo 'Configuration will proceed anyway, since you have set the' >&2 echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 echo >&2 else cat >&2 <<'END' Aborting the configuration process, to ensure you take notice of the issue. You can download and install GNU coreutils to get an 'rm' implementation that behaves properly: . If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM to "yes", and re-run configure. END as_fn_error $? "Your 'rm' program is bad, sorry." "$LINENO" 5 fi fi # Checks for programs. ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. set dummy ${ac_tool_prefix}gcc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}gcc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_CC"; then ac_ct_CC=$CC # Extract the first word of "gcc", so it can be a program name with args. set dummy gcc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="gcc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 $as_echo "$ac_ct_CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi else CC="$ac_cv_prog_CC" fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. set dummy ${ac_tool_prefix}cc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}cc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi fi if test -z "$CC"; then # Extract the first word of "cc", so it can be a program name with args. set dummy cc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else ac_prog_rejected=no as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then ac_prog_rejected=yes continue fi ac_cv_prog_CC="cc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS if test $ac_prog_rejected = yes; then # We found a bogon in the path, so make sure we never use it. set dummy $ac_cv_prog_CC shift if test $# != 0; then # We chose a different compiler from the bogus one. # However, it has the same basename, so the bogon will be chosen # first if we set CC to just the basename; use the full file name. shift ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" fi fi fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then for ac_prog in cl.exe do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CC="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$CC" && break done fi if test -z "$CC"; then ac_ct_CC=$CC for ac_prog in cl.exe do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 $as_echo "$ac_ct_CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_CC" && break done if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi fi fi test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "no acceptable C compiler found in \$PATH See \`config.log' for more details" "$LINENO" 5; } # Provide some information about the compiler. $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 set X $ac_compile ac_compiler=$2 for ac_option in --version -v -V -qversion; do { { ac_try="$ac_compiler $ac_option >&5" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compiler $ac_option >&5") 2>conftest.err ac_status=$? if test -s conftest.err; then sed '10a\ ... rest of stderr output deleted ... 10q' conftest.err >conftest.er1 cat conftest.er1 >&5 fi rm -f conftest.er1 conftest.err $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } done cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" # Try to create an executable without -o first, disregard a.out. # It will help us diagnose broken compilers, and finding out an intuition # of exeext. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 $as_echo_n "checking whether the C compiler works... " >&6; } ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` # The possible output files: ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" ac_rmfiles= for ac_file in $ac_files do case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; * ) ac_rmfiles="$ac_rmfiles $ac_file";; esac done rm -f $ac_rmfiles if { { ac_try="$ac_link_default" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link_default") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then : # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. # So ignore a value of `no', otherwise this would lead to `EXEEXT = no' # in a Makefile. We should not override ac_cv_exeext if it was cached, # so that the user can short-circuit this test for compilers unknown to # Autoconf. for ac_file in $ac_files '' do test -f "$ac_file" || continue case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; [ab].out ) # We found the default executable, but exeext='' is most # certainly right. break;; *.* ) if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; then :; else ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` fi # We set ac_cv_exeext here because the later test for it is not # safe: cross compilers may not add the suffix if given an `-o' # argument, so we may need to know it at that point already. # Even if this section looks crufty: it has the advantage of # actually working. break;; * ) break;; esac done test "$ac_cv_exeext" = no && ac_cv_exeext= else ac_file='' fi if test -z "$ac_file"; then : { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "C compiler cannot create executables See \`config.log' for more details" "$LINENO" 5; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 $as_echo_n "checking for C compiler default output file name... " >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 $as_echo "$ac_file" >&6; } ac_exeext=$ac_cv_exeext rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out ac_clean_files=$ac_clean_files_save { $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 $as_echo_n "checking for suffix of executables... " >&6; } if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then : # If both `conftest.exe' and `conftest' are `present' (well, observable) # catch `conftest.exe'. For instance with Cygwin, `ls conftest' will # work properly (i.e., refer to `conftest.exe'), while it won't with # `rm'. for ac_file in conftest.exe conftest conftest.*; do test -f "$ac_file" || continue case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` break;; * ) break;; esac done else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot compute suffix of executables: cannot compile and link See \`config.log' for more details" "$LINENO" 5; } fi rm -f conftest conftest$ac_cv_exeext { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 $as_echo "$ac_cv_exeext" >&6; } rm -f conftest.$ac_ext EXEEXT=$ac_cv_exeext ac_exeext=$EXEEXT cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main () { FILE *f = fopen ("conftest.out", "w"); return ferror (f) || fclose (f) != 0; ; return 0; } _ACEOF ac_clean_files="$ac_clean_files conftest.out" # Check that the compiler produces executables we can run. If not, either # the compiler is broken, or we cross compile. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 $as_echo_n "checking whether we are cross compiling... " >&6; } if test "$cross_compiling" != yes; then { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if { ac_try='./conftest$ac_cv_exeext' { { case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_try") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; }; then cross_compiling=no else if test "$cross_compiling" = maybe; then cross_compiling=yes else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot run C compiled programs. If you meant to cross compile, use \`--host'. See \`config.log' for more details" "$LINENO" 5; } fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 $as_echo "$cross_compiling" >&6; } rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out ac_clean_files=$ac_clean_files_save { $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 $as_echo_n "checking for suffix of object files... " >&6; } if ${ac_cv_objext+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF rm -f conftest.o conftest.obj if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then : for ac_file in conftest.o conftest.obj conftest.*; do test -f "$ac_file" || continue; case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` break;; esac done else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot compute suffix of object files: cannot compile See \`config.log' for more details" "$LINENO" 5; } fi rm -f conftest.$ac_cv_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 $as_echo "$ac_cv_objext" >&6; } OBJEXT=$ac_cv_objext ac_objext=$OBJEXT { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 $as_echo_n "checking whether we are using the GNU C compiler... " >&6; } if ${ac_cv_c_compiler_gnu+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { #ifndef __GNUC__ choke me #endif ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_compiler_gnu=yes else ac_compiler_gnu=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext ac_cv_c_compiler_gnu=$ac_compiler_gnu fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 $as_echo "$ac_cv_c_compiler_gnu" >&6; } if test $ac_compiler_gnu = yes; then GCC=yes else GCC= fi ac_test_CFLAGS=${CFLAGS+set} ac_save_CFLAGS=$CFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 $as_echo_n "checking whether $CC accepts -g... " >&6; } if ${ac_cv_prog_cc_g+:} false; then : $as_echo_n "(cached) " >&6 else ac_save_c_werror_flag=$ac_c_werror_flag ac_c_werror_flag=yes ac_cv_prog_cc_g=no CFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_prog_cc_g=yes else CFLAGS="" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : else ac_c_werror_flag=$ac_save_c_werror_flag CFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_prog_cc_g=yes fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext ac_c_werror_flag=$ac_save_c_werror_flag fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 $as_echo "$ac_cv_prog_cc_g" >&6; } if test "$ac_test_CFLAGS" = set; then CFLAGS=$ac_save_CFLAGS elif test $ac_cv_prog_cc_g = yes; then if test "$GCC" = yes; then CFLAGS="-g -O2" else CFLAGS="-g" fi else if test "$GCC" = yes; then CFLAGS="-O2" else CFLAGS= fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 $as_echo_n "checking for $CC option to accept ISO C89... " >&6; } if ${ac_cv_prog_cc_c89+:} false; then : $as_echo_n "(cached) " >&6 else ac_cv_prog_cc_c89=no ac_save_CC=$CC cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include struct stat; /* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ struct buf { int x; }; FILE * (*rcsopen) (struct buf *, struct stat *, int); static char *e (p, i) char **p; int i; { return p[i]; } static char *f (char * (*g) (char **, int), char **p, ...) { char *s; va_list v; va_start (v,p); s = g (p, va_arg (v,int)); va_end (v); return s; } /* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has function prototypes and stuff, but not '\xHH' hex character constants. These don't provoke an error unfortunately, instead are silently treated as 'x'. The following induces an error, until -std is added to get proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an array size at least. It's necessary to write '\x00'==0 to get something that's true only with -std. */ int osf4_cc_array ['\x00' == 0 ? 1 : -1]; /* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters inside strings and character constants. */ #define FOO(x) 'x' int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1]; int test (int i, double x); struct s1 {int (*f) (int a);}; struct s2 {int (*f) (double a);}; int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); int argc; char **argv; int main () { return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; ; return 0; } _ACEOF for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" do CC="$ac_save_CC $ac_arg" if ac_fn_c_try_compile "$LINENO"; then : ac_cv_prog_cc_c89=$ac_arg fi rm -f core conftest.err conftest.$ac_objext test "x$ac_cv_prog_cc_c89" != "xno" && break done rm -f conftest.$ac_ext CC=$ac_save_CC fi # AC_CACHE_VAL case "x$ac_cv_prog_cc_c89" in x) { $as_echo "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 $as_echo "none needed" >&6; } ;; xno) { $as_echo "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 $as_echo "unsupported" >&6; } ;; *) CC="$CC $ac_cv_prog_cc_c89" { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 $as_echo "$ac_cv_prog_cc_c89" >&6; } ;; esac if test "x$ac_cv_prog_cc_c89" != xno; then : fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC understands -c and -o together" >&5 $as_echo_n "checking whether $CC understands -c and -o together... " >&6; } if ${am_cv_prog_cc_c_o+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF # Make sure it works both with $CC and with simple cc. # Following AC_PROG_CC_C_O, we do the test twice because some # compilers refuse to overwrite an existing .o file with -o, # though they will create one. am_cv_prog_cc_c_o=yes for am_i in 1 2; do if { echo "$as_me:$LINENO: $CC -c conftest.$ac_ext -o conftest2.$ac_objext" >&5 ($CC -c conftest.$ac_ext -o conftest2.$ac_objext) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } \ && test -f conftest2.$ac_objext; then : OK else am_cv_prog_cc_c_o=no break fi done rm -f core conftest* unset am_i fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_prog_cc_c_o" >&5 $as_echo "$am_cv_prog_cc_c_o" >&6; } if test "$am_cv_prog_cc_c_o" != yes; then # Losing compiler, so override with the script. # FIXME: It is wrong to rewrite CC. # But if we don't then we get into trouble of one sort or another. # A longer-term fix would be to have automake use am__CC in this case, # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" CC="$am_aux_dir/compile $CC" fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu DEPDIR="${am__leading_dot}deps" ac_config_commands="$ac_config_commands depfiles" am_make=${MAKE-make} cat > confinc << 'END' am__doit: @echo this is the am__doit target .PHONY: am__doit END # If we don't find an include directive, just comment out the code. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5 $as_echo_n "checking for style of include used by $am_make... " >&6; } am__include="#" am__quote= _am_result=none # First try GNU make style include. echo "include confinc" > confmf # Ignore all kinds of additional output from 'make'. case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=include am__quote= _am_result=GNU ;; esac # Now try BSD make style include. if test "$am__include" = "#"; then echo '.include "confinc"' > confmf case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=.include am__quote="\"" _am_result=BSD ;; esac fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5 $as_echo "$_am_result" >&6; } rm -f confinc confmf # Check whether --enable-dependency-tracking was given. if test "${enable_dependency_tracking+set}" = set; then : enableval=$enable_dependency_tracking; fi if test "x$enable_dependency_tracking" != xno; then am_depcomp="$ac_aux_dir/depcomp" AMDEPBACKSLASH='\' am__nodep='_no' fi if test "x$enable_dependency_tracking" != xno; then AMDEP_TRUE= AMDEP_FALSE='#' else AMDEP_TRUE='#' AMDEP_FALSE= fi depcc="$CC" am_compiler_list= { $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 $as_echo_n "checking dependency style of $depcc... " >&6; } if ${am_cv_CC_dependencies_compiler_type+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_CC_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` fi am__universal=false case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_CC_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_CC_dependencies_compiler_type=none fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_CC_dependencies_compiler_type" >&5 $as_echo "$am_cv_CC_dependencies_compiler_type" >&6; } CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type if test "x$enable_dependency_tracking" != xno \ && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then am__fastdepCC_TRUE= am__fastdepCC_FALSE='#' else am__fastdepCC_TRUE='#' am__fastdepCC_FALSE= fi ac_ext=${ac_fc_srcext-f} ac_compile='$FC -c $FCFLAGS $ac_fcflags_srcext conftest.$ac_ext >&5' ac_link='$FC -o conftest$ac_exeext $FCFLAGS $LDFLAGS $ac_fcflags_srcext conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_fc_compiler_gnu if test -n "$ac_tool_prefix"; then for ac_prog in gfortran g95 xlf95 f95 fort ifort ifc efc pgfortran pgf95 lf95 ftn nagfor xlf90 f90 pgf90 pghpf epcf90 g77 xlf f77 frt pgf77 cf77 fort77 fl32 af77 do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_FC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$FC"; then ac_cv_prog_FC="$FC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_FC="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi FC=$ac_cv_prog_FC if test -n "$FC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $FC" >&5 $as_echo "$FC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$FC" && break done fi if test -z "$FC"; then ac_ct_FC=$FC for ac_prog in gfortran g95 xlf95 f95 fort ifort ifc efc pgfortran pgf95 lf95 ftn nagfor xlf90 f90 pgf90 pghpf epcf90 g77 xlf f77 frt pgf77 cf77 fort77 fl32 af77 do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_FC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_FC"; then ac_cv_prog_ac_ct_FC="$ac_ct_FC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_FC="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_FC=$ac_cv_prog_ac_ct_FC if test -n "$ac_ct_FC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_FC" >&5 $as_echo "$ac_ct_FC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_FC" && break done if test "x$ac_ct_FC" = x; then FC="" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac FC=$ac_ct_FC fi fi # Provide some information about the compiler. $as_echo "$as_me:${as_lineno-$LINENO}: checking for Fortran compiler version" >&5 set X $ac_compile ac_compiler=$2 for ac_option in --version -v -V -qversion; do { { ac_try="$ac_compiler $ac_option >&5" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compiler $ac_option >&5") 2>conftest.err ac_status=$? if test -s conftest.err; then sed '10a\ ... rest of stderr output deleted ... 10q' conftest.err >conftest.er1 cat conftest.er1 >&5 fi rm -f conftest.er1 conftest.err $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } done rm -f a.out # If we don't use `.F' as extension, the preprocessor is not run on the # input file. (Note that this only needs to work for GNU compilers.) ac_save_ext=$ac_ext ac_ext=F { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU Fortran compiler" >&5 $as_echo_n "checking whether we are using the GNU Fortran compiler... " >&6; } if ${ac_cv_fc_compiler_gnu+:} false; then : $as_echo_n "(cached) " >&6 else cat > conftest.$ac_ext <<_ACEOF program main #ifndef __GNUC__ choke me #endif end _ACEOF if ac_fn_fc_try_compile "$LINENO"; then : ac_compiler_gnu=yes else ac_compiler_gnu=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext ac_cv_fc_compiler_gnu=$ac_compiler_gnu fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_fc_compiler_gnu" >&5 $as_echo "$ac_cv_fc_compiler_gnu" >&6; } ac_ext=$ac_save_ext ac_test_FCFLAGS=${FCFLAGS+set} ac_save_FCFLAGS=$FCFLAGS FCFLAGS= { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $FC accepts -g" >&5 $as_echo_n "checking whether $FC accepts -g... " >&6; } if ${ac_cv_prog_fc_g+:} false; then : $as_echo_n "(cached) " >&6 else FCFLAGS=-g cat > conftest.$ac_ext <<_ACEOF program main end _ACEOF if ac_fn_fc_try_compile "$LINENO"; then : ac_cv_prog_fc_g=yes else ac_cv_prog_fc_g=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_fc_g" >&5 $as_echo "$ac_cv_prog_fc_g" >&6; } if test "$ac_test_FCFLAGS" = set; then FCFLAGS=$ac_save_FCFLAGS elif test $ac_cv_prog_fc_g = yes; then if test "x$ac_cv_fc_compiler_gnu" = xyes; then FCFLAGS="-g -O2" else FCFLAGS="-g" fi else if test "x$ac_cv_fc_compiler_gnu" = xyes; then FCFLAGS="-O2" else FCFLAGS= fi fi if test $ac_compiler_gnu = yes; then GFC=yes else GFC= fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu ac_ext=cpp ac_cpp='$CXXCPP $CPPFLAGS' ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_cxx_compiler_gnu if test -z "$CXX"; then if test -n "$CCC"; then CXX=$CCC else if test -n "$ac_tool_prefix"; then for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CXX+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CXX"; then ac_cv_prog_CXX="$CXX" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CXX="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CXX=$ac_cv_prog_CXX if test -n "$CXX"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CXX" >&5 $as_echo "$CXX" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$CXX" && break done fi if test -z "$CXX"; then ac_ct_CXX=$CXX for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_CXX+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CXX"; then ac_cv_prog_ac_ct_CXX="$ac_ct_CXX" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CXX="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CXX=$ac_cv_prog_ac_ct_CXX if test -n "$ac_ct_CXX"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CXX" >&5 $as_echo "$ac_ct_CXX" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_CXX" && break done if test "x$ac_ct_CXX" = x; then CXX="g++" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CXX=$ac_ct_CXX fi fi fi fi # Provide some information about the compiler. $as_echo "$as_me:${as_lineno-$LINENO}: checking for C++ compiler version" >&5 set X $ac_compile ac_compiler=$2 for ac_option in --version -v -V -qversion; do { { ac_try="$ac_compiler $ac_option >&5" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compiler $ac_option >&5") 2>conftest.err ac_status=$? if test -s conftest.err; then sed '10a\ ... rest of stderr output deleted ... 10q' conftest.err >conftest.er1 cat conftest.er1 >&5 fi rm -f conftest.er1 conftest.err $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } done { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C++ compiler" >&5 $as_echo_n "checking whether we are using the GNU C++ compiler... " >&6; } if ${ac_cv_cxx_compiler_gnu+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { #ifndef __GNUC__ choke me #endif ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO"; then : ac_compiler_gnu=yes else ac_compiler_gnu=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext ac_cv_cxx_compiler_gnu=$ac_compiler_gnu fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_cxx_compiler_gnu" >&5 $as_echo "$ac_cv_cxx_compiler_gnu" >&6; } if test $ac_compiler_gnu = yes; then GXX=yes else GXX= fi ac_test_CXXFLAGS=${CXXFLAGS+set} ac_save_CXXFLAGS=$CXXFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CXX accepts -g" >&5 $as_echo_n "checking whether $CXX accepts -g... " >&6; } if ${ac_cv_prog_cxx_g+:} false; then : $as_echo_n "(cached) " >&6 else ac_save_cxx_werror_flag=$ac_cxx_werror_flag ac_cxx_werror_flag=yes ac_cv_prog_cxx_g=no CXXFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO"; then : ac_cv_prog_cxx_g=yes else CXXFLAGS="" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO"; then : else ac_cxx_werror_flag=$ac_save_cxx_werror_flag CXXFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO"; then : ac_cv_prog_cxx_g=yes fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext ac_cxx_werror_flag=$ac_save_cxx_werror_flag fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cxx_g" >&5 $as_echo "$ac_cv_prog_cxx_g" >&6; } if test "$ac_test_CXXFLAGS" = set; then CXXFLAGS=$ac_save_CXXFLAGS elif test $ac_cv_prog_cxx_g = yes; then if test "$GXX" = yes; then CXXFLAGS="-g -O2" else CXXFLAGS="-g" fi else if test "$GXX" = yes; then CXXFLAGS="-O2" else CXXFLAGS= fi fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu depcc="$CXX" am_compiler_list= { $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 $as_echo_n "checking dependency style of $depcc... " >&6; } if ${am_cv_CXX_dependencies_compiler_type+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_CXX_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` fi am__universal=false case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_CXX_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_CXX_dependencies_compiler_type=none fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_CXX_dependencies_compiler_type" >&5 $as_echo "$am_cv_CXX_dependencies_compiler_type" >&6; } CXXDEPMODE=depmode=$am_cv_CXX_dependencies_compiler_type if test "x$enable_dependency_tracking" != xno \ && test "$am_cv_CXX_dependencies_compiler_type" = gcc3; then am__fastdepCXX_TRUE= am__fastdepCXX_FALSE='#' else am__fastdepCXX_TRUE='#' am__fastdepCXX_FALSE= fi ac_ext=cpp ac_cpp='$CXXCPP $CPPFLAGS' ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_cxx_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} sets \$(MAKE)" >&5 $as_echo_n "checking whether ${MAKE-make} sets \$(MAKE)... " >&6; } set x ${MAKE-make} ac_make=`$as_echo "$2" | sed 's/+/p/g; s/[^a-zA-Z0-9_]/_/g'` if eval \${ac_cv_prog_make_${ac_make}_set+:} false; then : $as_echo_n "(cached) " >&6 else cat >conftest.make <<\_ACEOF SHELL = /bin/sh all: @echo '@@@%%%=$(MAKE)=@@@%%%' _ACEOF # GNU make sometimes prints "make[1]: Entering ...", which would confuse us. case `${MAKE-make} -f conftest.make 2>/dev/null` in *@@@%%%=?*=@@@%%%*) eval ac_cv_prog_make_${ac_make}_set=yes;; *) eval ac_cv_prog_make_${ac_make}_set=no;; esac rm -f conftest.make fi if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } SET_MAKE= else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } SET_MAKE="MAKE=${MAKE-make}" fi case `pwd` in *\ * | *\ *) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&5 $as_echo "$as_me: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&2;} ;; esac macro_version='2.4.2' macro_revision='1.3337' ltmain="$ac_aux_dir/ltmain.sh" # Make sure we can run config.sub. $SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 || as_fn_error $? "cannot run $SHELL $ac_aux_dir/config.sub" "$LINENO" 5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking build system type" >&5 $as_echo_n "checking build system type... " >&6; } if ${ac_cv_build+:} false; then : $as_echo_n "(cached) " >&6 else ac_build_alias=$build_alias test "x$ac_build_alias" = x && ac_build_alias=`$SHELL "$ac_aux_dir/config.guess"` test "x$ac_build_alias" = x && as_fn_error $? "cannot guess build type; you must specify one" "$LINENO" 5 ac_cv_build=`$SHELL "$ac_aux_dir/config.sub" $ac_build_alias` || as_fn_error $? "$SHELL $ac_aux_dir/config.sub $ac_build_alias failed" "$LINENO" 5 fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_build" >&5 $as_echo "$ac_cv_build" >&6; } case $ac_cv_build in *-*-*) ;; *) as_fn_error $? "invalid value of canonical build" "$LINENO" 5;; esac build=$ac_cv_build ac_save_IFS=$IFS; IFS='-' set x $ac_cv_build shift build_cpu=$1 build_vendor=$2 shift; shift # Remember, the first character of IFS is used to create $*, # except with old shells: build_os=$* IFS=$ac_save_IFS case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking host system type" >&5 $as_echo_n "checking host system type... " >&6; } if ${ac_cv_host+:} false; then : $as_echo_n "(cached) " >&6 else if test "x$host_alias" = x; then ac_cv_host=$ac_cv_build else ac_cv_host=`$SHELL "$ac_aux_dir/config.sub" $host_alias` || as_fn_error $? "$SHELL $ac_aux_dir/config.sub $host_alias failed" "$LINENO" 5 fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_host" >&5 $as_echo "$ac_cv_host" >&6; } case $ac_cv_host in *-*-*) ;; *) as_fn_error $? "invalid value of canonical host" "$LINENO" 5;; esac host=$ac_cv_host ac_save_IFS=$IFS; IFS='-' set x $ac_cv_host shift host_cpu=$1 host_vendor=$2 shift; shift # Remember, the first character of IFS is used to create $*, # except with old shells: host_os=$* IFS=$ac_save_IFS case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac # Backslashify metacharacters that are still active within # double-quoted strings. sed_quote_subst='s/\(["`$\\]\)/\\\1/g' # Same as above, but do not quote variable references. double_quote_subst='s/\(["`\\]\)/\\\1/g' # Sed substitution to delay expansion of an escaped shell variable in a # double_quote_subst'ed string. delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' # Sed substitution to delay expansion of an escaped single quote. delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' # Sed substitution to avoid accidental globbing in evaled expressions no_glob_subst='s/\*/\\\*/g' ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to print strings" >&5 $as_echo_n "checking how to print strings... " >&6; } # Test print first, because it will be a builtin if present. if test "X`( print -r -- -n ) 2>/dev/null`" = X-n && \ test "X`print -r -- $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='print -r --' elif test "X`printf %s $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='printf %s\n' else # Use this function as a fallback that always works. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $1 _LTECHO_EOF' } ECHO='func_fallback_echo' fi # func_echo_all arg... # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "" } case "$ECHO" in printf*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: printf" >&5 $as_echo "printf" >&6; } ;; print*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: print -r" >&5 $as_echo "print -r" >&6; } ;; *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: cat" >&5 $as_echo "cat" >&6; } ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a sed that does not truncate output" >&5 $as_echo_n "checking for a sed that does not truncate output... " >&6; } if ${ac_cv_path_SED+:} false; then : $as_echo_n "(cached) " >&6 else ac_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ for ac_i in 1 2 3 4 5 6 7; do ac_script="$ac_script$as_nl$ac_script" done echo "$ac_script" 2>/dev/null | sed 99q >conftest.sed { ac_script=; unset ac_script;} if test -z "$SED"; then ac_path_SED_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in sed gsed; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_SED="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_SED" || continue # Check for GNU ac_path_SED and select it if it is found. # Check for GNU $ac_path_SED case `"$ac_path_SED" --version 2>&1` in *GNU*) ac_cv_path_SED="$ac_path_SED" ac_path_SED_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo '' >> "conftest.nl" "$ac_path_SED" -f conftest.sed < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_SED_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_SED="$ac_path_SED" ac_path_SED_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_SED_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_SED"; then as_fn_error $? "no acceptable sed could be found in \$PATH" "$LINENO" 5 fi else ac_cv_path_SED=$SED fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_SED" >&5 $as_echo "$ac_cv_path_SED" >&6; } SED="$ac_cv_path_SED" rm -f conftest.sed test -z "$SED" && SED=sed Xsed="$SED -e 1s/^X//" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for grep that handles long lines and -e" >&5 $as_echo_n "checking for grep that handles long lines and -e... " >&6; } if ${ac_cv_path_GREP+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$GREP"; then ac_path_GREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in grep ggrep; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_GREP="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_GREP" || continue # Check for GNU ac_path_GREP and select it if it is found. # Check for GNU $ac_path_GREP case `"$ac_path_GREP" --version 2>&1` in *GNU*) ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo 'GREP' >> "conftest.nl" "$ac_path_GREP" -e 'GREP$' -e '-(cannot match)-' < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_GREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_GREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_GREP"; then as_fn_error $? "no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_GREP=$GREP fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_GREP" >&5 $as_echo "$ac_cv_path_GREP" >&6; } GREP="$ac_cv_path_GREP" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for egrep" >&5 $as_echo_n "checking for egrep... " >&6; } if ${ac_cv_path_EGREP+:} false; then : $as_echo_n "(cached) " >&6 else if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 then ac_cv_path_EGREP="$GREP -E" else if test -z "$EGREP"; then ac_path_EGREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in egrep; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_EGREP="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_EGREP" || continue # Check for GNU ac_path_EGREP and select it if it is found. # Check for GNU $ac_path_EGREP case `"$ac_path_EGREP" --version 2>&1` in *GNU*) ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo 'EGREP' >> "conftest.nl" "$ac_path_EGREP" 'EGREP$' < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_EGREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_EGREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_EGREP"; then as_fn_error $? "no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_EGREP=$EGREP fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_EGREP" >&5 $as_echo "$ac_cv_path_EGREP" >&6; } EGREP="$ac_cv_path_EGREP" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for fgrep" >&5 $as_echo_n "checking for fgrep... " >&6; } if ${ac_cv_path_FGREP+:} false; then : $as_echo_n "(cached) " >&6 else if echo 'ab*c' | $GREP -F 'ab*c' >/dev/null 2>&1 then ac_cv_path_FGREP="$GREP -F" else if test -z "$FGREP"; then ac_path_FGREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in fgrep; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_FGREP="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_FGREP" || continue # Check for GNU ac_path_FGREP and select it if it is found. # Check for GNU $ac_path_FGREP case `"$ac_path_FGREP" --version 2>&1` in *GNU*) ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo 'FGREP' >> "conftest.nl" "$ac_path_FGREP" FGREP < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_FGREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_FGREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_FGREP"; then as_fn_error $? "no acceptable fgrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_FGREP=$FGREP fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_FGREP" >&5 $as_echo "$ac_cv_path_FGREP" >&6; } FGREP="$ac_cv_path_FGREP" test -z "$GREP" && GREP=grep # Check whether --with-gnu-ld was given. if test "${with_gnu_ld+set}" = set; then : withval=$with_gnu_ld; test "$withval" = no || with_gnu_ld=yes else with_gnu_ld=no fi ac_prog=ld if test "$GCC" = yes; then # Check if gcc -print-prog-name=ld gives a path. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5 $as_echo_n "checking for ld used by $CC... " >&6; } case $host in *-*-mingw*) # gcc leaves a trailing carriage return which upsets mingw ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; esac case $ac_prog in # Accept absolute paths. [\\/]* | ?:[\\/]*) re_direlt='/[^/][^/]*/\.\./' # Canonicalize the pathname of ld ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` done test -z "$LD" && LD="$ac_prog" ;; "") # If it fails, then pretend we aren't using GCC. ac_prog=ld ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac elif test "$with_gnu_ld" = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5 $as_echo_n "checking for GNU ld... " >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for non-GNU ld" >&5 $as_echo_n "checking for non-GNU ld... " >&6; } fi if ${lt_cv_path_LD+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$LD"; then lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS="$lt_save_ifs" test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then lt_cv_path_LD="$ac_dir/$ac_prog" # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$lt_cv_path_LD" -v 2>&1 &5 $as_echo "$LD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -z "$LD" && as_fn_error $? "no acceptable ld found in \$PATH" "$LINENO" 5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking if the linker ($LD) is GNU ld" >&5 $as_echo_n "checking if the linker ($LD) is GNU ld... " >&6; } if ${lt_cv_prog_gnu_ld+:} false; then : $as_echo_n "(cached) " >&6 else # I'd rather use --version here, but apparently some GNU lds only accept -v. case `$LD -v 2>&1 &5 $as_echo "$lt_cv_prog_gnu_ld" >&6; } with_gnu_ld=$lt_cv_prog_gnu_ld { $as_echo "$as_me:${as_lineno-$LINENO}: checking for BSD- or MS-compatible name lister (nm)" >&5 $as_echo_n "checking for BSD- or MS-compatible name lister (nm)... " >&6; } if ${lt_cv_path_NM+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$NM"; then # Let the user override the test. lt_cv_path_NM="$NM" else lt_nm_to_check="${ac_tool_prefix}nm" if test -n "$ac_tool_prefix" && test "$build" = "$host"; then lt_nm_to_check="$lt_nm_to_check nm" fi for lt_tmp_nm in $lt_nm_to_check; do lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do IFS="$lt_save_ifs" test -z "$ac_dir" && ac_dir=. tmp_nm="$ac_dir/$lt_tmp_nm" if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then # Check to see if the nm accepts a BSD-compat flag. # Adding the `sed 1q' prevents false positives on HP-UX, which says: # nm: unknown option "B" ignored # Tru64's nm complains that /dev/null is an invalid object file case `"$tmp_nm" -B /dev/null 2>&1 | sed '1q'` in */dev/null* | *'Invalid file or object type'*) lt_cv_path_NM="$tmp_nm -B" break ;; *) case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in */dev/null*) lt_cv_path_NM="$tmp_nm -p" break ;; *) lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but continue # so that we can try to find one that supports BSD flags ;; esac ;; esac fi done IFS="$lt_save_ifs" done : ${lt_cv_path_NM=no} fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_NM" >&5 $as_echo "$lt_cv_path_NM" >&6; } if test "$lt_cv_path_NM" != "no"; then NM="$lt_cv_path_NM" else # Didn't find any BSD compatible name lister, look for dumpbin. if test -n "$DUMPBIN"; then : # Let the user override the test. else if test -n "$ac_tool_prefix"; then for ac_prog in dumpbin "link -dump" do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_DUMPBIN+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DUMPBIN"; then ac_cv_prog_DUMPBIN="$DUMPBIN" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_DUMPBIN="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DUMPBIN=$ac_cv_prog_DUMPBIN if test -n "$DUMPBIN"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DUMPBIN" >&5 $as_echo "$DUMPBIN" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$DUMPBIN" && break done fi if test -z "$DUMPBIN"; then ac_ct_DUMPBIN=$DUMPBIN for ac_prog in dumpbin "link -dump" do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_DUMPBIN+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_DUMPBIN"; then ac_cv_prog_ac_ct_DUMPBIN="$ac_ct_DUMPBIN" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DUMPBIN="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DUMPBIN=$ac_cv_prog_ac_ct_DUMPBIN if test -n "$ac_ct_DUMPBIN"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DUMPBIN" >&5 $as_echo "$ac_ct_DUMPBIN" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_DUMPBIN" && break done if test "x$ac_ct_DUMPBIN" = x; then DUMPBIN=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DUMPBIN=$ac_ct_DUMPBIN fi fi case `$DUMPBIN -symbols /dev/null 2>&1 | sed '1q'` in *COFF*) DUMPBIN="$DUMPBIN -symbols" ;; *) DUMPBIN=: ;; esac fi if test "$DUMPBIN" != ":"; then NM="$DUMPBIN" fi fi test -z "$NM" && NM=nm { $as_echo "$as_me:${as_lineno-$LINENO}: checking the name lister ($NM) interface" >&5 $as_echo_n "checking the name lister ($NM) interface... " >&6; } if ${lt_cv_nm_interface+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_nm_interface="BSD nm" echo "int some_variable = 0;" > conftest.$ac_ext (eval echo "\"\$as_me:$LINENO: $ac_compile\"" >&5) (eval "$ac_compile" 2>conftest.err) cat conftest.err >&5 (eval echo "\"\$as_me:$LINENO: $NM \\\"conftest.$ac_objext\\\"\"" >&5) (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) cat conftest.err >&5 (eval echo "\"\$as_me:$LINENO: output\"" >&5) cat conftest.out >&5 if $GREP 'External.*some_variable' conftest.out > /dev/null; then lt_cv_nm_interface="MS dumpbin" fi rm -f conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_nm_interface" >&5 $as_echo "$lt_cv_nm_interface" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ln -s works" >&5 $as_echo_n "checking whether ln -s works... " >&6; } LN_S=$as_ln_s if test "$LN_S" = "ln -s"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no, using $LN_S" >&5 $as_echo "no, using $LN_S" >&6; } fi # find the maximum length of command line arguments { $as_echo "$as_me:${as_lineno-$LINENO}: checking the maximum length of command line arguments" >&5 $as_echo_n "checking the maximum length of command line arguments... " >&6; } if ${lt_cv_sys_max_cmd_len+:} false; then : $as_echo_n "(cached) " >&6 else i=0 teststring="ABCD" case $build_os in msdosdjgpp*) # On DJGPP, this test can blow up pretty badly due to problems in libc # (any single argument exceeding 2000 bytes causes a buffer overrun # during glob expansion). Even if it were fixed, the result of this # check would be larger than it should be. lt_cv_sys_max_cmd_len=12288; # 12K is about right ;; gnu*) # Under GNU Hurd, this test is not required because there is # no limit to the length of command line arguments. # Libtool will interpret -1 as no limit whatsoever lt_cv_sys_max_cmd_len=-1; ;; cygwin* | mingw* | cegcc*) # On Win9x/ME, this test blows up -- it succeeds, but takes # about 5 minutes as the teststring grows exponentially. # Worse, since 9x/ME are not pre-emptively multitasking, # you end up with a "frozen" computer, even though with patience # the test eventually succeeds (with a max line length of 256k). # Instead, let's just punt: use the minimum linelength reported by # all of the supported platforms: 8192 (on NT/2K/XP). lt_cv_sys_max_cmd_len=8192; ;; mint*) # On MiNT this can take a long time and run out of memory. lt_cv_sys_max_cmd_len=8192; ;; amigaos*) # On AmigaOS with pdksh, this test takes hours, literally. # So we just punt and use a minimum line length of 8192. lt_cv_sys_max_cmd_len=8192; ;; netbsd* | freebsd* | openbsd* | darwin* | dragonfly*) # This has been around since 386BSD, at least. Likely further. if test -x /sbin/sysctl; then lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` elif test -x /usr/sbin/sysctl; then lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` else lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs fi # And add a safety zone lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` ;; interix*) # We know the value 262144 and hardcode it with a safety zone (like BSD) lt_cv_sys_max_cmd_len=196608 ;; os2*) # The test takes a long time on OS/2. lt_cv_sys_max_cmd_len=8192 ;; osf*) # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not # nice to cause kernel panics so lets avoid the loop below. # First set a reasonable default. lt_cv_sys_max_cmd_len=16384 # if test -x /sbin/sysconfig; then case `/sbin/sysconfig -q proc exec_disable_arg_limit` in *1*) lt_cv_sys_max_cmd_len=-1 ;; esac fi ;; sco3.2v5*) lt_cv_sys_max_cmd_len=102400 ;; sysv5* | sco5v6* | sysv4.2uw2*) kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` if test -n "$kargmax"; then lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[ ]//'` else lt_cv_sys_max_cmd_len=32768 fi ;; *) lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` if test -n "$lt_cv_sys_max_cmd_len" && \ test undefined != "$lt_cv_sys_max_cmd_len"; then lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` else # Make teststring a little bigger before we do anything with it. # a 1K string should be a reasonable start. for i in 1 2 3 4 5 6 7 8 ; do teststring=$teststring$teststring done SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} # If test is not a shell built-in, we'll probably end up computing a # maximum length that is only half of the actual maximum length, but # we can't tell. while { test "X"`env echo "$teststring$teststring" 2>/dev/null` \ = "X$teststring$teststring"; } >/dev/null 2>&1 && test $i != 17 # 1/2 MB should be enough do i=`expr $i + 1` teststring=$teststring$teststring done # Only check the string length outside the loop. lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` teststring= # Add a significant safety factor because C++ compilers can tack on # massive amounts of additional arguments before passing them to the # linker. It appears as though 1/2 is a usable value. lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` fi ;; esac fi if test -n $lt_cv_sys_max_cmd_len ; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sys_max_cmd_len" >&5 $as_echo "$lt_cv_sys_max_cmd_len" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: none" >&5 $as_echo "none" >&6; } fi max_cmd_len=$lt_cv_sys_max_cmd_len : ${CP="cp -f"} : ${MV="mv -f"} : ${RM="rm -f"} { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the shell understands some XSI constructs" >&5 $as_echo_n "checking whether the shell understands some XSI constructs... " >&6; } # Try some XSI features xsi_shell=no ( _lt_dummy="a/b/c" test "${_lt_dummy##*/},${_lt_dummy%/*},${_lt_dummy#??}"${_lt_dummy%"$_lt_dummy"}, \ = c,a/b,b/c, \ && eval 'test $(( 1 + 1 )) -eq 2 \ && test "${#_lt_dummy}" -eq 5' ) >/dev/null 2>&1 \ && xsi_shell=yes { $as_echo "$as_me:${as_lineno-$LINENO}: result: $xsi_shell" >&5 $as_echo "$xsi_shell" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the shell understands \"+=\"" >&5 $as_echo_n "checking whether the shell understands \"+=\"... " >&6; } lt_shell_append=no ( foo=bar; set foo baz; eval "$1+=\$2" && test "$foo" = barbaz ) \ >/dev/null 2>&1 \ && lt_shell_append=yes { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_shell_append" >&5 $as_echo "$lt_shell_append" >&6; } if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then lt_unset=unset else lt_unset=false fi # test EBCDIC or ASCII case `echo X|tr X '\101'` in A) # ASCII based system # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr lt_SP2NL='tr \040 \012' lt_NL2SP='tr \015\012 \040\040' ;; *) # EBCDIC based system lt_SP2NL='tr \100 \n' lt_NL2SP='tr \r\n \100\100' ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to convert $build file names to $host format" >&5 $as_echo_n "checking how to convert $build file names to $host format... " >&6; } if ${lt_cv_to_host_file_cmd+:} false; then : $as_echo_n "(cached) " >&6 else case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_w32 ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_cygwin_to_w32 ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_w32 ;; esac ;; *-*-cygwin* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_cygwin ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_noop ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_cygwin ;; esac ;; * ) # unhandled hosts (and "normal" native builds) lt_cv_to_host_file_cmd=func_convert_file_noop ;; esac fi to_host_file_cmd=$lt_cv_to_host_file_cmd { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_to_host_file_cmd" >&5 $as_echo "$lt_cv_to_host_file_cmd" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to convert $build file names to toolchain format" >&5 $as_echo_n "checking how to convert $build file names to toolchain format... " >&6; } if ${lt_cv_to_tool_file_cmd+:} false; then : $as_echo_n "(cached) " >&6 else #assume ordinary cross tools, or native build. lt_cv_to_tool_file_cmd=func_convert_file_noop case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_tool_file_cmd=func_convert_file_msys_to_w32 ;; esac ;; esac fi to_tool_file_cmd=$lt_cv_to_tool_file_cmd { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_to_tool_file_cmd" >&5 $as_echo "$lt_cv_to_tool_file_cmd" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $LD option to reload object files" >&5 $as_echo_n "checking for $LD option to reload object files... " >&6; } if ${lt_cv_ld_reload_flag+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ld_reload_flag='-r' fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_reload_flag" >&5 $as_echo "$lt_cv_ld_reload_flag" >&6; } reload_flag=$lt_cv_ld_reload_flag case $reload_flag in "" | " "*) ;; *) reload_flag=" $reload_flag" ;; esac reload_cmds='$LD$reload_flag -o $output$reload_objs' case $host_os in cygwin* | mingw* | pw32* | cegcc*) if test "$GCC" != yes; then reload_cmds=false fi ;; darwin*) if test "$GCC" = yes; then reload_cmds='$LTCC $LTCFLAGS -nostdlib ${wl}-r -o $output$reload_objs' else reload_cmds='$LD$reload_flag -o $output$reload_objs' fi ;; esac if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args. set dummy ${ac_tool_prefix}objdump; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_OBJDUMP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJDUMP"; then ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OBJDUMP=$ac_cv_prog_OBJDUMP if test -n "$OBJDUMP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OBJDUMP" >&5 $as_echo "$OBJDUMP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_OBJDUMP"; then ac_ct_OBJDUMP=$OBJDUMP # Extract the first word of "objdump", so it can be a program name with args. set dummy objdump; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_OBJDUMP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJDUMP"; then ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OBJDUMP="objdump" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP if test -n "$ac_ct_OBJDUMP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OBJDUMP" >&5 $as_echo "$ac_ct_OBJDUMP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_OBJDUMP" = x; then OBJDUMP="false" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OBJDUMP=$ac_ct_OBJDUMP fi else OBJDUMP="$ac_cv_prog_OBJDUMP" fi test -z "$OBJDUMP" && OBJDUMP=objdump { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to recognize dependent libraries" >&5 $as_echo_n "checking how to recognize dependent libraries... " >&6; } if ${lt_cv_deplibs_check_method+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_file_magic_cmd='$MAGIC_CMD' lt_cv_file_magic_test_file= lt_cv_deplibs_check_method='unknown' # Need to set the preceding variable on all platforms that support # interlibrary dependencies. # 'none' -- dependencies not supported. # `unknown' -- same as none, but documents that we really don't know. # 'pass_all' -- all dependencies passed with no checks. # 'test_compile' -- check by making test program. # 'file_magic [[regex]]' -- check by looking for files in library path # which responds to the $file_magic_cmd with a given extended regex. # If you have `file' or equivalent on your system and you're not sure # whether `pass_all' will *always* work, you probably want this one. case $host_os in aix[4-9]*) lt_cv_deplibs_check_method=pass_all ;; beos*) lt_cv_deplibs_check_method=pass_all ;; bsdi[45]*) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib)' lt_cv_file_magic_cmd='/usr/bin/file -L' lt_cv_file_magic_test_file=/shlib/libc.so ;; cygwin*) # func_win32_libid is a shell function defined in ltmain.sh lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' ;; mingw* | pw32*) # Base MSYS/MinGW do not provide the 'file' command needed by # func_win32_libid shell function, so use a weaker test based on 'objdump', # unless we find 'file', for example because we are cross-compiling. # func_win32_libid assumes BSD nm, so disallow it if using MS dumpbin. if ( test "$lt_cv_nm_interface" = "BSD nm" && file / ) >/dev/null 2>&1; then lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' else # Keep this pattern in sync with the one in func_win32_libid. lt_cv_deplibs_check_method='file_magic file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' lt_cv_file_magic_cmd='$OBJDUMP -f' fi ;; cegcc*) # use the weaker test based on 'objdump'. See mingw*. lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' lt_cv_file_magic_cmd='$OBJDUMP -f' ;; darwin* | rhapsody*) lt_cv_deplibs_check_method=pass_all ;; freebsd* | dragonfly*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then case $host_cpu in i*86 ) # Not sure whether the presence of OpenBSD here was a mistake. # Let's accept both of them until this is cleared up. lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[3-9]86 (compact )?demand paged shared library' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` ;; esac else lt_cv_deplibs_check_method=pass_all fi ;; haiku*) lt_cv_deplibs_check_method=pass_all ;; hpux10.20* | hpux11*) lt_cv_file_magic_cmd=/usr/bin/file case $host_cpu in ia64*) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - IA64' lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so ;; hppa*64*) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF[ -][0-9][0-9])(-bit)?( [LM]SB)? shared object( file)?[, -]* PA-RISC [0-9]\.[0-9]' lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl ;; *) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|PA-RISC[0-9]\.[0-9]) shared library' lt_cv_file_magic_test_file=/usr/lib/libc.sl ;; esac ;; interix[3-9]*) # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|\.a)$' ;; irix5* | irix6* | nonstopux*) case $LD in *-32|*"-32 ") libmagic=32-bit;; *-n32|*"-n32 ") libmagic=N32;; *-64|*"-64 ") libmagic=64-bit;; *) libmagic=never-match;; esac lt_cv_deplibs_check_method=pass_all ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) lt_cv_deplibs_check_method=pass_all ;; netbsd* | netbsdelf*-gnu) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|_pic\.a)$' fi ;; newos6*) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (executable|dynamic lib)' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=/usr/lib/libnls.so ;; *nto* | *qnx*) lt_cv_deplibs_check_method=pass_all ;; openbsd*) if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|\.so|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' fi ;; osf3* | osf4* | osf5*) lt_cv_deplibs_check_method=pass_all ;; rdos*) lt_cv_deplibs_check_method=pass_all ;; solaris*) lt_cv_deplibs_check_method=pass_all ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) lt_cv_deplibs_check_method=pass_all ;; sysv4 | sysv4.3*) case $host_vendor in motorola) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib) M[0-9][0-9]* Version [0-9]' lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` ;; ncr) lt_cv_deplibs_check_method=pass_all ;; sequent) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [LM]SB (shared object|dynamic lib )' ;; sni) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method="file_magic ELF [0-9][0-9]*-bit [LM]SB dynamic lib" lt_cv_file_magic_test_file=/lib/libc.so ;; siemens) lt_cv_deplibs_check_method=pass_all ;; pc) lt_cv_deplibs_check_method=pass_all ;; esac ;; tpf*) lt_cv_deplibs_check_method=pass_all ;; esac fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_deplibs_check_method" >&5 $as_echo "$lt_cv_deplibs_check_method" >&6; } file_magic_glob= want_nocaseglob=no if test "$build" = "$host"; then case $host_os in mingw* | pw32*) if ( shopt | grep nocaseglob ) >/dev/null 2>&1; then want_nocaseglob=yes else file_magic_glob=`echo aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ | $SED -e "s/\(..\)/s\/[\1]\/[\1]\/g;/g"` fi ;; esac fi file_magic_cmd=$lt_cv_file_magic_cmd deplibs_check_method=$lt_cv_deplibs_check_method test -z "$deplibs_check_method" && deplibs_check_method=unknown if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}dlltool", so it can be a program name with args. set dummy ${ac_tool_prefix}dlltool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_DLLTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DLLTOOL"; then ac_cv_prog_DLLTOOL="$DLLTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_DLLTOOL="${ac_tool_prefix}dlltool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DLLTOOL=$ac_cv_prog_DLLTOOL if test -n "$DLLTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DLLTOOL" >&5 $as_echo "$DLLTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_DLLTOOL"; then ac_ct_DLLTOOL=$DLLTOOL # Extract the first word of "dlltool", so it can be a program name with args. set dummy dlltool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_DLLTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_DLLTOOL"; then ac_cv_prog_ac_ct_DLLTOOL="$ac_ct_DLLTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DLLTOOL="dlltool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DLLTOOL=$ac_cv_prog_ac_ct_DLLTOOL if test -n "$ac_ct_DLLTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DLLTOOL" >&5 $as_echo "$ac_ct_DLLTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_DLLTOOL" = x; then DLLTOOL="false" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DLLTOOL=$ac_ct_DLLTOOL fi else DLLTOOL="$ac_cv_prog_DLLTOOL" fi test -z "$DLLTOOL" && DLLTOOL=dlltool { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to associate runtime and link libraries" >&5 $as_echo_n "checking how to associate runtime and link libraries... " >&6; } if ${lt_cv_sharedlib_from_linklib_cmd+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_sharedlib_from_linklib_cmd='unknown' case $host_os in cygwin* | mingw* | pw32* | cegcc*) # two different shell functions defined in ltmain.sh # decide which to use based on capabilities of $DLLTOOL case `$DLLTOOL --help 2>&1` in *--identify-strict*) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib ;; *) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib_fallback ;; esac ;; *) # fallback: assume linklib IS sharedlib lt_cv_sharedlib_from_linklib_cmd="$ECHO" ;; esac fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sharedlib_from_linklib_cmd" >&5 $as_echo "$lt_cv_sharedlib_from_linklib_cmd" >&6; } sharedlib_from_linklib_cmd=$lt_cv_sharedlib_from_linklib_cmd test -z "$sharedlib_from_linklib_cmd" && sharedlib_from_linklib_cmd=$ECHO if test -n "$ac_tool_prefix"; then for ac_prog in ar do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_AR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$AR"; then ac_cv_prog_AR="$AR" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_AR="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi AR=$ac_cv_prog_AR if test -n "$AR"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AR" >&5 $as_echo "$AR" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$AR" && break done fi if test -z "$AR"; then ac_ct_AR=$AR for ac_prog in ar do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_AR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_AR"; then ac_cv_prog_ac_ct_AR="$ac_ct_AR" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_AR="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_AR=$ac_cv_prog_ac_ct_AR if test -n "$ac_ct_AR"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_AR" >&5 $as_echo "$ac_ct_AR" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_AR" && break done if test "x$ac_ct_AR" = x; then AR="false" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac AR=$ac_ct_AR fi fi : ${AR=ar} : ${AR_FLAGS=cru} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for archiver @FILE support" >&5 $as_echo_n "checking for archiver @FILE support... " >&6; } if ${lt_cv_ar_at_file+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ar_at_file=no cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO"; then : echo conftest.$ac_objext > conftest.lst lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&5' { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5 (eval $lt_ar_try) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if test "$ac_status" -eq 0; then # Ensure the archiver fails upon bogus file names. rm -f conftest.$ac_objext libconftest.a { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5 (eval $lt_ar_try) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if test "$ac_status" -ne 0; then lt_cv_ar_at_file=@ fi fi rm -f conftest.* libconftest.a fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ar_at_file" >&5 $as_echo "$lt_cv_ar_at_file" >&6; } if test "x$lt_cv_ar_at_file" = xno; then archiver_list_spec= else archiver_list_spec=$lt_cv_ar_at_file fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. set dummy ${ac_tool_prefix}strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$STRIP"; then ac_cv_prog_STRIP="$STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_STRIP="${ac_tool_prefix}strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi STRIP=$ac_cv_prog_STRIP if test -n "$STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 $as_echo "$STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_STRIP"; then ac_ct_STRIP=$STRIP # Extract the first word of "strip", so it can be a program name with args. set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_STRIP"; then ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_STRIP="strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP if test -n "$ac_ct_STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 $as_echo "$ac_ct_STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_STRIP" = x; then STRIP=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac STRIP=$ac_ct_STRIP fi else STRIP="$ac_cv_prog_STRIP" fi test -z "$STRIP" && STRIP=: if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. set dummy ${ac_tool_prefix}ranlib; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_RANLIB+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$RANLIB"; then ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi RANLIB=$ac_cv_prog_RANLIB if test -n "$RANLIB"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $RANLIB" >&5 $as_echo "$RANLIB" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_RANLIB"; then ac_ct_RANLIB=$RANLIB # Extract the first word of "ranlib", so it can be a program name with args. set dummy ranlib; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_RANLIB+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_RANLIB"; then ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_RANLIB="ranlib" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB if test -n "$ac_ct_RANLIB"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_RANLIB" >&5 $as_echo "$ac_ct_RANLIB" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_RANLIB" = x; then RANLIB=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac RANLIB=$ac_ct_RANLIB fi else RANLIB="$ac_cv_prog_RANLIB" fi test -z "$RANLIB" && RANLIB=: # Determine commands to create old-style static archives. old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' old_postinstall_cmds='chmod 644 $oldlib' old_postuninstall_cmds= if test -n "$RANLIB"; then case $host_os in openbsd*) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib" ;; *) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$tool_oldlib" ;; esac old_archive_cmds="$old_archive_cmds~\$RANLIB \$tool_oldlib" fi case $host_os in darwin*) lock_old_archive_extraction=yes ;; *) lock_old_archive_extraction=no ;; esac # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # Check for command to grab the raw symbol name followed by C symbol from nm. { $as_echo "$as_me:${as_lineno-$LINENO}: checking command to parse $NM output from $compiler object" >&5 $as_echo_n "checking command to parse $NM output from $compiler object... " >&6; } if ${lt_cv_sys_global_symbol_pipe+:} false; then : $as_echo_n "(cached) " >&6 else # These are sane defaults that work on at least a few old systems. # [They come from Ultrix. What could be older than Ultrix?!! ;)] # Character class describing NM global symbol codes. symcode='[BCDEGRST]' # Regexp to match symbols that can be accessed directly from C. sympat='\([_A-Za-z][_A-Za-z0-9]*\)' # Define system-specific variables. case $host_os in aix*) symcode='[BCDT]' ;; cygwin* | mingw* | pw32* | cegcc*) symcode='[ABCDGISTW]' ;; hpux*) if test "$host_cpu" = ia64; then symcode='[ABCDEGRST]' fi ;; irix* | nonstopux*) symcode='[BCDEGRST]' ;; osf*) symcode='[BCDEGQRST]' ;; solaris*) symcode='[BDRT]' ;; sco3.2v5*) symcode='[DT]' ;; sysv4.2uw2*) symcode='[DT]' ;; sysv5* | sco5v6* | unixware* | OpenUNIX*) symcode='[ABDT]' ;; sysv4) symcode='[DFNSTU]' ;; esac # If we're using GNU nm, then use its standard symbol codes. case `$NM -V 2>&1` in *GNU* | *'with BFD'*) symcode='[ABCDGIRSTW]' ;; esac # Transform an extracted symbol line into a proper C declaration. # Some systems (esp. on ia64) link data and code symbols differently, # so use this general approach. lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'" # Transform an extracted symbol line into symbol name and symbol address lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([^ ]*\)[ ]*$/ {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([^ ]*\) \([^ ]*\)$/ {\"\2\", (void *) \&\2},/p'" lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n -e 's/^: \([^ ]*\)[ ]*$/ {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([^ ]*\) \(lib[^ ]*\)$/ {\"\2\", (void *) \&\2},/p' -e 's/^$symcode* \([^ ]*\) \([^ ]*\)$/ {\"lib\2\", (void *) \&\2},/p'" # Handle CRLF in mingw tool chain opt_cr= case $build_os in mingw*) opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp ;; esac # Try without a prefix underscore, then with it. for ac_symprfx in "" "_"; do # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. symxfrm="\\1 $ac_symprfx\\2 \\2" # Write the raw and C identifiers. if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Fake it for dumpbin and say T for any non-static function # and D for any global variable. # Also find C++ and __fastcall symbols from MSVC++, # which start with @ or ?. lt_cv_sys_global_symbol_pipe="$AWK '"\ " {last_section=section; section=\$ 3};"\ " /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\ " /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ " \$ 0!~/External *\|/{next};"\ " / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ " {if(hide[section]) next};"\ " {f=0}; \$ 0~/\(\).*\|/{f=1}; {printf f ? \"T \" : \"D \"};"\ " {split(\$ 0, a, /\||\r/); split(a[2], s)};"\ " s[1]~/^[@?]/{print s[1], s[1]; next};"\ " s[1]~prfx {split(s[1],t,\"@\"); print t[1], substr(t[1],length(prfx))}"\ " ' prfx=^$ac_symprfx" else lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[ ]\($symcode$symcode*\)[ ][ ]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" fi lt_cv_sys_global_symbol_pipe="$lt_cv_sys_global_symbol_pipe | sed '/ __gnu_lto/d'" # Check to see that the pipe works correctly. pipe_works=no rm -f conftest* cat > conftest.$ac_ext <<_LT_EOF #ifdef __cplusplus extern "C" { #endif char nm_test_var; void nm_test_func(void); void nm_test_func(void){} #ifdef __cplusplus } #endif int main(){nm_test_var='a';nm_test_func();return(0);} _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then # Now try to grab the symbols. nlist=conftest.nm if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist\""; } >&5 (eval $NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "$nlist"; then # Try sorting and uniquifying the output. if sort "$nlist" | uniq > "$nlist"T; then mv -f "$nlist"T "$nlist" else rm -f "$nlist"T fi # Make sure that we snagged all the symbols we need. if $GREP ' nm_test_var$' "$nlist" >/dev/null; then if $GREP ' nm_test_func$' "$nlist" >/dev/null; then cat <<_LT_EOF > conftest.$ac_ext /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined(_WIN32) || defined(__CYGWIN__) || defined(_WIN32_WCE) /* DATA imports from DLLs on WIN32 con't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT_DLSYM_CONST #elif defined(__osf__) /* This system does not cope well with relocations in const data. */ # define LT_DLSYM_CONST #else # define LT_DLSYM_CONST const #endif #ifdef __cplusplus extern "C" { #endif _LT_EOF # Now generate the symbol file. eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' cat <<_LT_EOF >> conftest.$ac_ext /* The mapping between symbol names and symbols. */ LT_DLSYM_CONST struct { const char *name; void *address; } lt__PROGRAM__LTX_preloaded_symbols[] = { { "@PROGRAM@", (void *) 0 }, _LT_EOF $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/ {\"\2\", (void *) \&\2},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext cat <<\_LT_EOF >> conftest.$ac_ext {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt__PROGRAM__LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif _LT_EOF # Now try linking the two files. mv conftest.$ac_objext conftstm.$ac_objext lt_globsym_save_LIBS=$LIBS lt_globsym_save_CFLAGS=$CFLAGS LIBS="conftstm.$ac_objext" CFLAGS="$CFLAGS$lt_prog_compiler_no_builtin_flag" if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s conftest${ac_exeext}; then pipe_works=yes fi LIBS=$lt_globsym_save_LIBS CFLAGS=$lt_globsym_save_CFLAGS else echo "cannot find nm_test_func in $nlist" >&5 fi else echo "cannot find nm_test_var in $nlist" >&5 fi else echo "cannot run $lt_cv_sys_global_symbol_pipe" >&5 fi else echo "$progname: failed program was:" >&5 cat conftest.$ac_ext >&5 fi rm -rf conftest* conftst* # Do not use the global_symbol_pipe unless it works. if test "$pipe_works" = yes; then break else lt_cv_sys_global_symbol_pipe= fi done fi if test -z "$lt_cv_sys_global_symbol_pipe"; then lt_cv_sys_global_symbol_to_cdecl= fi if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: failed" >&5 $as_echo "failed" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: ok" >&5 $as_echo "ok" >&6; } fi # Response file support. if test "$lt_cv_nm_interface" = "MS dumpbin"; then nm_file_list_spec='@' elif $NM --help 2>/dev/null | grep '[@]FILE' >/dev/null; then nm_file_list_spec='@' fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for sysroot" >&5 $as_echo_n "checking for sysroot... " >&6; } # Check whether --with-sysroot was given. if test "${with_sysroot+set}" = set; then : withval=$with_sysroot; else with_sysroot=no fi lt_sysroot= case ${with_sysroot} in #( yes) if test "$GCC" = yes; then lt_sysroot=`$CC --print-sysroot 2>/dev/null` fi ;; #( /*) lt_sysroot=`echo "$with_sysroot" | sed -e "$sed_quote_subst"` ;; #( no|'') ;; #( *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: ${with_sysroot}" >&5 $as_echo "${with_sysroot}" >&6; } as_fn_error $? "The sysroot must be an absolute path." "$LINENO" 5 ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: ${lt_sysroot:-no}" >&5 $as_echo "${lt_sysroot:-no}" >&6; } # Check whether --enable-libtool-lock was given. if test "${enable_libtool_lock+set}" = set; then : enableval=$enable_libtool_lock; fi test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes # Some flags need to be propagated to the compiler or linker for good # libtool support. case $host in ia64-*-hpux*) # Find out which ABI we are using. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `/usr/bin/file conftest.$ac_objext` in *ELF-32*) HPUX_IA64_MODE="32" ;; *ELF-64*) HPUX_IA64_MODE="64" ;; esac fi rm -rf conftest* ;; *-*-irix6*) # Find out which ABI we are using. echo '#line '$LINENO' "configure"' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then if test "$lt_cv_prog_gnu_ld" = yes; then case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -melf32bsmip" ;; *N32*) LD="${LD-ld} -melf32bmipn32" ;; *64-bit*) LD="${LD-ld} -melf64bmip" ;; esac else case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -32" ;; *N32*) LD="${LD-ld} -n32" ;; *64-bit*) LD="${LD-ld} -64" ;; esac fi fi rm -rf conftest* ;; x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ s390*-*linux*|s390*-*tpf*|sparc*-*linux*) # Find out which ABI we are using. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `/usr/bin/file conftest.o` in *32-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_i386_fbsd" ;; x86_64-*linux*) case `/usr/bin/file conftest.o` in *x86-64*) LD="${LD-ld} -m elf32_x86_64" ;; *) LD="${LD-ld} -m elf_i386" ;; esac ;; powerpc64le-*) LD="${LD-ld} -m elf32lppclinux" ;; powerpc64-*) LD="${LD-ld} -m elf32ppclinux" ;; s390x-*linux*) LD="${LD-ld} -m elf_s390" ;; sparc64-*linux*) LD="${LD-ld} -m elf32_sparc" ;; esac ;; *64-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_x86_64_fbsd" ;; x86_64-*linux*) LD="${LD-ld} -m elf_x86_64" ;; powerpcle-*) LD="${LD-ld} -m elf64lppc" ;; powerpc-*) LD="${LD-ld} -m elf64ppc" ;; s390*-*linux*|s390*-*tpf*) LD="${LD-ld} -m elf64_s390" ;; sparc*-*linux*) LD="${LD-ld} -m elf64_sparc" ;; esac ;; esac fi rm -rf conftest* ;; *-*-sco3.2v5*) # On SCO OpenServer 5, we need -belf to get full-featured binaries. SAVE_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS -belf" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler needs -belf" >&5 $as_echo_n "checking whether the C compiler needs -belf... " >&6; } if ${lt_cv_cc_needs_belf+:} false; then : $as_echo_n "(cached) " >&6 else ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_cv_cc_needs_belf=yes else lt_cv_cc_needs_belf=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_cc_needs_belf" >&5 $as_echo "$lt_cv_cc_needs_belf" >&6; } if test x"$lt_cv_cc_needs_belf" != x"yes"; then # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf CFLAGS="$SAVE_CFLAGS" fi ;; *-*solaris*) # Find out which ABI we are using. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `/usr/bin/file conftest.o` in *64-bit*) case $lt_cv_prog_gnu_ld in yes*) case $host in i?86-*-solaris*) LD="${LD-ld} -m elf_x86_64" ;; sparc*-*-solaris*) LD="${LD-ld} -m elf64_sparc" ;; esac # GNU ld 2.21 introduced _sol2 emulations. Use them if available. if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then LD="${LD-ld}_sol2" fi ;; *) if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then LD="${LD-ld} -64" fi ;; esac ;; esac fi rm -rf conftest* ;; esac need_locks="$enable_libtool_lock" if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}mt", so it can be a program name with args. set dummy ${ac_tool_prefix}mt; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_MANIFEST_TOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$MANIFEST_TOOL"; then ac_cv_prog_MANIFEST_TOOL="$MANIFEST_TOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_MANIFEST_TOOL="${ac_tool_prefix}mt" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi MANIFEST_TOOL=$ac_cv_prog_MANIFEST_TOOL if test -n "$MANIFEST_TOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MANIFEST_TOOL" >&5 $as_echo "$MANIFEST_TOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_MANIFEST_TOOL"; then ac_ct_MANIFEST_TOOL=$MANIFEST_TOOL # Extract the first word of "mt", so it can be a program name with args. set dummy mt; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_MANIFEST_TOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_MANIFEST_TOOL"; then ac_cv_prog_ac_ct_MANIFEST_TOOL="$ac_ct_MANIFEST_TOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_MANIFEST_TOOL="mt" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_MANIFEST_TOOL=$ac_cv_prog_ac_ct_MANIFEST_TOOL if test -n "$ac_ct_MANIFEST_TOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_MANIFEST_TOOL" >&5 $as_echo "$ac_ct_MANIFEST_TOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_MANIFEST_TOOL" = x; then MANIFEST_TOOL=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac MANIFEST_TOOL=$ac_ct_MANIFEST_TOOL fi else MANIFEST_TOOL="$ac_cv_prog_MANIFEST_TOOL" fi test -z "$MANIFEST_TOOL" && MANIFEST_TOOL=mt { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $MANIFEST_TOOL is a manifest tool" >&5 $as_echo_n "checking if $MANIFEST_TOOL is a manifest tool... " >&6; } if ${lt_cv_path_mainfest_tool+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_path_mainfest_tool=no echo "$as_me:$LINENO: $MANIFEST_TOOL '-?'" >&5 $MANIFEST_TOOL '-?' 2>conftest.err > conftest.out cat conftest.err >&5 if $GREP 'Manifest Tool' conftest.out > /dev/null; then lt_cv_path_mainfest_tool=yes fi rm -f conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_mainfest_tool" >&5 $as_echo "$lt_cv_path_mainfest_tool" >&6; } if test "x$lt_cv_path_mainfest_tool" != xyes; then MANIFEST_TOOL=: fi case $host_os in rhapsody* | darwin*) if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}dsymutil", so it can be a program name with args. set dummy ${ac_tool_prefix}dsymutil; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_DSYMUTIL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DSYMUTIL"; then ac_cv_prog_DSYMUTIL="$DSYMUTIL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_DSYMUTIL="${ac_tool_prefix}dsymutil" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DSYMUTIL=$ac_cv_prog_DSYMUTIL if test -n "$DSYMUTIL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DSYMUTIL" >&5 $as_echo "$DSYMUTIL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_DSYMUTIL"; then ac_ct_DSYMUTIL=$DSYMUTIL # Extract the first word of "dsymutil", so it can be a program name with args. set dummy dsymutil; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_DSYMUTIL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_DSYMUTIL"; then ac_cv_prog_ac_ct_DSYMUTIL="$ac_ct_DSYMUTIL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DSYMUTIL="dsymutil" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DSYMUTIL=$ac_cv_prog_ac_ct_DSYMUTIL if test -n "$ac_ct_DSYMUTIL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DSYMUTIL" >&5 $as_echo "$ac_ct_DSYMUTIL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_DSYMUTIL" = x; then DSYMUTIL=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DSYMUTIL=$ac_ct_DSYMUTIL fi else DSYMUTIL="$ac_cv_prog_DSYMUTIL" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}nmedit", so it can be a program name with args. set dummy ${ac_tool_prefix}nmedit; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_NMEDIT+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$NMEDIT"; then ac_cv_prog_NMEDIT="$NMEDIT" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_NMEDIT="${ac_tool_prefix}nmedit" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi NMEDIT=$ac_cv_prog_NMEDIT if test -n "$NMEDIT"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $NMEDIT" >&5 $as_echo "$NMEDIT" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_NMEDIT"; then ac_ct_NMEDIT=$NMEDIT # Extract the first word of "nmedit", so it can be a program name with args. set dummy nmedit; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_NMEDIT+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_NMEDIT"; then ac_cv_prog_ac_ct_NMEDIT="$ac_ct_NMEDIT" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_NMEDIT="nmedit" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_NMEDIT=$ac_cv_prog_ac_ct_NMEDIT if test -n "$ac_ct_NMEDIT"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_NMEDIT" >&5 $as_echo "$ac_ct_NMEDIT" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_NMEDIT" = x; then NMEDIT=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac NMEDIT=$ac_ct_NMEDIT fi else NMEDIT="$ac_cv_prog_NMEDIT" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}lipo", so it can be a program name with args. set dummy ${ac_tool_prefix}lipo; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_LIPO+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$LIPO"; then ac_cv_prog_LIPO="$LIPO" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_LIPO="${ac_tool_prefix}lipo" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi LIPO=$ac_cv_prog_LIPO if test -n "$LIPO"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LIPO" >&5 $as_echo "$LIPO" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_LIPO"; then ac_ct_LIPO=$LIPO # Extract the first word of "lipo", so it can be a program name with args. set dummy lipo; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_LIPO+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_LIPO"; then ac_cv_prog_ac_ct_LIPO="$ac_ct_LIPO" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_LIPO="lipo" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_LIPO=$ac_cv_prog_ac_ct_LIPO if test -n "$ac_ct_LIPO"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_LIPO" >&5 $as_echo "$ac_ct_LIPO" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_LIPO" = x; then LIPO=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac LIPO=$ac_ct_LIPO fi else LIPO="$ac_cv_prog_LIPO" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}otool", so it can be a program name with args. set dummy ${ac_tool_prefix}otool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_OTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OTOOL"; then ac_cv_prog_OTOOL="$OTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_OTOOL="${ac_tool_prefix}otool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OTOOL=$ac_cv_prog_OTOOL if test -n "$OTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OTOOL" >&5 $as_echo "$OTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_OTOOL"; then ac_ct_OTOOL=$OTOOL # Extract the first word of "otool", so it can be a program name with args. set dummy otool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_OTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OTOOL"; then ac_cv_prog_ac_ct_OTOOL="$ac_ct_OTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OTOOL="otool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OTOOL=$ac_cv_prog_ac_ct_OTOOL if test -n "$ac_ct_OTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OTOOL" >&5 $as_echo "$ac_ct_OTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_OTOOL" = x; then OTOOL=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OTOOL=$ac_ct_OTOOL fi else OTOOL="$ac_cv_prog_OTOOL" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}otool64", so it can be a program name with args. set dummy ${ac_tool_prefix}otool64; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_OTOOL64+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OTOOL64"; then ac_cv_prog_OTOOL64="$OTOOL64" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_OTOOL64="${ac_tool_prefix}otool64" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OTOOL64=$ac_cv_prog_OTOOL64 if test -n "$OTOOL64"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OTOOL64" >&5 $as_echo "$OTOOL64" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_OTOOL64"; then ac_ct_OTOOL64=$OTOOL64 # Extract the first word of "otool64", so it can be a program name with args. set dummy otool64; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_OTOOL64+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OTOOL64"; then ac_cv_prog_ac_ct_OTOOL64="$ac_ct_OTOOL64" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OTOOL64="otool64" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OTOOL64=$ac_cv_prog_ac_ct_OTOOL64 if test -n "$ac_ct_OTOOL64"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OTOOL64" >&5 $as_echo "$ac_ct_OTOOL64" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_OTOOL64" = x; then OTOOL64=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OTOOL64=$ac_ct_OTOOL64 fi else OTOOL64="$ac_cv_prog_OTOOL64" fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -single_module linker flag" >&5 $as_echo_n "checking for -single_module linker flag... " >&6; } if ${lt_cv_apple_cc_single_mod+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_apple_cc_single_mod=no if test -z "${LT_MULTI_MODULE}"; then # By default we will add the -single_module flag. You can override # by either setting the environment variable LT_MULTI_MODULE # non-empty at configure time, or by adding -multi_module to the # link flags. rm -rf libconftest.dylib* echo "int foo(void){return 1;}" > conftest.c echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c" >&5 $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c 2>conftest.err _lt_result=$? # If there is a non-empty error log, and "single_module" # appears in it, assume the flag caused a linker warning if test -s conftest.err && $GREP single_module conftest.err; then cat conftest.err >&5 # Otherwise, if the output was created with a 0 exit code from # the compiler, it worked. elif test -f libconftest.dylib && test $_lt_result -eq 0; then lt_cv_apple_cc_single_mod=yes else cat conftest.err >&5 fi rm -rf libconftest.dylib* rm -f conftest.* fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_apple_cc_single_mod" >&5 $as_echo "$lt_cv_apple_cc_single_mod" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -exported_symbols_list linker flag" >&5 $as_echo_n "checking for -exported_symbols_list linker flag... " >&6; } if ${lt_cv_ld_exported_symbols_list+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ld_exported_symbols_list=no save_LDFLAGS=$LDFLAGS echo "_main" > conftest.sym LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_cv_ld_exported_symbols_list=yes else lt_cv_ld_exported_symbols_list=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS="$save_LDFLAGS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_exported_symbols_list" >&5 $as_echo "$lt_cv_ld_exported_symbols_list" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -force_load linker flag" >&5 $as_echo_n "checking for -force_load linker flag... " >&6; } if ${lt_cv_ld_force_load+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ld_force_load=no cat > conftest.c << _LT_EOF int forced_loaded() { return 2;} _LT_EOF echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&5 $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&5 echo "$AR cru libconftest.a conftest.o" >&5 $AR cru libconftest.a conftest.o 2>&5 echo "$RANLIB libconftest.a" >&5 $RANLIB libconftest.a 2>&5 cat > conftest.c << _LT_EOF int main() { return 0;} _LT_EOF echo "$LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a" >&5 $LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a 2>conftest.err _lt_result=$? if test -s conftest.err && $GREP force_load conftest.err; then cat conftest.err >&5 elif test -f conftest && test $_lt_result -eq 0 && $GREP forced_load conftest >/dev/null 2>&1 ; then lt_cv_ld_force_load=yes else cat conftest.err >&5 fi rm -f conftest.err libconftest.a conftest conftest.c rm -rf conftest.dSYM fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_force_load" >&5 $as_echo "$lt_cv_ld_force_load" >&6; } case $host_os in rhapsody* | darwin1.[012]) _lt_dar_allow_undefined='${wl}-undefined ${wl}suppress' ;; darwin1.*) _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;; darwin*) # darwin 5.x on # if running on 10.5 or later, the deployment target defaults # to the OS version, if on x86, and 10.4, the deployment # target defaults to 10.4. Don't you love it? case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in 10.0,*86*-darwin8*|10.0,*-darwin[91]*) _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;; 10.[012]*) _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;; 10.*) _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;; esac ;; esac if test "$lt_cv_apple_cc_single_mod" = "yes"; then _lt_dar_single_mod='$single_module' fi if test "$lt_cv_ld_exported_symbols_list" = "yes"; then _lt_dar_export_syms=' ${wl}-exported_symbols_list,$output_objdir/${libname}-symbols.expsym' else _lt_dar_export_syms='~$NMEDIT -s $output_objdir/${libname}-symbols.expsym ${lib}' fi if test "$DSYMUTIL" != ":" && test "$lt_cv_ld_force_load" = "no"; then _lt_dsymutil='~$DSYMUTIL $lib || :' else _lt_dsymutil= fi ;; esac ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to run the C preprocessor" >&5 $as_echo_n "checking how to run the C preprocessor... " >&6; } # On Suns, sometimes $CPP names a directory. if test -n "$CPP" && test -d "$CPP"; then CPP= fi if test -z "$CPP"; then if ${ac_cv_prog_CPP+:} false; then : $as_echo_n "(cached) " >&6 else # Double quotes because CPP needs to be expanded for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp" do ac_preproc_ok=false for ac_c_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # Prefer to if __STDC__ is defined, since # exists even on freestanding compilers. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __STDC__ # include #else # include #endif Syntax error _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : else # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : # Broken: success on invalid input. continue else # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok; then : break fi done ac_cv_prog_CPP=$CPP fi CPP=$ac_cv_prog_CPP else ac_cv_prog_CPP=$CPP fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CPP" >&5 $as_echo "$CPP" >&6; } ac_preproc_ok=false for ac_c_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # Prefer to if __STDC__ is defined, since # exists even on freestanding compilers. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __STDC__ # include #else # include #endif Syntax error _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : else # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : # Broken: success on invalid input. continue else # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok; then : else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C preprocessor \"$CPP\" fails sanity check See \`config.log' for more details" "$LINENO" 5; } fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5 $as_echo_n "checking for ANSI C header files... " >&6; } if ${ac_cv_header_stdc+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include #include #include int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_header_stdc=yes else ac_cv_header_stdc=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext if test $ac_cv_header_stdc = yes; then # SunOS 4.x string.h does not declare mem*, contrary to ANSI. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "memchr" >/dev/null 2>&1; then : else ac_cv_header_stdc=no fi rm -f conftest* fi if test $ac_cv_header_stdc = yes; then # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "free" >/dev/null 2>&1; then : else ac_cv_header_stdc=no fi rm -f conftest* fi if test $ac_cv_header_stdc = yes; then # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi. if test "$cross_compiling" = yes; then : : else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include #if ((' ' & 0x0FF) == 0x020) # define ISLOWER(c) ('a' <= (c) && (c) <= 'z') # define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) #else # define ISLOWER(c) \ (('a' <= (c) && (c) <= 'i') \ || ('j' <= (c) && (c) <= 'r') \ || ('s' <= (c) && (c) <= 'z')) # define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) #endif #define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) int main () { int i; for (i = 0; i < 256; i++) if (XOR (islower (i), ISLOWER (i)) || toupper (i) != TOUPPER (i)) return 2; return 0; } _ACEOF if ac_fn_c_try_run "$LINENO"; then : else ac_cv_header_stdc=no fi rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ conftest.$ac_objext conftest.beam conftest.$ac_ext fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_header_stdc" >&5 $as_echo "$ac_cv_header_stdc" >&6; } if test $ac_cv_header_stdc = yes; then $as_echo "#define STDC_HEADERS 1" >>confdefs.h fi # On IRIX 5.3, sys/types and inttypes.h are conflicting. for ac_header in sys/types.h sys/stat.h stdlib.h string.h memory.h strings.h \ inttypes.h stdint.h unistd.h do : as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` ac_fn_c_check_header_compile "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default " if eval test \"x\$"$as_ac_Header"\" = x"yes"; then : cat >>confdefs.h <<_ACEOF #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 _ACEOF fi done for ac_header in dlfcn.h do : ac_fn_c_check_header_compile "$LINENO" "dlfcn.h" "ac_cv_header_dlfcn_h" "$ac_includes_default " if test "x$ac_cv_header_dlfcn_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_DLFCN_H 1 _ACEOF fi done func_stripname_cnf () { case ${2} in .*) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%\\\\${2}\$%%"`;; *) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%${2}\$%%"`;; esac } # func_stripname_cnf # Set options enable_dlopen=no enable_win32_dll=no # Check whether --enable-shared was given. if test "${enable_shared+set}" = set; then : enableval=$enable_shared; p=${PACKAGE-default} case $enableval in yes) enable_shared=yes ;; no) enable_shared=no ;; *) enable_shared=no # Look at the argument we got. We use all the common list separators. lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," for pkg in $enableval; do IFS="$lt_save_ifs" if test "X$pkg" = "X$p"; then enable_shared=yes fi done IFS="$lt_save_ifs" ;; esac else enable_shared=yes fi # Check whether --enable-static was given. if test "${enable_static+set}" = set; then : enableval=$enable_static; p=${PACKAGE-default} case $enableval in yes) enable_static=yes ;; no) enable_static=no ;; *) enable_static=no # Look at the argument we got. We use all the common list separators. lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," for pkg in $enableval; do IFS="$lt_save_ifs" if test "X$pkg" = "X$p"; then enable_static=yes fi done IFS="$lt_save_ifs" ;; esac else enable_static=yes fi # Check whether --with-pic was given. if test "${with_pic+set}" = set; then : withval=$with_pic; lt_p=${PACKAGE-default} case $withval in yes|no) pic_mode=$withval ;; *) pic_mode=default # Look at the argument we got. We use all the common list separators. lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," for lt_pkg in $withval; do IFS="$lt_save_ifs" if test "X$lt_pkg" = "X$lt_p"; then pic_mode=yes fi done IFS="$lt_save_ifs" ;; esac else pic_mode=default fi test -z "$pic_mode" && pic_mode=default # Check whether --enable-fast-install was given. if test "${enable_fast_install+set}" = set; then : enableval=$enable_fast_install; p=${PACKAGE-default} case $enableval in yes) enable_fast_install=yes ;; no) enable_fast_install=no ;; *) enable_fast_install=no # Look at the argument we got. We use all the common list separators. lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," for pkg in $enableval; do IFS="$lt_save_ifs" if test "X$pkg" = "X$p"; then enable_fast_install=yes fi done IFS="$lt_save_ifs" ;; esac else enable_fast_install=yes fi # This can be used to rebuild libtool when needed LIBTOOL_DEPS="$ltmain" # Always use our own libtool. LIBTOOL='$(SHELL) $(top_builddir)/libtool' test -z "$LN_S" && LN_S="ln -s" if test -n "${ZSH_VERSION+set}" ; then setopt NO_GLOB_SUBST fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for objdir" >&5 $as_echo_n "checking for objdir... " >&6; } if ${lt_cv_objdir+:} false; then : $as_echo_n "(cached) " >&6 else rm -f .libs 2>/dev/null mkdir .libs 2>/dev/null if test -d .libs; then lt_cv_objdir=.libs else # MS-DOS does not allow filenames that begin with a dot. lt_cv_objdir=_libs fi rmdir .libs 2>/dev/null fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_objdir" >&5 $as_echo "$lt_cv_objdir" >&6; } objdir=$lt_cv_objdir cat >>confdefs.h <<_ACEOF #define LT_OBJDIR "$lt_cv_objdir/" _ACEOF case $host_os in aix3*) # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test "X${COLLECT_NAMES+set}" != Xset; then COLLECT_NAMES= export COLLECT_NAMES fi ;; esac # Global variables: ofile=libtool can_build_shared=yes # All known linkers require a `.a' archive for static linking (except MSVC, # which needs '.lib'). libext=a with_gnu_ld="$lt_cv_prog_gnu_ld" old_CC="$CC" old_CFLAGS="$CFLAGS" # Set sane defaults for various variables test -z "$CC" && CC=cc test -z "$LTCC" && LTCC=$CC test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS test -z "$LD" && LD=ld test -z "$ac_objext" && ac_objext=o for cc_temp in $compiler""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done cc_basename=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` # Only perform the check for file, if the check method requires it test -z "$MAGIC_CMD" && MAGIC_CMD=file case $deplibs_check_method in file_magic*) if test "$file_magic_cmd" = '$MAGIC_CMD'; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ${ac_tool_prefix}file" >&5 $as_echo_n "checking for ${ac_tool_prefix}file... " >&6; } if ${lt_cv_path_MAGIC_CMD+:} false; then : $as_echo_n "(cached) " >&6 else case $MAGIC_CMD in [\\/*] | ?:[\\/]*) lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD="$MAGIC_CMD" lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" for ac_dir in $ac_dummy; do IFS="$lt_save_ifs" test -z "$ac_dir" && ac_dir=. if test -f $ac_dir/${ac_tool_prefix}file; then lt_cv_path_MAGIC_CMD="$ac_dir/${ac_tool_prefix}file" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD="$lt_cv_path_MAGIC_CMD" if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS="$lt_save_ifs" MAGIC_CMD="$lt_save_MAGIC_CMD" ;; esac fi MAGIC_CMD="$lt_cv_path_MAGIC_CMD" if test -n "$MAGIC_CMD"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5 $as_echo "$MAGIC_CMD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test -z "$lt_cv_path_MAGIC_CMD"; then if test -n "$ac_tool_prefix"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for file" >&5 $as_echo_n "checking for file... " >&6; } if ${lt_cv_path_MAGIC_CMD+:} false; then : $as_echo_n "(cached) " >&6 else case $MAGIC_CMD in [\\/*] | ?:[\\/]*) lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD="$MAGIC_CMD" lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" for ac_dir in $ac_dummy; do IFS="$lt_save_ifs" test -z "$ac_dir" && ac_dir=. if test -f $ac_dir/file; then lt_cv_path_MAGIC_CMD="$ac_dir/file" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD="$lt_cv_path_MAGIC_CMD" if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS="$lt_save_ifs" MAGIC_CMD="$lt_save_MAGIC_CMD" ;; esac fi MAGIC_CMD="$lt_cv_path_MAGIC_CMD" if test -n "$MAGIC_CMD"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5 $as_echo "$MAGIC_CMD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi else MAGIC_CMD=: fi fi fi ;; esac # Use C for the default configuration in the libtool script lt_save_CC="$CC" ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu # Source file extension for C test sources. ac_ext=c # Object file extension for compiled C test sources. objext=o objext=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(){return(0);}' # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # Save the default compiler, since it gets overwritten when the other # tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. compiler_DEFAULT=$CC # save warnings/boilerplate of simple test code ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then lt_prog_compiler_no_builtin_flag= if test "$GCC" = yes; then case $cc_basename in nvcc*) lt_prog_compiler_no_builtin_flag=' -Xcompiler -fno-builtin' ;; *) lt_prog_compiler_no_builtin_flag=' -fno-builtin' ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -fno-rtti -fno-exceptions" >&5 $as_echo_n "checking if $compiler supports -fno-rtti -fno-exceptions... " >&6; } if ${lt_cv_prog_compiler_rtti_exceptions+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_rtti_exceptions=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-fno-rtti -fno-exceptions" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_rtti_exceptions=yes fi fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_rtti_exceptions" >&5 $as_echo "$lt_cv_prog_compiler_rtti_exceptions" >&6; } if test x"$lt_cv_prog_compiler_rtti_exceptions" = xyes; then lt_prog_compiler_no_builtin_flag="$lt_prog_compiler_no_builtin_flag -fno-rtti -fno-exceptions" else : fi fi lt_prog_compiler_wl= lt_prog_compiler_pic= lt_prog_compiler_static= if test "$GCC" = yes; then lt_prog_compiler_wl='-Wl,' lt_prog_compiler_static='-static' case $host_os in aix*) # All AIX code is PIC. if test "$host_cpu" = ia64; then # AIX 5 now supports IA64 processor lt_prog_compiler_static='-Bstatic' fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support lt_prog_compiler_pic='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the `-m68020' flag to GCC prevents building anything better, # like `-m68040'. lt_prog_compiler_pic='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries lt_prog_compiler_pic='-DDLL_EXPORT' ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files lt_prog_compiler_pic='-fno-common' ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. lt_prog_compiler_static= ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) # +Z the default ;; *) lt_prog_compiler_pic='-fPIC' ;; esac ;; interix[3-9]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; msdosdjgpp*) # Just because we use GCC doesn't mean we suddenly get shared libraries # on systems that don't support them. lt_prog_compiler_can_build_shared=no enable_shared=no ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic='-fPIC -shared' ;; sysv4*MP*) if test -d /usr/nec; then lt_prog_compiler_pic=-Kconform_pic fi ;; *) lt_prog_compiler_pic='-fPIC' ;; esac case $cc_basename in nvcc*) # Cuda Compiler Driver 2.2 lt_prog_compiler_wl='-Xlinker ' if test -n "$lt_prog_compiler_pic"; then lt_prog_compiler_pic="-Xcompiler $lt_prog_compiler_pic" fi ;; esac else # PORTME Check for flag to pass linker flags through the system compiler. case $host_os in aix*) lt_prog_compiler_wl='-Wl,' if test "$host_cpu" = ia64; then # AIX 5 now supports IA64 processor lt_prog_compiler_static='-Bstatic' else lt_prog_compiler_static='-bnso -bI:/lib/syscalls.exp' fi ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). lt_prog_compiler_pic='-DDLL_EXPORT' ;; hpux9* | hpux10* | hpux11*) lt_prog_compiler_wl='-Wl,' # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but # not for PA HP-UX. case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) lt_prog_compiler_pic='+Z' ;; esac # Is there a better lt_prog_compiler_static that works with the bundled CC? lt_prog_compiler_static='${wl}-a ${wl}archive' ;; irix5* | irix6* | nonstopux*) lt_prog_compiler_wl='-Wl,' # PIC (with -KPIC) is the default. lt_prog_compiler_static='-non_shared' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in # old Intel for x86_64 which still supported -KPIC. ecc*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-static' ;; # icc used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. icc* | ifort*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; # Lahey Fortran 8.1. lf95*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='--shared' lt_prog_compiler_static='--static' ;; nagfor*) # NAG Fortran compiler lt_prog_compiler_wl='-Wl,-Wl,,' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group compilers (*not* the Pentium gcc compiler, # which looks to be a dead project) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fpic' lt_prog_compiler_static='-Bstatic' ;; ccc*) lt_prog_compiler_wl='-Wl,' # All Alpha code is PIC. lt_prog_compiler_static='-non_shared' ;; xl* | bgxl* | bgf* | mpixl*) # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-qpic' lt_prog_compiler_static='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [1-7].* | *Sun*Fortran*\ 8.[0-3]*) # Sun Fortran 8.3 passes all unrecognized flags to the linker lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='' ;; *Sun\ F* | *Sun*Fortran*) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='-Qoption ld ' ;; *Sun\ C*) # Sun C 5.9 lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='-Wl,' ;; *Intel*\ [CF]*Compiler*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; *Portland\ Group*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fpic' lt_prog_compiler_static='-Bstatic' ;; esac ;; esac ;; newsos6) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic='-fPIC -shared' ;; osf3* | osf4* | osf5*) lt_prog_compiler_wl='-Wl,' # All OSF/1 code is PIC. lt_prog_compiler_static='-non_shared' ;; rdos*) lt_prog_compiler_static='-non_shared' ;; solaris*) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) lt_prog_compiler_wl='-Qoption ld ';; *) lt_prog_compiler_wl='-Wl,';; esac ;; sunos4*) lt_prog_compiler_wl='-Qoption ld ' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; sysv4 | sysv4.2uw2* | sysv4.3*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; sysv4*MP*) if test -d /usr/nec ;then lt_prog_compiler_pic='-Kconform_pic' lt_prog_compiler_static='-Bstatic' fi ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; unicos*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_can_build_shared=no ;; uts4*) lt_prog_compiler_pic='-pic' lt_prog_compiler_static='-Bstatic' ;; *) lt_prog_compiler_can_build_shared=no ;; esac fi case $host_os in # For platforms which do not support PIC, -DPIC is meaningless: *djgpp*) lt_prog_compiler_pic= ;; *) lt_prog_compiler_pic="$lt_prog_compiler_pic -DPIC" ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $compiler option to produce PIC" >&5 $as_echo_n "checking for $compiler option to produce PIC... " >&6; } if ${lt_cv_prog_compiler_pic+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_pic=$lt_prog_compiler_pic fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic" >&5 $as_echo "$lt_cv_prog_compiler_pic" >&6; } lt_prog_compiler_pic=$lt_cv_prog_compiler_pic # # Check to make sure the PIC flag actually works. # if test -n "$lt_prog_compiler_pic"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler PIC flag $lt_prog_compiler_pic works" >&5 $as_echo_n "checking if $compiler PIC flag $lt_prog_compiler_pic works... " >&6; } if ${lt_cv_prog_compiler_pic_works+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_pic_works=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$lt_prog_compiler_pic -DPIC" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_pic_works=yes fi fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works" >&5 $as_echo "$lt_cv_prog_compiler_pic_works" >&6; } if test x"$lt_cv_prog_compiler_pic_works" = xyes; then case $lt_prog_compiler_pic in "" | " "*) ;; *) lt_prog_compiler_pic=" $lt_prog_compiler_pic" ;; esac else lt_prog_compiler_pic= lt_prog_compiler_can_build_shared=no fi fi # # Check to make sure the static flag actually works. # wl=$lt_prog_compiler_wl eval lt_tmp_static_flag=\"$lt_prog_compiler_static\" { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler static flag $lt_tmp_static_flag works" >&5 $as_echo_n "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; } if ${lt_cv_prog_compiler_static_works+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_static_works=no save_LDFLAGS="$LDFLAGS" LDFLAGS="$LDFLAGS $lt_tmp_static_flag" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_static_works=yes fi else lt_cv_prog_compiler_static_works=yes fi fi $RM -r conftest* LDFLAGS="$save_LDFLAGS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works" >&5 $as_echo "$lt_cv_prog_compiler_static_works" >&6; } if test x"$lt_cv_prog_compiler_static_works" = xyes; then : else lt_prog_compiler_static= fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 $as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if ${lt_cv_prog_compiler_c_o+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_c_o=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o" >&5 $as_echo "$lt_cv_prog_compiler_c_o" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 $as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if ${lt_cv_prog_compiler_c_o+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_c_o=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o" >&5 $as_echo "$lt_cv_prog_compiler_c_o" >&6; } hard_links="nottested" if test "$lt_cv_prog_compiler_c_o" = no && test "$need_locks" != no; then # do not overwrite the value of need_locks provided by the user { $as_echo "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5 $as_echo_n "checking if we can lock with hard links... " >&6; } hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5 $as_echo "$hard_links" >&6; } if test "$hard_links" = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 $as_echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} need_locks=warn fi else need_locks=no fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 $as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } runpath_var= allow_undefined_flag= always_export_symbols=no archive_cmds= archive_expsym_cmds= compiler_needs_object=no enable_shared_with_static_runtimes=no export_dynamic_flag_spec= export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' hardcode_automatic=no hardcode_direct=no hardcode_direct_absolute=no hardcode_libdir_flag_spec= hardcode_libdir_separator= hardcode_minus_L=no hardcode_shlibpath_var=unsupported inherit_rpath=no link_all_deplibs=unknown module_cmds= module_expsym_cmds= old_archive_from_new_cmds= old_archive_from_expsyms_cmds= thread_safe_flag_spec= whole_archive_flag_spec= # include_expsyms should be a list of space-separated symbols to be *always* # included in the symbol list include_expsyms= # exclude_expsyms can be an extended regexp of symbols to exclude # it will be wrapped by ` (' and `)$', so one must not match beginning or # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', # as well as any symbol that contains `d'. exclude_expsyms='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*' # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out # platforms (ab)use it in PIC code, but their linkers get confused if # the symbol is explicitly referenced. Since portable code cannot # rely on this symbol name, it's probably fine to never include it in # preloaded symbol tables. # Exclude shared library initialization/finalization symbols. extract_expsyms_cmds= case $host_os in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++. if test "$GCC" != yes; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++) with_gnu_ld=yes ;; openbsd*) with_gnu_ld=no ;; linux* | k*bsd*-gnu | gnu*) link_all_deplibs=no ;; esac ld_shlibs=yes # On some targets, GNU ld is compatible enough with the native linker # that we're better off using the native interface for both. lt_use_gnu_ld_interface=no if test "$with_gnu_ld" = yes; then case $host_os in aix*) # The AIX port of GNU ld has always aspired to compatibility # with the native linker. However, as the warning in the GNU ld # block says, versions before 2.19.5* couldn't really create working # shared libraries, regardless of the interface used. case `$LD -v 2>&1` in *\ \(GNU\ Binutils\)\ 2.19.5*) ;; *\ \(GNU\ Binutils\)\ 2.[2-9]*) ;; *\ \(GNU\ Binutils\)\ [3-9]*) ;; *) lt_use_gnu_ld_interface=yes ;; esac ;; *) lt_use_gnu_ld_interface=yes ;; esac fi if test "$lt_use_gnu_ld_interface" = yes; then # If archive_cmds runs LD, not CC, wlarc should be empty wlarc='${wl}' # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. runpath_var=LD_RUN_PATH hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' export_dynamic_flag_spec='${wl}--export-dynamic' # ancient GNU ld didn't support --whole-archive et. al. if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then whole_archive_flag_spec="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' else whole_archive_flag_spec= fi supports_anon_versioning=no case `$LD -v 2>&1` in *GNU\ gold*) supports_anon_versioning=yes ;; *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11 *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... *\ 2.11.*) ;; # other 2.11 versions *) supports_anon_versioning=yes ;; esac # See if GNU ld supports shared libraries. case $host_os in aix[3-9]*) # On AIX/PPC, the GNU linker is very broken if test "$host_cpu" != ia64; then ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: the GNU linker, at least up to release 2.19, is reported *** to be unable to reliably create shared libraries on AIX. *** Therefore, libtool is disabling shared libraries support. If you *** really care for shared libraries, you may want to install binutils *** 2.20 or above, or modify your PATH so that a non-GNU linker is found. *** You will then need to restart the configuration process. _LT_EOF fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds='' ;; m68k) archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then allow_undefined_flag=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' else ld_shlibs=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # _LT_TAGVAR(hardcode_libdir_flag_spec, ) is actually meaningless, # as there is no search path for DLLs. hardcode_libdir_flag_spec='-L$libdir' export_dynamic_flag_spec='${wl}--export-all-symbols' allow_undefined_flag=unsupported always_export_symbols=no enable_shared_with_static_runtimes=yes export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/;s/^.*[ ]__nm__\([^ ]*\)[ ][^ ]*/\1 DATA/;/^I[ ]/d;/^[AITW][ ]/s/.* //'\'' | sort | uniq > $export_symbols' exclude_expsyms='[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname' if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file (1st line # is EXPORTS), use it as is; otherwise, prepend... archive_expsym_cmds='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else ld_shlibs=no fi ;; haiku*) archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' link_all_deplibs=yes ;; interix[3-9]*) hardcode_direct=no hardcode_shlibpath_var=no hardcode_libdir_flag_spec='${wl}-rpath,$libdir' export_dynamic_flag_spec='${wl}-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' archive_expsym_cmds='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) tmp_diet=no if test "$host_os" = linux-dietlibc; then case $cc_basename in diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) esac fi if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ && test "$tmp_diet" = no then tmp_addflag=' $pic_flag' tmp_sharedflag='-shared' case $cc_basename,$host_cpu in pgcc*) # Portland Group C compiler whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' tmp_addflag=' $pic_flag' ;; pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group f77 and f90 compilers whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' tmp_addflag=' $pic_flag -Mnomain' ;; ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 tmp_addflag=' -i_dynamic' ;; efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 tmp_addflag=' -i_dynamic -nofor_main' ;; ifc* | ifort*) # Intel Fortran compiler tmp_addflag=' -nofor_main' ;; lf95*) # Lahey Fortran 8.1 whole_archive_flag_spec= tmp_sharedflag='--shared' ;; xl[cC]* | bgxl[cC]* | mpixl[cC]*) # IBM XL C 8.0 on PPC (deal with xlf below) tmp_sharedflag='-qmkshrobj' tmp_addflag= ;; nvcc*) # Cuda Compiler Driver 2.2 whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' compiler_needs_object=yes ;; esac case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C 5.9 whole_archive_flag_spec='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' compiler_needs_object=yes tmp_sharedflag='-G' ;; *Sun\ F*) # Sun Fortran 8.3 tmp_sharedflag='-G' ;; esac archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' if test "x$supports_anon_versioning" = xyes; then archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' fi case $cc_basename in xlf* | bgf* | bgxlf* | mpixlf*) # IBM XL Fortran 10.1 on PPC cannot create shared libs itself whole_archive_flag_spec='--whole-archive$convenience --no-whole-archive' hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' archive_cmds='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' if test "x$supports_anon_versioning" = xyes; then archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' fi ;; esac else ld_shlibs=no fi ;; netbsd* | netbsdelf*-gnu) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' wlarc= else archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' fi ;; solaris*) if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: The releases 2.8.* of the GNU linker cannot reliably *** create shared libraries on Solaris systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.9.1 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*) ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not *** reliably create shared libraries on SCO systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.16.91.0.3 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF ;; *) # For security reasons, it is highly recommended that you always # use absolute paths for naming shared libraries, and exclude the # DT_RUNPATH tag from executables and libraries. But doing so # requires that you compile everything twice, which is a pain. if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; esac ;; sunos4*) archive_cmds='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' wlarc= hardcode_direct=yes hardcode_shlibpath_var=no ;; *) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; esac if test "$ld_shlibs" = no; then runpath_var= hardcode_libdir_flag_spec= export_dynamic_flag_spec= whole_archive_flag_spec= fi else # PORTME fill in a description of your system's linker (not GNU ld) case $host_os in aix3*) allow_undefined_flag=unsupported always_export_symbols=yes archive_expsym_cmds='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. hardcode_minus_L=yes if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. hardcode_direct=unsupported fi ;; aix[4-9]*) if test "$host_cpu" = ia64; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag="" else # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to AIX nm, but means don't demangle with GNU nm # Also, AIX nm treats weak defined symbols like other global # defined symbols, whereas GNU nm marks them as "W". if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' else export_symbols_cmds='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' fi aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # need to do runtime linking. case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) for ld_flag in $LDFLAGS; do if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then aix_use_runtimelinking=yes break fi done ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. archive_cmds='' hardcode_direct=yes hardcode_direct_absolute=yes hardcode_libdir_separator=':' link_all_deplibs=yes file_list_spec='${wl}-f,' if test "$GCC" = yes; then case $host_os in aix4.[012]|aix4.[012].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`${CC} -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 hardcode_direct=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking hardcode_minus_L=yes hardcode_libdir_flag_spec='-L$libdir' hardcode_libdir_separator= fi ;; esac shared_flag='-shared' if test "$aix_use_runtimelinking" = yes; then shared_flag="$shared_flag "'${wl}-G' fi link_all_deplibs=no else # not using gcc if test "$host_cpu" = ia64; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test "$aix_use_runtimelinking" = yes; then shared_flag='${wl}-G' else shared_flag='${wl}-bM:SRE' fi fi fi export_dynamic_flag_spec='${wl}-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to export. always_export_symbols=yes if test "$aix_use_runtimelinking" = yes; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. allow_undefined_flag='-berok' # Determine the default libpath from the value encoded in an # empty executable. if test "${lt_cv_aix_libpath+set}" = set; then aix_libpath=$lt_cv_aix_libpath else if ${lt_cv_aix_libpath_+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath_=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_="/usr/lib:/lib" fi fi aix_libpath=$lt_cv_aix_libpath_ fi hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" archive_expsym_cmds='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then func_echo_all "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" else if test "$host_cpu" = ia64; then hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib' allow_undefined_flag="-z nodefs" archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. if test "${lt_cv_aix_libpath+set}" = set; then aix_libpath=$lt_cv_aix_libpath else if ${lt_cv_aix_libpath_+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath_=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_="/usr/lib:/lib" fi fi aix_libpath=$lt_cv_aix_libpath_ fi hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. no_undefined_flag=' ${wl}-bernotok' allow_undefined_flag=' ${wl}-berok' if test "$with_gnu_ld" = yes; then # We only use this code for GNU lds that support --whole-archive. whole_archive_flag_spec='${wl}--whole-archive$convenience ${wl}--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives whole_archive_flag_spec='$convenience' fi archive_cmds_need_lc=yes # This is similar to how AIX traditionally builds its shared libraries. archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' fi fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds='' ;; m68k) archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; bsdi[45]*) export_dynamic_flag_spec=-rdynamic ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. case $cc_basename in cl*) # Native MSVC hardcode_libdir_flag_spec=' ' allow_undefined_flag=unsupported always_export_symbols=yes file_list_spec='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=".dll" # FIXME: Setting linknames here is a bad hack. archive_cmds='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-dll~linknames=' archive_expsym_cmds='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then sed -n -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' -e '1\\\!p' < $export_symbols > $output_objdir/$soname.exp; else sed -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, )='true' enable_shared_with_static_runtimes=yes exclude_expsyms='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1,DATA/'\'' | $SED -e '\''/^[AITW][ ]/s/.*[ ]//'\'' | sort | uniq > $export_symbols' # Don't use ranlib old_postinstall_cmds='chmod 644 $oldlib' postlink_cmds='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile="$lt_outputfile.exe" lt_tool_outputfile="$lt_tool_outputfile.exe" ;; esac~ if test "$MANIFEST_TOOL" != ":" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # Assume MSVC wrapper hardcode_libdir_flag_spec=' ' allow_undefined_flag=unsupported # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=".dll" # FIXME: Setting linknames here is a bad hack. archive_cmds='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' # The linker will automatically build a .lib file if we build a DLL. old_archive_from_new_cmds='true' # FIXME: Should let the user specify the lib program. old_archive_cmds='lib -OUT:$oldlib$oldobjs$old_deplibs' enable_shared_with_static_runtimes=yes ;; esac ;; darwin* | rhapsody*) archive_cmds_need_lc=no hardcode_direct=no hardcode_automatic=yes hardcode_shlibpath_var=unsupported if test "$lt_cv_ld_force_load" = "yes"; then whole_archive_flag_spec='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience ${wl}-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' else whole_archive_flag_spec='' fi link_all_deplibs=yes allow_undefined_flag="$_lt_dar_allow_undefined" case $cc_basename in ifort*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test "$_lt_dar_can_shared" = "yes"; then output_verbose_link_cmd=func_echo_all archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}" module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" archive_expsym_cmds="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" module_expsym_cmds="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" else ld_shlibs=no fi ;; dgux*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec='-L$libdir' hardcode_shlibpath_var=no ;; # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor # support. Future versions do this automatically, but an explicit c++rt0.o # does not break anything, and helps significantly (at the cost of a little # extra space). freebsd2.2*) archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; # Unfortunately, older versions of FreeBSD 2 do not have this feature. freebsd2.*) archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes hardcode_minus_L=yes hardcode_shlibpath_var=no ;; # FreeBSD 3 and greater uses gcc -shared to do shared libraries. freebsd* | dragonfly*) archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; hpux9*) if test "$GCC" = yes; then archive_cmds='$RM $output_objdir/$soname~$CC -shared $pic_flag ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' else archive_cmds='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' fi hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' hardcode_libdir_separator=: hardcode_direct=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes export_dynamic_flag_spec='${wl}-E' ;; hpux10*) if test "$GCC" = yes && test "$with_gnu_ld" = no; then archive_cmds='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi if test "$with_gnu_ld" = no; then hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' hardcode_libdir_separator=: hardcode_direct=yes hardcode_direct_absolute=yes export_dynamic_flag_spec='${wl}-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes fi ;; hpux11*) if test "$GCC" = yes && test "$with_gnu_ld" = no; then case $host_cpu in hppa*64*) archive_cmds='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) archive_cmds='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) archive_cmds='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' ;; esac else case $host_cpu in hppa*64*) archive_cmds='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) archive_cmds='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) # Older versions of the 11.00 compiler do not understand -b yet # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does) { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $CC understands -b" >&5 $as_echo_n "checking if $CC understands -b... " >&6; } if ${lt_cv_prog_compiler__b+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler__b=no save_LDFLAGS="$LDFLAGS" LDFLAGS="$LDFLAGS -b" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler__b=yes fi else lt_cv_prog_compiler__b=yes fi fi $RM -r conftest* LDFLAGS="$save_LDFLAGS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler__b" >&5 $as_echo "$lt_cv_prog_compiler__b" >&6; } if test x"$lt_cv_prog_compiler__b" = xyes; then archive_cmds='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi ;; esac fi if test "$with_gnu_ld" = no; then hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' hardcode_libdir_separator=: case $host_cpu in hppa*64*|ia64*) hardcode_direct=no hardcode_shlibpath_var=no ;; *) hardcode_direct=yes hardcode_direct_absolute=yes export_dynamic_flag_spec='${wl}-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) if test "$GCC" = yes; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' # Try to use the -exported_symbol ld option, if it does not # work, assume that -exports_file does not work either and # implicitly export all symbols. # This should be the same for all languages, so no per-tag cache variable. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $host_os linker accepts -exported_symbol" >&5 $as_echo_n "checking whether the $host_os linker accepts -exported_symbol... " >&6; } if ${lt_cv_irix_exported_symbol+:} false; then : $as_echo_n "(cached) " >&6 else save_LDFLAGS="$LDFLAGS" LDFLAGS="$LDFLAGS -shared ${wl}-exported_symbol ${wl}foo ${wl}-update_registry ${wl}/dev/null" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int foo (void) { return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_cv_irix_exported_symbol=yes else lt_cv_irix_exported_symbol=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS="$save_LDFLAGS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_irix_exported_symbol" >&5 $as_echo "$lt_cv_irix_exported_symbol" >&6; } if test "$lt_cv_irix_exported_symbol" = yes; then archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations ${wl}-exports_file ${wl}$export_symbols -o $lib' fi else archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -exports_file $export_symbols -o $lib' fi archive_cmds_need_lc='no' hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator=: inherit_rpath=yes link_all_deplibs=yes ;; netbsd* | netbsdelf*-gnu) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out else archive_cmds='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF fi hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; newsos6) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator=: hardcode_shlibpath_var=no ;; *nto* | *qnx*) ;; openbsd*) if test -f /usr/libexec/ld.so; then hardcode_direct=yes hardcode_shlibpath_var=no hardcode_direct_absolute=yes if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols' hardcode_libdir_flag_spec='${wl}-rpath,$libdir' export_dynamic_flag_spec='${wl}-E' else case $host_os in openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*) archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec='-R$libdir' ;; *) archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' hardcode_libdir_flag_spec='${wl}-rpath,$libdir' ;; esac fi else ld_shlibs=no fi ;; os2*) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes allow_undefined_flag=unsupported archive_cmds='$ECHO "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~echo DATA >> $output_objdir/$libname.def~echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' old_archive_from_new_cmds='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' ;; osf3*) if test "$GCC" = yes; then allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*' archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' else allow_undefined_flag=' -expect_unresolved \*' archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' fi archive_cmds_need_lc='no' hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator=: ;; osf4* | osf5*) # as osf3* with the addition of -msym flag if test "$GCC" = yes; then allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*' archive_cmds='$CC -shared${allow_undefined_flag} $pic_flag $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' else allow_undefined_flag=' -expect_unresolved \*' archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' archive_expsym_cmds='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ $CC -shared${allow_undefined_flag} ${wl}-input ${wl}$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib~$RM $lib.exp' # Both c and cxx compiler support -rpath directly hardcode_libdir_flag_spec='-rpath $libdir' fi archive_cmds_need_lc='no' hardcode_libdir_separator=: ;; solaris*) no_undefined_flag=' -z defs' if test "$GCC" = yes; then wlarc='${wl}' archive_cmds='$CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' else case `$CC -V 2>&1` in *"Compilers 5.0"*) wlarc='' archive_cmds='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' ;; *) wlarc='${wl}' archive_cmds='$CC -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' ;; esac fi hardcode_libdir_flag_spec='-R$libdir' hardcode_shlibpath_var=no case $host_os in solaris2.[0-5] | solaris2.[0-5].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands `-z linker_flag'. GCC discards it without `$wl', # but is careful enough not to reorder. # Supported since Solaris 2.6 (maybe 2.5.1?) if test "$GCC" = yes; then whole_archive_flag_spec='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' else whole_archive_flag_spec='-z allextract$convenience -z defaultextract' fi ;; esac link_all_deplibs=yes ;; sunos4*) if test "x$host_vendor" = xsequent; then # Use $CC to link under sequent, because it throws in some extra .o # files that make .init and .fini sections work. archive_cmds='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' fi hardcode_libdir_flag_spec='-L$libdir' hardcode_direct=yes hardcode_minus_L=yes hardcode_shlibpath_var=no ;; sysv4) case $host_vendor in sni) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes # is this really true??? ;; siemens) ## LD is ld it makes a PLAMLIB ## CC just makes a GrossModule. archive_cmds='$LD -G -o $lib $libobjs $deplibs $linker_flags' reload_cmds='$CC -r -o $output$reload_objs' hardcode_direct=no ;; motorola) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=no #Motorola manual says yes, but my tests say they lie ;; esac runpath_var='LD_RUN_PATH' hardcode_shlibpath_var=no ;; sysv4.3*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_shlibpath_var=no export_dynamic_flag_spec='-Bexport' ;; sysv4*MP*) if test -d /usr/nec; then archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_shlibpath_var=no runpath_var=LD_RUN_PATH hardcode_runpath_var=yes ld_shlibs=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) no_undefined_flag='${wl}-z,text' archive_cmds_need_lc=no hardcode_shlibpath_var=no runpath_var='LD_RUN_PATH' if test "$GCC" = yes; then archive_cmds='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We can NOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. no_undefined_flag='${wl}-z,text' allow_undefined_flag='${wl}-z,nodefs' archive_cmds_need_lc=no hardcode_shlibpath_var=no hardcode_libdir_flag_spec='${wl}-R,$libdir' hardcode_libdir_separator=':' link_all_deplibs=yes export_dynamic_flag_spec='${wl}-Bexport' runpath_var='LD_RUN_PATH' if test "$GCC" = yes; then archive_cmds='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; uts4*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec='-L$libdir' hardcode_shlibpath_var=no ;; *) ld_shlibs=no ;; esac if test x$host_vendor = xsni; then case $host in sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) export_dynamic_flag_spec='${wl}-Blargedynsym' ;; esac fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs" >&5 $as_echo "$ld_shlibs" >&6; } test "$ld_shlibs" = no && can_build_shared=no with_gnu_ld=$with_gnu_ld # # Do we need to explicitly link libc? # case "x$archive_cmds_need_lc" in x|xyes) # Assume -lc should be added archive_cmds_need_lc=yes if test "$enable_shared" = yes && test "$GCC" = yes; then case $archive_cmds in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether -lc should be explicitly linked in" >&5 $as_echo_n "checking whether -lc should be explicitly linked in... " >&6; } if ${lt_cv_archive_cmds_need_lc+:} false; then : $as_echo_n "(cached) " >&6 else $RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$lt_prog_compiler_wl pic_flag=$lt_prog_compiler_pic compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$allow_undefined_flag allow_undefined_flag= if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\""; } >&5 (eval $archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } then lt_cv_archive_cmds_need_lc=no else lt_cv_archive_cmds_need_lc=yes fi allow_undefined_flag=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_archive_cmds_need_lc" >&5 $as_echo "$lt_cv_archive_cmds_need_lc" >&6; } archive_cmds_need_lc=$lt_cv_archive_cmds_need_lc ;; esac fi ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking dynamic linker characteristics" >&5 $as_echo_n "checking dynamic linker characteristics... " >&6; } if test "$GCC" = yes; then case $host_os in darwin*) lt_awk_arg="/^libraries:/,/LR/" ;; *) lt_awk_arg="/^libraries:/" ;; esac case $host_os in mingw* | cegcc*) lt_sed_strip_eq="s,=\([A-Za-z]:\),\1,g" ;; *) lt_sed_strip_eq="s,=/,/,g" ;; esac lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq` case $lt_search_path_spec in *\;*) # if the path contains ";" then we assume it to be the separator # otherwise default to the standard path separator (i.e. ":") - it is # assumed that no part of a normal pathname contains ";" but that should # okay in the real world where ";" in dirpaths is itself problematic. lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED 's/;/ /g'` ;; *) lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED "s/$PATH_SEPARATOR/ /g"` ;; esac # Ok, now we have the path, separated by spaces, we can step through it # and add multilib dir if necessary. lt_tmp_lt_search_path_spec= lt_multi_os_dir=`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` for lt_sys_path in $lt_search_path_spec; do if test -d "$lt_sys_path/$lt_multi_os_dir"; then lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path/$lt_multi_os_dir" else test -d "$lt_sys_path" && \ lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" fi done lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk ' BEGIN {RS=" "; FS="/|\n";} { lt_foo=""; lt_count=0; for (lt_i = NF; lt_i > 0; lt_i--) { if ($lt_i != "" && $lt_i != ".") { if ($lt_i == "..") { lt_count++; } else { if (lt_count == 0) { lt_foo="/" $lt_i lt_foo; } else { lt_count--; } } } } if (lt_foo != "") { lt_freq[lt_foo]++; } if (lt_freq[lt_foo] == 1) { print lt_foo; } }'` # AWK program above erroneously prepends '/' to C:/dos/paths # for these hosts. case $host_os in mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\ $SED 's,/\([A-Za-z]:\),\1,g'` ;; esac sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP` else sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" fi library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=".so" postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='${libname}${release}${shared_ext}$major' ;; aix[4-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test "$host_cpu" = ia64; then # AIX 5 supports IA64 library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line `#! .'. This would cause the generated library to # depend on `.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[01] | aix4.[01].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | ${CC} -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # AIX (on Power*) has no versioning support, so currently we can not hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. if test "$aix_use_runtimelinking" = yes; then # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' else # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='${libname}${release}.a $libname.a' soname_spec='${libname}${release}${shared_ext}$major' fi shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='${libname}${shared_ext}' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[45]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=".dll" need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \${file}`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api" ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl*) # Native MSVC libname_spec='$name' soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' library_names_spec='${libname}.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([a-zA-Z]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec="$LIB" if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \${file}`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC wrapper library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext' soname_spec='${libname}${release}${major}$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib" sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[23].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[01]* | freebsdelf3.[01]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[2-9]* | freebsdelf3.[2-9]* | \ freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=yes sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' if test "X$HPUX_IA64_MODE" = X32; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" fi sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[3-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test "$lt_cv_prog_gnu_ld" = yes; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='${libname}${release}${shared_ext}$major' library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH if ${lt_cv_shlibpath_overrides_runpath+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$lt_prog_compiler_wl\"; \ LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec\"" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : if ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null; then : lt_cv_shlibpath_overrides_runpath=yes fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS libdir=$save_libdir fi shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Append ld.so.conf contents to the search path if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsdelf*-gnu) version_type=linux need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='NetBSD ld.elf_so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd*) version_type=sunos sys_lib_dlsearch_path_spec="/usr/lib" need_lib_prefix=no # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. case $host_os in openbsd3.3 | openbsd3.3.*) need_version=yes ;; *) need_version=no ;; esac library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then case $host_os in openbsd2.[89] | openbsd2.[89].*) shlibpath_overrides_runpath=no ;; *) shlibpath_overrides_runpath=yes ;; esac else shlibpath_overrides_runpath=yes fi ;; os2*) libname_spec='$name' shrext_cmds=".dll" need_lib_prefix=no library_names_spec='$libname${shared_ext} $libname.a' dynamic_linker='OS/2 ld.exe' shlibpath_var=LIBPATH ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='${libname}${release}${shared_ext}$major' library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test "$with_gnu_ld" = yes; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec ;then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' soname_spec='$libname${shared_ext}.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=freebsd-elf need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test "$with_gnu_ld" = yes; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5 $as_echo "$dynamic_linker" >&6; } test "$dynamic_linker" = no && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test "$GCC" = yes; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec" fi if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec" fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to hardcode library paths into programs" >&5 $as_echo_n "checking how to hardcode library paths into programs... " >&6; } hardcode_action= if test -n "$hardcode_libdir_flag_spec" || test -n "$runpath_var" || test "X$hardcode_automatic" = "Xyes" ; then # We can hardcode non-existent directories. if test "$hardcode_direct" != no && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test "$_LT_TAGVAR(hardcode_shlibpath_var, )" != no && test "$hardcode_minus_L" != no; then # Linking always hardcodes the temporary library directory. hardcode_action=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. hardcode_action=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. hardcode_action=unsupported fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hardcode_action" >&5 $as_echo "$hardcode_action" >&6; } if test "$hardcode_action" = relink || test "$inherit_rpath" = yes; then # Fast installation is not supported enable_fast_install=no elif test "$shlibpath_overrides_runpath" = yes || test "$enable_shared" = no; then # Fast installation is not necessary enable_fast_install=needless fi if test "x$enable_dlopen" != xyes; then enable_dlopen=unknown enable_dlopen_self=unknown enable_dlopen_self_static=unknown else lt_cv_dlopen=no lt_cv_dlopen_libs= case $host_os in beos*) lt_cv_dlopen="load_add_on" lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ;; mingw* | pw32* | cegcc*) lt_cv_dlopen="LoadLibrary" lt_cv_dlopen_libs= ;; cygwin*) lt_cv_dlopen="dlopen" lt_cv_dlopen_libs= ;; darwin*) # if libdl is installed we need to link against it { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 $as_echo_n "checking for dlopen in -ldl... " >&6; } if ${ac_cv_lib_dl_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dl_dlopen=yes else ac_cv_lib_dl_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 $as_echo "$ac_cv_lib_dl_dlopen" >&6; } if test "x$ac_cv_lib_dl_dlopen" = xyes; then : lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" else lt_cv_dlopen="dyld" lt_cv_dlopen_libs= lt_cv_dlopen_self=yes fi ;; *) ac_fn_c_check_func "$LINENO" "shl_load" "ac_cv_func_shl_load" if test "x$ac_cv_func_shl_load" = xyes; then : lt_cv_dlopen="shl_load" else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for shl_load in -ldld" >&5 $as_echo_n "checking for shl_load in -ldld... " >&6; } if ${ac_cv_lib_dld_shl_load+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char shl_load (); int main () { return shl_load (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dld_shl_load=yes else ac_cv_lib_dld_shl_load=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_shl_load" >&5 $as_echo "$ac_cv_lib_dld_shl_load" >&6; } if test "x$ac_cv_lib_dld_shl_load" = xyes; then : lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-ldld" else ac_fn_c_check_func "$LINENO" "dlopen" "ac_cv_func_dlopen" if test "x$ac_cv_func_dlopen" = xyes; then : lt_cv_dlopen="dlopen" else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 $as_echo_n "checking for dlopen in -ldl... " >&6; } if ${ac_cv_lib_dl_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dl_dlopen=yes else ac_cv_lib_dl_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 $as_echo "$ac_cv_lib_dl_dlopen" >&6; } if test "x$ac_cv_lib_dl_dlopen" = xyes; then : lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -lsvld" >&5 $as_echo_n "checking for dlopen in -lsvld... " >&6; } if ${ac_cv_lib_svld_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lsvld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_svld_dlopen=yes else ac_cv_lib_svld_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_svld_dlopen" >&5 $as_echo "$ac_cv_lib_svld_dlopen" >&6; } if test "x$ac_cv_lib_svld_dlopen" = xyes; then : lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld" else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dld_link in -ldld" >&5 $as_echo_n "checking for dld_link in -ldld... " >&6; } if ${ac_cv_lib_dld_dld_link+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dld_link (); int main () { return dld_link (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dld_dld_link=yes else ac_cv_lib_dld_dld_link=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_dld_link" >&5 $as_echo "$ac_cv_lib_dld_dld_link" >&6; } if test "x$ac_cv_lib_dld_dld_link" = xyes; then : lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-ldld" fi fi fi fi fi fi ;; esac if test "x$lt_cv_dlopen" != xno; then enable_dlopen=yes else enable_dlopen=no fi case $lt_cv_dlopen in dlopen) save_CPPFLAGS="$CPPFLAGS" test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" save_LDFLAGS="$LDFLAGS" wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" save_LIBS="$LIBS" LIBS="$lt_cv_dlopen_libs $LIBS" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a program can dlopen itself" >&5 $as_echo_n "checking whether a program can dlopen itself... " >&6; } if ${lt_cv_dlopen_self+:} false; then : $as_echo_n "(cached) " >&6 else if test "$cross_compiling" = yes; then : lt_cv_dlopen_self=cross else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF #line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisbility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined(__GNUC__) && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; } _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s conftest${ac_exeext} 2>/dev/null; then (./conftest; exit; ) >&5 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) lt_cv_dlopen_self=yes ;; x$lt_dlneed_uscore) lt_cv_dlopen_self=yes ;; x$lt_dlunknown|x*) lt_cv_dlopen_self=no ;; esac else : # compilation failed lt_cv_dlopen_self=no fi fi rm -fr conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self" >&5 $as_echo "$lt_cv_dlopen_self" >&6; } if test "x$lt_cv_dlopen_self" = xyes; then wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a statically linked program can dlopen itself" >&5 $as_echo_n "checking whether a statically linked program can dlopen itself... " >&6; } if ${lt_cv_dlopen_self_static+:} false; then : $as_echo_n "(cached) " >&6 else if test "$cross_compiling" = yes; then : lt_cv_dlopen_self_static=cross else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF #line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisbility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined(__GNUC__) && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; } _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s conftest${ac_exeext} 2>/dev/null; then (./conftest; exit; ) >&5 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) lt_cv_dlopen_self_static=yes ;; x$lt_dlneed_uscore) lt_cv_dlopen_self_static=yes ;; x$lt_dlunknown|x*) lt_cv_dlopen_self_static=no ;; esac else : # compilation failed lt_cv_dlopen_self_static=no fi fi rm -fr conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self_static" >&5 $as_echo "$lt_cv_dlopen_self_static" >&6; } fi CPPFLAGS="$save_CPPFLAGS" LDFLAGS="$save_LDFLAGS" LIBS="$save_LIBS" ;; esac case $lt_cv_dlopen_self in yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; *) enable_dlopen_self=unknown ;; esac case $lt_cv_dlopen_self_static in yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; *) enable_dlopen_self_static=unknown ;; esac fi striplib= old_striplib= { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether stripping libraries is possible" >&5 $as_echo_n "checking whether stripping libraries is possible... " >&6; } if test -n "$STRIP" && $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" test -z "$striplib" && striplib="$STRIP --strip-unneeded" { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else # FIXME - insert some real tests, host_os isn't really good enough case $host_os in darwin*) if test -n "$STRIP" ; then striplib="$STRIP -x" old_striplib="$STRIP -S" { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi ;; *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } ;; esac fi # Report which library types will actually be built { $as_echo "$as_me:${as_lineno-$LINENO}: checking if libtool supports shared libraries" >&5 $as_echo_n "checking if libtool supports shared libraries... " >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: result: $can_build_shared" >&5 $as_echo "$can_build_shared" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build shared libraries" >&5 $as_echo_n "checking whether to build shared libraries... " >&6; } test "$can_build_shared" = "no" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test "$enable_shared" = yes && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[4-9]*) if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then test "$enable_shared" = yes && enable_static=no fi ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_shared" >&5 $as_echo "$enable_shared" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build static libraries" >&5 $as_echo_n "checking whether to build static libraries... " >&6; } # Make sure either enable_shared or enable_static is yes. test "$enable_shared" = yes || enable_static=yes { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_static" >&5 $as_echo "$enable_static" >&6; } fi ac_ext=cpp ac_cpp='$CXXCPP $CPPFLAGS' ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_cxx_compiler_gnu CC="$lt_save_CC" if test -n "$CXX" && ( test "X$CXX" != "Xno" && ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) || (test "X$CXX" != "Xg++"))) ; then ac_ext=cpp ac_cpp='$CXXCPP $CPPFLAGS' ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_cxx_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to run the C++ preprocessor" >&5 $as_echo_n "checking how to run the C++ preprocessor... " >&6; } if test -z "$CXXCPP"; then if ${ac_cv_prog_CXXCPP+:} false; then : $as_echo_n "(cached) " >&6 else # Double quotes because CXXCPP needs to be expanded for CXXCPP in "$CXX -E" "/lib/cpp" do ac_preproc_ok=false for ac_cxx_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # Prefer to if __STDC__ is defined, since # exists even on freestanding compilers. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __STDC__ # include #else # include #endif Syntax error _ACEOF if ac_fn_cxx_try_cpp "$LINENO"; then : else # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_cxx_try_cpp "$LINENO"; then : # Broken: success on invalid input. continue else # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok; then : break fi done ac_cv_prog_CXXCPP=$CXXCPP fi CXXCPP=$ac_cv_prog_CXXCPP else ac_cv_prog_CXXCPP=$CXXCPP fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CXXCPP" >&5 $as_echo "$CXXCPP" >&6; } ac_preproc_ok=false for ac_cxx_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # Prefer to if __STDC__ is defined, since # exists even on freestanding compilers. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __STDC__ # include #else # include #endif Syntax error _ACEOF if ac_fn_cxx_try_cpp "$LINENO"; then : else # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_cxx_try_cpp "$LINENO"; then : # Broken: success on invalid input. continue else # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok; then : else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C++ preprocessor \"$CXXCPP\" fails sanity check See \`config.log' for more details" "$LINENO" 5; } fi ac_ext=cpp ac_cpp='$CXXCPP $CPPFLAGS' ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_cxx_compiler_gnu else _lt_caught_CXX_error=yes fi ac_ext=cpp ac_cpp='$CXXCPP $CPPFLAGS' ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_cxx_compiler_gnu archive_cmds_need_lc_CXX=no allow_undefined_flag_CXX= always_export_symbols_CXX=no archive_expsym_cmds_CXX= compiler_needs_object_CXX=no export_dynamic_flag_spec_CXX= hardcode_direct_CXX=no hardcode_direct_absolute_CXX=no hardcode_libdir_flag_spec_CXX= hardcode_libdir_separator_CXX= hardcode_minus_L_CXX=no hardcode_shlibpath_var_CXX=unsupported hardcode_automatic_CXX=no inherit_rpath_CXX=no module_cmds_CXX= module_expsym_cmds_CXX= link_all_deplibs_CXX=unknown old_archive_cmds_CXX=$old_archive_cmds reload_flag_CXX=$reload_flag reload_cmds_CXX=$reload_cmds no_undefined_flag_CXX= whole_archive_flag_spec_CXX= enable_shared_with_static_runtimes_CXX=no # Source file extension for C++ test sources. ac_ext=cpp # Object file extension for compiled C++ test sources. objext=o objext_CXX=$objext # No sense in running all these tests if we already determined that # the CXX compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test "$_lt_caught_CXX_error" != yes; then # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(int, char *[]) { return(0); }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # save warnings/boilerplate of simple test code ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_LD=$LD lt_save_GCC=$GCC GCC=$GXX lt_save_with_gnu_ld=$with_gnu_ld lt_save_path_LD=$lt_cv_path_LD if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx else $as_unset lt_cv_prog_gnu_ld fi if test -n "${lt_cv_path_LDCXX+set}"; then lt_cv_path_LD=$lt_cv_path_LDCXX else $as_unset lt_cv_path_LD fi test -z "${LDCXX+set}" || LD=$LDCXX CC=${CXX-"c++"} CFLAGS=$CXXFLAGS compiler=$CC compiler_CXX=$CC for cc_temp in $compiler""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done cc_basename=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` if test -n "$compiler"; then # We don't want -fno-exception when compiling C++ code, so set the # no_builtin_flag separately if test "$GXX" = yes; then lt_prog_compiler_no_builtin_flag_CXX=' -fno-builtin' else lt_prog_compiler_no_builtin_flag_CXX= fi if test "$GXX" = yes; then # Set up default GNU C++ configuration # Check whether --with-gnu-ld was given. if test "${with_gnu_ld+set}" = set; then : withval=$with_gnu_ld; test "$withval" = no || with_gnu_ld=yes else with_gnu_ld=no fi ac_prog=ld if test "$GCC" = yes; then # Check if gcc -print-prog-name=ld gives a path. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5 $as_echo_n "checking for ld used by $CC... " >&6; } case $host in *-*-mingw*) # gcc leaves a trailing carriage return which upsets mingw ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; esac case $ac_prog in # Accept absolute paths. [\\/]* | ?:[\\/]*) re_direlt='/[^/][^/]*/\.\./' # Canonicalize the pathname of ld ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` done test -z "$LD" && LD="$ac_prog" ;; "") # If it fails, then pretend we aren't using GCC. ac_prog=ld ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac elif test "$with_gnu_ld" = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5 $as_echo_n "checking for GNU ld... " >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for non-GNU ld" >&5 $as_echo_n "checking for non-GNU ld... " >&6; } fi if ${lt_cv_path_LD+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$LD"; then lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS="$lt_save_ifs" test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then lt_cv_path_LD="$ac_dir/$ac_prog" # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$lt_cv_path_LD" -v 2>&1 &5 $as_echo "$LD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -z "$LD" && as_fn_error $? "no acceptable ld found in \$PATH" "$LINENO" 5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking if the linker ($LD) is GNU ld" >&5 $as_echo_n "checking if the linker ($LD) is GNU ld... " >&6; } if ${lt_cv_prog_gnu_ld+:} false; then : $as_echo_n "(cached) " >&6 else # I'd rather use --version here, but apparently some GNU lds only accept -v. case `$LD -v 2>&1 &5 $as_echo "$lt_cv_prog_gnu_ld" >&6; } with_gnu_ld=$lt_cv_prog_gnu_ld # Check if GNU C++ uses GNU ld as the underlying linker, since the # archiving commands below assume that GNU ld is being used. if test "$with_gnu_ld" = yes; then archive_cmds_CXX='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds_CXX='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' export_dynamic_flag_spec_CXX='${wl}--export-dynamic' # If archive_cmds runs LD, not CC, wlarc should be empty # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to # investigate it a little bit more. (MM) wlarc='${wl}' # ancient GNU ld didn't support --whole-archive et. al. if eval "`$CC -print-prog-name=ld` --help 2>&1" | $GREP 'no-whole-archive' > /dev/null; then whole_archive_flag_spec_CXX="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' else whole_archive_flag_spec_CXX= fi else with_gnu_ld=no wlarc= # A generic and very simple default shared library creation # command for GNU C++ for the case where it uses the native # linker, instead of GNU ld. If possible, this setting should # overridden to take advantage of the native linker features on # the platform it is being used on. archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' fi # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else GXX=no with_gnu_ld=no wlarc= fi # PORTME: fill in a description of your system's C++ link characteristics { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 $as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } ld_shlibs_CXX=yes case $host_os in aix3*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; aix[4-9]*) if test "$host_cpu" = ia64; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag="" else aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # need to do runtime linking. case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) for ld_flag in $LDFLAGS; do case $ld_flag in *-brtl*) aix_use_runtimelinking=yes break ;; esac done ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. archive_cmds_CXX='' hardcode_direct_CXX=yes hardcode_direct_absolute_CXX=yes hardcode_libdir_separator_CXX=':' link_all_deplibs_CXX=yes file_list_spec_CXX='${wl}-f,' if test "$GXX" = yes; then case $host_os in aix4.[012]|aix4.[012].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`${CC} -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 hardcode_direct_CXX=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking hardcode_minus_L_CXX=yes hardcode_libdir_flag_spec_CXX='-L$libdir' hardcode_libdir_separator_CXX= fi esac shared_flag='-shared' if test "$aix_use_runtimelinking" = yes; then shared_flag="$shared_flag "'${wl}-G' fi else # not using gcc if test "$host_cpu" = ia64; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test "$aix_use_runtimelinking" = yes; then shared_flag='${wl}-G' else shared_flag='${wl}-bM:SRE' fi fi fi export_dynamic_flag_spec_CXX='${wl}-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to # export. always_export_symbols_CXX=yes if test "$aix_use_runtimelinking" = yes; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. allow_undefined_flag_CXX='-berok' # Determine the default libpath from the value encoded in an empty # executable. if test "${lt_cv_aix_libpath+set}" = set; then aix_libpath=$lt_cv_aix_libpath else if ${lt_cv_aix_libpath__CXX+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath__CXX=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath__CXX"; then lt_cv_aix_libpath__CXX=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath__CXX"; then lt_cv_aix_libpath__CXX="/usr/lib:/lib" fi fi aix_libpath=$lt_cv_aix_libpath__CXX fi hardcode_libdir_flag_spec_CXX='${wl}-blibpath:$libdir:'"$aix_libpath" archive_expsym_cmds_CXX='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then func_echo_all "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" else if test "$host_cpu" = ia64; then hardcode_libdir_flag_spec_CXX='${wl}-R $libdir:/usr/lib:/lib' allow_undefined_flag_CXX="-z nodefs" archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. if test "${lt_cv_aix_libpath+set}" = set; then aix_libpath=$lt_cv_aix_libpath else if ${lt_cv_aix_libpath__CXX+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath__CXX=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath__CXX"; then lt_cv_aix_libpath__CXX=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath__CXX"; then lt_cv_aix_libpath__CXX="/usr/lib:/lib" fi fi aix_libpath=$lt_cv_aix_libpath__CXX fi hardcode_libdir_flag_spec_CXX='${wl}-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. no_undefined_flag_CXX=' ${wl}-bernotok' allow_undefined_flag_CXX=' ${wl}-berok' if test "$with_gnu_ld" = yes; then # We only use this code for GNU lds that support --whole-archive. whole_archive_flag_spec_CXX='${wl}--whole-archive$convenience ${wl}--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives whole_archive_flag_spec_CXX='$convenience' fi archive_cmds_need_lc_CXX=yes # This is similar to how AIX traditionally builds its shared # libraries. archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' fi fi ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then allow_undefined_flag_CXX=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME archive_cmds_CXX='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' else ld_shlibs_CXX=no fi ;; chorus*) case $cc_basename in *) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; esac ;; cygwin* | mingw* | pw32* | cegcc*) case $GXX,$cc_basename in ,cl* | no,cl*) # Native MSVC # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. hardcode_libdir_flag_spec_CXX=' ' allow_undefined_flag_CXX=unsupported always_export_symbols_CXX=yes file_list_spec_CXX='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=".dll" # FIXME: Setting linknames here is a bad hack. archive_cmds_CXX='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-dll~linknames=' archive_expsym_cmds_CXX='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then $SED -n -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' -e '1\\\!p' < $export_symbols > $output_objdir/$soname.exp; else $SED -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, CXX)='true' enable_shared_with_static_runtimes_CXX=yes # Don't use ranlib old_postinstall_cmds_CXX='chmod 644 $oldlib' postlink_cmds_CXX='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile="$lt_outputfile.exe" lt_tool_outputfile="$lt_tool_outputfile.exe" ;; esac~ func_to_tool_file "$lt_outputfile"~ if test "$MANIFEST_TOOL" != ":" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # g++ # _LT_TAGVAR(hardcode_libdir_flag_spec, CXX) is actually meaningless, # as there is no search path for DLLs. hardcode_libdir_flag_spec_CXX='-L$libdir' export_dynamic_flag_spec_CXX='${wl}--export-all-symbols' allow_undefined_flag_CXX=unsupported always_export_symbols_CXX=no enable_shared_with_static_runtimes_CXX=yes if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file (1st line # is EXPORTS), use it as is; otherwise, prepend... archive_expsym_cmds_CXX='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else ld_shlibs_CXX=no fi ;; esac ;; darwin* | rhapsody*) archive_cmds_need_lc_CXX=no hardcode_direct_CXX=no hardcode_automatic_CXX=yes hardcode_shlibpath_var_CXX=unsupported if test "$lt_cv_ld_force_load" = "yes"; then whole_archive_flag_spec_CXX='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience ${wl}-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' else whole_archive_flag_spec_CXX='' fi link_all_deplibs_CXX=yes allow_undefined_flag_CXX="$_lt_dar_allow_undefined" case $cc_basename in ifort*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test "$_lt_dar_can_shared" = "yes"; then output_verbose_link_cmd=func_echo_all archive_cmds_CXX="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}" module_cmds_CXX="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" archive_expsym_cmds_CXX="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" module_expsym_cmds_CXX="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" if test "$lt_cv_apple_cc_single_mod" != "yes"; then archive_cmds_CXX="\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dsymutil}" archive_expsym_cmds_CXX="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dar_export_syms}${_lt_dsymutil}" fi else ld_shlibs_CXX=no fi ;; dgux*) case $cc_basename in ec++*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; ghcx*) # Green Hills C++ Compiler # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; *) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; esac ;; freebsd2.*) # C++ shared libraries reported to be fairly broken before # switch to ELF ld_shlibs_CXX=no ;; freebsd-elf*) archive_cmds_need_lc_CXX=no ;; freebsd* | dragonfly*) # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF # conventions ld_shlibs_CXX=yes ;; haiku*) archive_cmds_CXX='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' link_all_deplibs_CXX=yes ;; hpux9*) hardcode_libdir_flag_spec_CXX='${wl}+b ${wl}$libdir' hardcode_libdir_separator_CXX=: export_dynamic_flag_spec_CXX='${wl}-E' hardcode_direct_CXX=yes hardcode_minus_L_CXX=yes # Not in the search PATH, # but as the default # location of the library. case $cc_basename in CC*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; aCC*) archive_cmds_CXX='$RM $output_objdir/$soname~$CC -b ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test "$GXX" = yes; then archive_cmds_CXX='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' else # FIXME: insert proper C++ library support ld_shlibs_CXX=no fi ;; esac ;; hpux10*|hpux11*) if test $with_gnu_ld = no; then hardcode_libdir_flag_spec_CXX='${wl}+b ${wl}$libdir' hardcode_libdir_separator_CXX=: case $host_cpu in hppa*64*|ia64*) ;; *) export_dynamic_flag_spec_CXX='${wl}-E' ;; esac fi case $host_cpu in hppa*64*|ia64*) hardcode_direct_CXX=no hardcode_shlibpath_var_CXX=no ;; *) hardcode_direct_CXX=yes hardcode_direct_absolute_CXX=yes hardcode_minus_L_CXX=yes # Not in the search PATH, # but as the default # location of the library. ;; esac case $cc_basename in CC*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; aCC*) case $host_cpu in hppa*64*) archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test "$GXX" = yes; then if test $with_gnu_ld = no; then case $host_cpu in hppa*64*) archive_cmds_CXX='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) archive_cmds_CXX='$CC -shared -nostdlib $pic_flag ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) archive_cmds_CXX='$CC -shared -nostdlib $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac fi else # FIXME: insert proper C++ library support ld_shlibs_CXX=no fi ;; esac ;; interix[3-9]*) hardcode_direct_CXX=no hardcode_shlibpath_var_CXX=no hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' export_dynamic_flag_spec_CXX='${wl}-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. archive_cmds_CXX='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' archive_expsym_cmds_CXX='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; irix5* | irix6*) case $cc_basename in CC*) # SGI C++ archive_cmds_CXX='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' # Archives containing C++ object files must be created using # "CC -ar", where "CC" is the IRIX C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. old_archive_cmds_CXX='$CC -ar -WR,-u -o $oldlib $oldobjs' ;; *) if test "$GXX" = yes; then if test "$with_gnu_ld" = no; then archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' else archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` -o $lib' fi fi link_all_deplibs_CXX=yes ;; esac hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator_CXX=: inherit_rpath_CXX=yes ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' archive_expsym_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib ${wl}-retain-symbols-file,$export_symbols; mv \$templib $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' export_dynamic_flag_spec_CXX='${wl}--export-dynamic' # Archives containing C++ object files must be created using # "CC -Bstatic", where "CC" is the KAI C++ compiler. old_archive_cmds_CXX='$CC -Bstatic -o $oldlib $oldobjs' ;; icpc* | ecpc* ) # Intel C++ with_gnu_ld=yes # version 8.0 and above of icpc choke on multiply defined symbols # if we add $predep_objects and $postdep_objects, however 7.1 and # earlier do not add the objects themselves. case `$CC -V 2>&1` in *"Version 7."*) archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' ;; *) # Version 8.0 or newer tmp_idyn= case $host_cpu in ia64*) tmp_idyn=' -i_dynamic';; esac archive_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' ;; esac archive_cmds_need_lc_CXX=no hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' export_dynamic_flag_spec_CXX='${wl}--export-dynamic' whole_archive_flag_spec_CXX='${wl}--whole-archive$convenience ${wl}--no-whole-archive' ;; pgCC* | pgcpp*) # Portland Group C++ compiler case `$CC -V` in *pgCC\ [1-5].* | *pgcpp\ [1-5].*) prelink_cmds_CXX='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~ compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"' old_archive_cmds_CXX='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~ $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~ $RANLIB $oldlib' archive_cmds_CXX='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib' archive_expsym_cmds_CXX='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib' ;; *) # Version 6 and above use weak symbols archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib' archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib' ;; esac hardcode_libdir_flag_spec_CXX='${wl}--rpath ${wl}$libdir' export_dynamic_flag_spec_CXX='${wl}--export-dynamic' whole_archive_flag_spec_CXX='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' ;; cxx*) # Compaq C++ archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib ${wl}-retain-symbols-file $wl$export_symbols' runpath_var=LD_RUN_PATH hardcode_libdir_flag_spec_CXX='-rpath $libdir' hardcode_libdir_separator_CXX=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed' ;; xl* | mpixl* | bgxl*) # IBM XL 8.0 on PPC, with GNU ld hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' export_dynamic_flag_spec_CXX='${wl}--export-dynamic' archive_cmds_CXX='$CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' if test "x$supports_anon_versioning" = xyes; then archive_expsym_cmds_CXX='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' fi ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 no_undefined_flag_CXX=' -zdefs' archive_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' archive_expsym_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file ${wl}$export_symbols' hardcode_libdir_flag_spec_CXX='-R$libdir' whole_archive_flag_spec_CXX='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' compiler_needs_object_CXX=yes # Not sure whether something based on # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 # would be better. output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. old_archive_cmds_CXX='$CC -xar -o $oldlib $oldobjs' ;; esac ;; esac ;; lynxos*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; m88k*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; mvs*) case $cc_basename in cxx*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; *) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds_CXX='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' wlarc= hardcode_libdir_flag_spec_CXX='-R$libdir' hardcode_direct_CXX=yes hardcode_shlibpath_var_CXX=no fi # Workaround some broken pre-1.5 toolchains output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' ;; *nto* | *qnx*) ld_shlibs_CXX=yes ;; openbsd2*) # C++ shared libraries are fairly broken ld_shlibs_CXX=no ;; openbsd*) if test -f /usr/libexec/ld.so; then hardcode_direct_CXX=yes hardcode_shlibpath_var_CXX=no hardcode_direct_absolute_CXX=yes archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file,$export_symbols -o $lib' export_dynamic_flag_spec_CXX='${wl}-E' whole_archive_flag_spec_CXX="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' fi output_verbose_link_cmd=func_echo_all else ld_shlibs_CXX=no fi ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' hardcode_libdir_separator_CXX=: # Archives containing C++ object files must be created using # the KAI C++ compiler. case $host in osf3*) old_archive_cmds_CXX='$CC -Bstatic -o $oldlib $oldobjs' ;; *) old_archive_cmds_CXX='$CC -o $oldlib $oldobjs' ;; esac ;; RCC*) # Rational C++ 2.4.1 # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; cxx*) case $host in osf3*) allow_undefined_flag_CXX=' ${wl}-expect_unresolved ${wl}\*' archive_cmds_CXX='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && func_echo_all "${wl}-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' ;; *) allow_undefined_flag_CXX=' -expect_unresolved \*' archive_cmds_CXX='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' archive_expsym_cmds_CXX='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ echo "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname ${wl}-input ${wl}$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib~ $RM $lib.exp' hardcode_libdir_flag_spec_CXX='-rpath $libdir' ;; esac hardcode_libdir_separator_CXX=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test "$GXX" = yes && test "$with_gnu_ld" = no; then allow_undefined_flag_CXX=' ${wl}-expect_unresolved ${wl}\*' case $host in osf3*) archive_cmds_CXX='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' ;; *) archive_cmds_CXX='$CC -shared $pic_flag -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' ;; esac hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator_CXX=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # FIXME: insert proper C++ library support ld_shlibs_CXX=no fi ;; esac ;; psos*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; lcc*) # Lucid # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; *) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; esac ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ archive_cmds_need_lc_CXX=yes no_undefined_flag_CXX=' -zdefs' archive_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G${allow_undefined_flag} ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' hardcode_libdir_flag_spec_CXX='-R$libdir' hardcode_shlibpath_var_CXX=no case $host_os in solaris2.[0-5] | solaris2.[0-5].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands `-z linker_flag'. # Supported since Solaris 2.6 (maybe 2.5.1?) whole_archive_flag_spec_CXX='-z allextract$convenience -z defaultextract' ;; esac link_all_deplibs_CXX=yes output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. old_archive_cmds_CXX='$CC -xar -o $oldlib $oldobjs' ;; gcx*) # Green Hills C++ Compiler archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' # The C++ compiler must be used to create the archive. old_archive_cmds_CXX='$CC $LDFLAGS -archive -o $oldlib $oldobjs' ;; *) # GNU C++ compiler with Solaris linker if test "$GXX" = yes && test "$with_gnu_ld" = no; then no_undefined_flag_CXX=' ${wl}-z ${wl}defs' if $CC --version | $GREP -v '^2\.7' > /dev/null; then archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # g++ 2.7 appears to require `-G' NOT `-shared' on this # platform. archive_cmds_CXX='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' fi hardcode_libdir_flag_spec_CXX='${wl}-R $wl$libdir' case $host_os in solaris2.[0-5] | solaris2.[0-5].*) ;; *) whole_archive_flag_spec_CXX='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' ;; esac fi ;; esac ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) no_undefined_flag_CXX='${wl}-z,text' archive_cmds_need_lc_CXX=no hardcode_shlibpath_var_CXX=no runpath_var='LD_RUN_PATH' case $cc_basename in CC*) archive_cmds_CXX='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_CXX='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; *) archive_cmds_CXX='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_CXX='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We can NOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. no_undefined_flag_CXX='${wl}-z,text' allow_undefined_flag_CXX='${wl}-z,nodefs' archive_cmds_need_lc_CXX=no hardcode_shlibpath_var_CXX=no hardcode_libdir_flag_spec_CXX='${wl}-R,$libdir' hardcode_libdir_separator_CXX=':' link_all_deplibs_CXX=yes export_dynamic_flag_spec_CXX='${wl}-Bexport' runpath_var='LD_RUN_PATH' case $cc_basename in CC*) archive_cmds_CXX='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_CXX='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' old_archive_cmds_CXX='$CC -Tprelink_objects $oldobjs~ '"$old_archive_cmds_CXX" reload_cmds_CXX='$CC -Tprelink_objects $reload_objs~ '"$reload_cmds_CXX" ;; *) archive_cmds_CXX='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_CXX='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; *) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; esac ;; vxworks*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; *) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs_CXX" >&5 $as_echo "$ld_shlibs_CXX" >&6; } test "$ld_shlibs_CXX" = no && can_build_shared=no GCC_CXX="$GXX" LD_CXX="$LD" ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... # Dependencies to place before and after the object being linked: predep_objects_CXX= postdep_objects_CXX= predeps_CXX= postdeps_CXX= compiler_lib_search_path_CXX= cat > conftest.$ac_ext <<_LT_EOF class Foo { public: Foo (void) { a = 0; } private: int a; }; _LT_EOF _lt_libdeps_save_CFLAGS=$CFLAGS case "$CC $CFLAGS " in #( *\ -flto*\ *) CFLAGS="$CFLAGS -fno-lto" ;; *\ -fwhopr*\ *) CFLAGS="$CFLAGS -fno-whopr" ;; *\ -fuse-linker-plugin*\ *) CFLAGS="$CFLAGS -fno-use-linker-plugin" ;; esac if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then # Parse the compiler output and extract the necessary # objects, libraries and library flags. # Sentinel used to keep track of whether or not we are before # the conftest object file. pre_test_object_deps_done=no for p in `eval "$output_verbose_link_cmd"`; do case ${prev}${p} in -L* | -R* | -l*) # Some compilers place space between "-{L,R}" and the path. # Remove the space. if test $p = "-L" || test $p = "-R"; then prev=$p continue fi # Expand the sysroot to ease extracting the directories later. if test -z "$prev"; then case $p in -L*) func_stripname_cnf '-L' '' "$p"; prev=-L; p=$func_stripname_result ;; -R*) func_stripname_cnf '-R' '' "$p"; prev=-R; p=$func_stripname_result ;; -l*) func_stripname_cnf '-l' '' "$p"; prev=-l; p=$func_stripname_result ;; esac fi case $p in =*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;; esac if test "$pre_test_object_deps_done" = no; then case ${prev} in -L | -R) # Internal compiler library paths should come after those # provided the user. The postdeps already come after the # user supplied libs so there is no need to process them. if test -z "$compiler_lib_search_path_CXX"; then compiler_lib_search_path_CXX="${prev}${p}" else compiler_lib_search_path_CXX="${compiler_lib_search_path_CXX} ${prev}${p}" fi ;; # The "-l" case would never come before the object being # linked, so don't bother handling this case. esac else if test -z "$postdeps_CXX"; then postdeps_CXX="${prev}${p}" else postdeps_CXX="${postdeps_CXX} ${prev}${p}" fi fi prev= ;; *.lto.$objext) ;; # Ignore GCC LTO objects *.$objext) # This assumes that the test object file only shows up # once in the compiler output. if test "$p" = "conftest.$objext"; then pre_test_object_deps_done=yes continue fi if test "$pre_test_object_deps_done" = no; then if test -z "$predep_objects_CXX"; then predep_objects_CXX="$p" else predep_objects_CXX="$predep_objects_CXX $p" fi else if test -z "$postdep_objects_CXX"; then postdep_objects_CXX="$p" else postdep_objects_CXX="$postdep_objects_CXX $p" fi fi ;; *) ;; # Ignore the rest. esac done # Clean up. rm -f a.out a.exe else echo "libtool.m4: error: problem compiling CXX test program" fi $RM -f confest.$objext CFLAGS=$_lt_libdeps_save_CFLAGS # PORTME: override above test on systems where it is broken case $host_os in interix[3-9]*) # Interix 3.5 installs completely hosed .la files for C++, so rather than # hack all around it, let's just trust "g++" to DTRT. predep_objects_CXX= postdep_objects_CXX= postdeps_CXX= ;; linux*) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 # The more standards-conforming stlport4 library is # incompatible with the Cstd library. Avoid specifying # it if it's in CXXFLAGS. Ignore libCrun as # -library=stlport4 depends on it. case " $CXX $CXXFLAGS " in *" -library=stlport4 "*) solaris_use_stlport4=yes ;; esac if test "$solaris_use_stlport4" != yes; then postdeps_CXX='-library=Cstd -library=Crun' fi ;; esac ;; solaris*) case $cc_basename in CC* | sunCC*) # The more standards-conforming stlport4 library is # incompatible with the Cstd library. Avoid specifying # it if it's in CXXFLAGS. Ignore libCrun as # -library=stlport4 depends on it. case " $CXX $CXXFLAGS " in *" -library=stlport4 "*) solaris_use_stlport4=yes ;; esac # Adding this requires a known-good setup of shared libraries for # Sun compiler versions before 5.6, else PIC objects from an old # archive will be linked into the output, leading to subtle bugs. if test "$solaris_use_stlport4" != yes; then postdeps_CXX='-library=Cstd -library=Crun' fi ;; esac ;; esac case " $postdeps_CXX " in *" -lc "*) archive_cmds_need_lc_CXX=no ;; esac compiler_lib_search_dirs_CXX= if test -n "${compiler_lib_search_path_CXX}"; then compiler_lib_search_dirs_CXX=`echo " ${compiler_lib_search_path_CXX}" | ${SED} -e 's! -L! !g' -e 's!^ !!'` fi lt_prog_compiler_wl_CXX= lt_prog_compiler_pic_CXX= lt_prog_compiler_static_CXX= # C++ specific cases for pic, static, wl, etc. if test "$GXX" = yes; then lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_static_CXX='-static' case $host_os in aix*) # All AIX code is PIC. if test "$host_cpu" = ia64; then # AIX 5 now supports IA64 processor lt_prog_compiler_static_CXX='-Bstatic' fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support lt_prog_compiler_pic_CXX='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the `-m68020' flag to GCC prevents building anything better, # like `-m68040'. lt_prog_compiler_pic_CXX='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries lt_prog_compiler_pic_CXX='-DDLL_EXPORT' ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files lt_prog_compiler_pic_CXX='-fno-common' ;; *djgpp*) # DJGPP does not support shared libraries at all lt_prog_compiler_pic_CXX= ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. lt_prog_compiler_static_CXX= ;; interix[3-9]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; sysv4*MP*) if test -d /usr/nec; then lt_prog_compiler_pic_CXX=-Kconform_pic fi ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) ;; *) lt_prog_compiler_pic_CXX='-fPIC' ;; esac ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic_CXX='-fPIC -shared' ;; *) lt_prog_compiler_pic_CXX='-fPIC' ;; esac else case $host_os in aix[4-9]*) # All AIX code is PIC. if test "$host_cpu" = ia64; then # AIX 5 now supports IA64 processor lt_prog_compiler_static_CXX='-Bstatic' else lt_prog_compiler_static_CXX='-bnso -bI:/lib/syscalls.exp' fi ;; chorus*) case $cc_basename in cxch68*) # Green Hills C++ Compiler # _LT_TAGVAR(lt_prog_compiler_static, CXX)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" ;; esac ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). lt_prog_compiler_pic_CXX='-DDLL_EXPORT' ;; dgux*) case $cc_basename in ec++*) lt_prog_compiler_pic_CXX='-KPIC' ;; ghcx*) # Green Hills C++ Compiler lt_prog_compiler_pic_CXX='-pic' ;; *) ;; esac ;; freebsd* | dragonfly*) # FreeBSD uses GNU C++ ;; hpux9* | hpux10* | hpux11*) case $cc_basename in CC*) lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_static_CXX='${wl}-a ${wl}archive' if test "$host_cpu" != ia64; then lt_prog_compiler_pic_CXX='+Z' fi ;; aCC*) lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_static_CXX='${wl}-a ${wl}archive' case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) lt_prog_compiler_pic_CXX='+Z' ;; esac ;; *) ;; esac ;; interix*) # This is c89, which is MS Visual C++ (no shared libs) # Anyone wants to do a port? ;; irix5* | irix6* | nonstopux*) case $cc_basename in CC*) lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_static_CXX='-non_shared' # CC pic flag -KPIC is the default. ;; *) ;; esac ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # KAI C++ Compiler lt_prog_compiler_wl_CXX='--backend -Wl,' lt_prog_compiler_pic_CXX='-fPIC' ;; ecpc* ) # old Intel C++ for x86_64 which still supported -KPIC. lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_pic_CXX='-KPIC' lt_prog_compiler_static_CXX='-static' ;; icpc* ) # Intel C++, used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_pic_CXX='-fPIC' lt_prog_compiler_static_CXX='-static' ;; pgCC* | pgcpp*) # Portland Group C++ compiler lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_pic_CXX='-fpic' lt_prog_compiler_static_CXX='-Bstatic' ;; cxx*) # Compaq C++ # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. lt_prog_compiler_pic_CXX= lt_prog_compiler_static_CXX='-non_shared' ;; xlc* | xlC* | bgxl[cC]* | mpixl[cC]*) # IBM XL 8.0, 9.0 on PPC and BlueGene lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_pic_CXX='-qpic' lt_prog_compiler_static_CXX='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 lt_prog_compiler_pic_CXX='-KPIC' lt_prog_compiler_static_CXX='-Bstatic' lt_prog_compiler_wl_CXX='-Qoption ld ' ;; esac ;; esac ;; lynxos*) ;; m88k*) ;; mvs*) case $cc_basename in cxx*) lt_prog_compiler_pic_CXX='-W c,exportall' ;; *) ;; esac ;; netbsd* | netbsdelf*-gnu) ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic_CXX='-fPIC -shared' ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) lt_prog_compiler_wl_CXX='--backend -Wl,' ;; RCC*) # Rational C++ 2.4.1 lt_prog_compiler_pic_CXX='-pic' ;; cxx*) # Digital/Compaq C++ lt_prog_compiler_wl_CXX='-Wl,' # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. lt_prog_compiler_pic_CXX= lt_prog_compiler_static_CXX='-non_shared' ;; *) ;; esac ;; psos*) ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ lt_prog_compiler_pic_CXX='-KPIC' lt_prog_compiler_static_CXX='-Bstatic' lt_prog_compiler_wl_CXX='-Qoption ld ' ;; gcx*) # Green Hills C++ Compiler lt_prog_compiler_pic_CXX='-PIC' ;; *) ;; esac ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x lt_prog_compiler_pic_CXX='-pic' lt_prog_compiler_static_CXX='-Bstatic' ;; lcc*) # Lucid lt_prog_compiler_pic_CXX='-pic' ;; *) ;; esac ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) case $cc_basename in CC*) lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_pic_CXX='-KPIC' lt_prog_compiler_static_CXX='-Bstatic' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 lt_prog_compiler_pic_CXX='-KPIC' ;; *) ;; esac ;; vxworks*) ;; *) lt_prog_compiler_can_build_shared_CXX=no ;; esac fi case $host_os in # For platforms which do not support PIC, -DPIC is meaningless: *djgpp*) lt_prog_compiler_pic_CXX= ;; *) lt_prog_compiler_pic_CXX="$lt_prog_compiler_pic_CXX -DPIC" ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $compiler option to produce PIC" >&5 $as_echo_n "checking for $compiler option to produce PIC... " >&6; } if ${lt_cv_prog_compiler_pic_CXX+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_pic_CXX=$lt_prog_compiler_pic_CXX fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_CXX" >&5 $as_echo "$lt_cv_prog_compiler_pic_CXX" >&6; } lt_prog_compiler_pic_CXX=$lt_cv_prog_compiler_pic_CXX # # Check to make sure the PIC flag actually works. # if test -n "$lt_prog_compiler_pic_CXX"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler PIC flag $lt_prog_compiler_pic_CXX works" >&5 $as_echo_n "checking if $compiler PIC flag $lt_prog_compiler_pic_CXX works... " >&6; } if ${lt_cv_prog_compiler_pic_works_CXX+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_pic_works_CXX=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$lt_prog_compiler_pic_CXX -DPIC" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_pic_works_CXX=yes fi fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works_CXX" >&5 $as_echo "$lt_cv_prog_compiler_pic_works_CXX" >&6; } if test x"$lt_cv_prog_compiler_pic_works_CXX" = xyes; then case $lt_prog_compiler_pic_CXX in "" | " "*) ;; *) lt_prog_compiler_pic_CXX=" $lt_prog_compiler_pic_CXX" ;; esac else lt_prog_compiler_pic_CXX= lt_prog_compiler_can_build_shared_CXX=no fi fi # # Check to make sure the static flag actually works. # wl=$lt_prog_compiler_wl_CXX eval lt_tmp_static_flag=\"$lt_prog_compiler_static_CXX\" { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler static flag $lt_tmp_static_flag works" >&5 $as_echo_n "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; } if ${lt_cv_prog_compiler_static_works_CXX+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_static_works_CXX=no save_LDFLAGS="$LDFLAGS" LDFLAGS="$LDFLAGS $lt_tmp_static_flag" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_static_works_CXX=yes fi else lt_cv_prog_compiler_static_works_CXX=yes fi fi $RM -r conftest* LDFLAGS="$save_LDFLAGS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works_CXX" >&5 $as_echo "$lt_cv_prog_compiler_static_works_CXX" >&6; } if test x"$lt_cv_prog_compiler_static_works_CXX" = xyes; then : else lt_prog_compiler_static_CXX= fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 $as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if ${lt_cv_prog_compiler_c_o_CXX+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_c_o_CXX=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o_CXX=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o_CXX" >&5 $as_echo "$lt_cv_prog_compiler_c_o_CXX" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 $as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if ${lt_cv_prog_compiler_c_o_CXX+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_c_o_CXX=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o_CXX=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o_CXX" >&5 $as_echo "$lt_cv_prog_compiler_c_o_CXX" >&6; } hard_links="nottested" if test "$lt_cv_prog_compiler_c_o_CXX" = no && test "$need_locks" != no; then # do not overwrite the value of need_locks provided by the user { $as_echo "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5 $as_echo_n "checking if we can lock with hard links... " >&6; } hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5 $as_echo "$hard_links" >&6; } if test "$hard_links" = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 $as_echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} need_locks=warn fi else need_locks=no fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 $as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' exclude_expsyms_CXX='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*' case $host_os in aix[4-9]*) # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to AIX nm, but means don't demangle with GNU nm # Also, AIX nm treats weak defined symbols like other global defined # symbols, whereas GNU nm marks them as "W". if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then export_symbols_cmds_CXX='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' else export_symbols_cmds_CXX='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' fi ;; pw32*) export_symbols_cmds_CXX="$ltdll_cmds" ;; cygwin* | mingw* | cegcc*) case $cc_basename in cl*) exclude_expsyms_CXX='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' ;; *) export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/;s/^.*[ ]__nm__\([^ ]*\)[ ][^ ]*/\1 DATA/;/^I[ ]/d;/^[AITW][ ]/s/.* //'\'' | sort | uniq > $export_symbols' exclude_expsyms_CXX='[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname' ;; esac ;; linux* | k*bsd*-gnu | gnu*) link_all_deplibs_CXX=no ;; *) export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs_CXX" >&5 $as_echo "$ld_shlibs_CXX" >&6; } test "$ld_shlibs_CXX" = no && can_build_shared=no with_gnu_ld_CXX=$with_gnu_ld # # Do we need to explicitly link libc? # case "x$archive_cmds_need_lc_CXX" in x|xyes) # Assume -lc should be added archive_cmds_need_lc_CXX=yes if test "$enable_shared" = yes && test "$GCC" = yes; then case $archive_cmds_CXX in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether -lc should be explicitly linked in" >&5 $as_echo_n "checking whether -lc should be explicitly linked in... " >&6; } if ${lt_cv_archive_cmds_need_lc_CXX+:} false; then : $as_echo_n "(cached) " >&6 else $RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$lt_prog_compiler_wl_CXX pic_flag=$lt_prog_compiler_pic_CXX compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$allow_undefined_flag_CXX allow_undefined_flag_CXX= if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$archive_cmds_CXX 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\""; } >&5 (eval $archive_cmds_CXX 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } then lt_cv_archive_cmds_need_lc_CXX=no else lt_cv_archive_cmds_need_lc_CXX=yes fi allow_undefined_flag_CXX=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_archive_cmds_need_lc_CXX" >&5 $as_echo "$lt_cv_archive_cmds_need_lc_CXX" >&6; } archive_cmds_need_lc_CXX=$lt_cv_archive_cmds_need_lc_CXX ;; esac fi ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking dynamic linker characteristics" >&5 $as_echo_n "checking dynamic linker characteristics... " >&6; } library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=".so" postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='${libname}${release}${shared_ext}$major' ;; aix[4-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test "$host_cpu" = ia64; then # AIX 5 supports IA64 library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line `#! .'. This would cause the generated library to # depend on `.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[01] | aix4.[01].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | ${CC} -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # AIX (on Power*) has no versioning support, so currently we can not hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. if test "$aix_use_runtimelinking" = yes; then # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' else # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='${libname}${release}.a $libname.a' soname_spec='${libname}${release}${shared_ext}$major' fi shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='${libname}${shared_ext}' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[45]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=".dll" need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \${file}`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl*) # Native MSVC libname_spec='$name' soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' library_names_spec='${libname}.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([a-zA-Z]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec="$LIB" if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \${file}`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC wrapper library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext' soname_spec='${libname}${release}${major}$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[23].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[01]* | freebsdelf3.[01]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[2-9]* | freebsdelf3.[2-9]* | \ freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=yes sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' if test "X$HPUX_IA64_MODE" = X32; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" fi sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[3-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test "$lt_cv_prog_gnu_ld" = yes; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='${libname}${release}${shared_ext}$major' library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH if ${lt_cv_shlibpath_overrides_runpath+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$lt_prog_compiler_wl_CXX\"; \ LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec_CXX\"" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : if ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null; then : lt_cv_shlibpath_overrides_runpath=yes fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS libdir=$save_libdir fi shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Append ld.so.conf contents to the search path if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsdelf*-gnu) version_type=linux need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='NetBSD ld.elf_so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd*) version_type=sunos sys_lib_dlsearch_path_spec="/usr/lib" need_lib_prefix=no # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. case $host_os in openbsd3.3 | openbsd3.3.*) need_version=yes ;; *) need_version=no ;; esac library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then case $host_os in openbsd2.[89] | openbsd2.[89].*) shlibpath_overrides_runpath=no ;; *) shlibpath_overrides_runpath=yes ;; esac else shlibpath_overrides_runpath=yes fi ;; os2*) libname_spec='$name' shrext_cmds=".dll" need_lib_prefix=no library_names_spec='$libname${shared_ext} $libname.a' dynamic_linker='OS/2 ld.exe' shlibpath_var=LIBPATH ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='${libname}${release}${shared_ext}$major' library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test "$with_gnu_ld" = yes; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec ;then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' soname_spec='$libname${shared_ext}.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=freebsd-elf need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test "$with_gnu_ld" = yes; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5 $as_echo "$dynamic_linker" >&6; } test "$dynamic_linker" = no && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test "$GCC" = yes; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec" fi if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec" fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to hardcode library paths into programs" >&5 $as_echo_n "checking how to hardcode library paths into programs... " >&6; } hardcode_action_CXX= if test -n "$hardcode_libdir_flag_spec_CXX" || test -n "$runpath_var_CXX" || test "X$hardcode_automatic_CXX" = "Xyes" ; then # We can hardcode non-existent directories. if test "$hardcode_direct_CXX" != no && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test "$_LT_TAGVAR(hardcode_shlibpath_var, CXX)" != no && test "$hardcode_minus_L_CXX" != no; then # Linking always hardcodes the temporary library directory. hardcode_action_CXX=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. hardcode_action_CXX=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. hardcode_action_CXX=unsupported fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hardcode_action_CXX" >&5 $as_echo "$hardcode_action_CXX" >&6; } if test "$hardcode_action_CXX" = relink || test "$inherit_rpath_CXX" = yes; then # Fast installation is not supported enable_fast_install=no elif test "$shlibpath_overrides_runpath" = yes || test "$enable_shared" = no; then # Fast installation is not necessary enable_fast_install=needless fi fi # test -n "$compiler" CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS LDCXX=$LD LD=$lt_save_LD GCC=$lt_save_GCC with_gnu_ld=$lt_save_with_gnu_ld lt_cv_path_LDCXX=$lt_cv_path_LD lt_cv_path_LD=$lt_save_path_LD lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld fi # test "$_lt_caught_CXX_error" != yes ac_ext=cpp ac_cpp='$CXXCPP $CPPFLAGS' ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_cxx_compiler_gnu ac_ext=${ac_fc_srcext-f} ac_compile='$FC -c $FCFLAGS $ac_fcflags_srcext conftest.$ac_ext >&5' ac_link='$FC -o conftest$ac_exeext $FCFLAGS $LDFLAGS $ac_fcflags_srcext conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_fc_compiler_gnu if test -z "$FC" || test "X$FC" = "Xno"; then _lt_disable_FC=yes fi archive_cmds_need_lc_FC=no allow_undefined_flag_FC= always_export_symbols_FC=no archive_expsym_cmds_FC= export_dynamic_flag_spec_FC= hardcode_direct_FC=no hardcode_direct_absolute_FC=no hardcode_libdir_flag_spec_FC= hardcode_libdir_separator_FC= hardcode_minus_L_FC=no hardcode_automatic_FC=no inherit_rpath_FC=no module_cmds_FC= module_expsym_cmds_FC= link_all_deplibs_FC=unknown old_archive_cmds_FC=$old_archive_cmds reload_flag_FC=$reload_flag reload_cmds_FC=$reload_cmds no_undefined_flag_FC= whole_archive_flag_spec_FC= enable_shared_with_static_runtimes_FC=no # Source file extension for fc test sources. ac_ext=${ac_fc_srcext-f} # Object file extension for compiled fc test sources. objext=o objext_FC=$objext # No sense in running all these tests if we already determined that # the FC compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test "$_lt_disable_FC" != yes; then # Code to be used in simple compile tests lt_simple_compile_test_code="\ subroutine t return end " # Code to be used in simple link tests lt_simple_link_test_code="\ program t end " # ltmain only uses $CC for tagged configurations so make sure $CC is set. # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # save warnings/boilerplate of simple test code ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* # Allow CC to be a program name with arguments. lt_save_CC="$CC" lt_save_GCC=$GCC lt_save_CFLAGS=$CFLAGS CC=${FC-"f95"} CFLAGS=$FCFLAGS compiler=$CC GCC=$ac_cv_fc_compiler_gnu compiler_FC=$CC for cc_temp in $compiler""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done cc_basename=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` if test -n "$compiler"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking if libtool supports shared libraries" >&5 $as_echo_n "checking if libtool supports shared libraries... " >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: result: $can_build_shared" >&5 $as_echo "$can_build_shared" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build shared libraries" >&5 $as_echo_n "checking whether to build shared libraries... " >&6; } test "$can_build_shared" = "no" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test "$enable_shared" = yes && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[4-9]*) if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then test "$enable_shared" = yes && enable_static=no fi ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_shared" >&5 $as_echo "$enable_shared" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build static libraries" >&5 $as_echo_n "checking whether to build static libraries... " >&6; } # Make sure either enable_shared or enable_static is yes. test "$enable_shared" = yes || enable_static=yes { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_static" >&5 $as_echo "$enable_static" >&6; } GCC_FC="$ac_cv_fc_compiler_gnu" LD_FC="$LD" ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... # Dependencies to place before and after the object being linked: predep_objects_FC= postdep_objects_FC= predeps_FC= postdeps_FC= compiler_lib_search_path_FC= cat > conftest.$ac_ext <<_LT_EOF subroutine foo implicit none integer a a=0 return end _LT_EOF _lt_libdeps_save_CFLAGS=$CFLAGS case "$CC $CFLAGS " in #( *\ -flto*\ *) CFLAGS="$CFLAGS -fno-lto" ;; *\ -fwhopr*\ *) CFLAGS="$CFLAGS -fno-whopr" ;; *\ -fuse-linker-plugin*\ *) CFLAGS="$CFLAGS -fno-use-linker-plugin" ;; esac if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then # Parse the compiler output and extract the necessary # objects, libraries and library flags. # Sentinel used to keep track of whether or not we are before # the conftest object file. pre_test_object_deps_done=no for p in `eval "$output_verbose_link_cmd"`; do case ${prev}${p} in -L* | -R* | -l*) # Some compilers place space between "-{L,R}" and the path. # Remove the space. if test $p = "-L" || test $p = "-R"; then prev=$p continue fi # Expand the sysroot to ease extracting the directories later. if test -z "$prev"; then case $p in -L*) func_stripname_cnf '-L' '' "$p"; prev=-L; p=$func_stripname_result ;; -R*) func_stripname_cnf '-R' '' "$p"; prev=-R; p=$func_stripname_result ;; -l*) func_stripname_cnf '-l' '' "$p"; prev=-l; p=$func_stripname_result ;; esac fi case $p in =*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;; esac if test "$pre_test_object_deps_done" = no; then case ${prev} in -L | -R) # Internal compiler library paths should come after those # provided the user. The postdeps already come after the # user supplied libs so there is no need to process them. if test -z "$compiler_lib_search_path_FC"; then compiler_lib_search_path_FC="${prev}${p}" else compiler_lib_search_path_FC="${compiler_lib_search_path_FC} ${prev}${p}" fi ;; # The "-l" case would never come before the object being # linked, so don't bother handling this case. esac else if test -z "$postdeps_FC"; then postdeps_FC="${prev}${p}" else postdeps_FC="${postdeps_FC} ${prev}${p}" fi fi prev= ;; *.lto.$objext) ;; # Ignore GCC LTO objects *.$objext) # This assumes that the test object file only shows up # once in the compiler output. if test "$p" = "conftest.$objext"; then pre_test_object_deps_done=yes continue fi if test "$pre_test_object_deps_done" = no; then if test -z "$predep_objects_FC"; then predep_objects_FC="$p" else predep_objects_FC="$predep_objects_FC $p" fi else if test -z "$postdep_objects_FC"; then postdep_objects_FC="$p" else postdep_objects_FC="$postdep_objects_FC $p" fi fi ;; *) ;; # Ignore the rest. esac done # Clean up. rm -f a.out a.exe else echo "libtool.m4: error: problem compiling FC test program" fi $RM -f confest.$objext CFLAGS=$_lt_libdeps_save_CFLAGS # PORTME: override above test on systems where it is broken case " $postdeps_FC " in *" -lc "*) archive_cmds_need_lc_FC=no ;; esac compiler_lib_search_dirs_FC= if test -n "${compiler_lib_search_path_FC}"; then compiler_lib_search_dirs_FC=`echo " ${compiler_lib_search_path_FC}" | ${SED} -e 's! -L! !g' -e 's!^ !!'` fi lt_prog_compiler_wl_FC= lt_prog_compiler_pic_FC= lt_prog_compiler_static_FC= if test "$GCC" = yes; then lt_prog_compiler_wl_FC='-Wl,' lt_prog_compiler_static_FC='-static' case $host_os in aix*) # All AIX code is PIC. if test "$host_cpu" = ia64; then # AIX 5 now supports IA64 processor lt_prog_compiler_static_FC='-Bstatic' fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support lt_prog_compiler_pic_FC='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the `-m68020' flag to GCC prevents building anything better, # like `-m68040'. lt_prog_compiler_pic_FC='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries lt_prog_compiler_pic_FC='-DDLL_EXPORT' ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files lt_prog_compiler_pic_FC='-fno-common' ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. lt_prog_compiler_static_FC= ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) # +Z the default ;; *) lt_prog_compiler_pic_FC='-fPIC' ;; esac ;; interix[3-9]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; msdosdjgpp*) # Just because we use GCC doesn't mean we suddenly get shared libraries # on systems that don't support them. lt_prog_compiler_can_build_shared_FC=no enable_shared=no ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic_FC='-fPIC -shared' ;; sysv4*MP*) if test -d /usr/nec; then lt_prog_compiler_pic_FC=-Kconform_pic fi ;; *) lt_prog_compiler_pic_FC='-fPIC' ;; esac case $cc_basename in nvcc*) # Cuda Compiler Driver 2.2 lt_prog_compiler_wl_FC='-Xlinker ' if test -n "$lt_prog_compiler_pic_FC"; then lt_prog_compiler_pic_FC="-Xcompiler $lt_prog_compiler_pic_FC" fi ;; esac else # PORTME Check for flag to pass linker flags through the system compiler. case $host_os in aix*) lt_prog_compiler_wl_FC='-Wl,' if test "$host_cpu" = ia64; then # AIX 5 now supports IA64 processor lt_prog_compiler_static_FC='-Bstatic' else lt_prog_compiler_static_FC='-bnso -bI:/lib/syscalls.exp' fi ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). lt_prog_compiler_pic_FC='-DDLL_EXPORT' ;; hpux9* | hpux10* | hpux11*) lt_prog_compiler_wl_FC='-Wl,' # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but # not for PA HP-UX. case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) lt_prog_compiler_pic_FC='+Z' ;; esac # Is there a better lt_prog_compiler_static that works with the bundled CC? lt_prog_compiler_static_FC='${wl}-a ${wl}archive' ;; irix5* | irix6* | nonstopux*) lt_prog_compiler_wl_FC='-Wl,' # PIC (with -KPIC) is the default. lt_prog_compiler_static_FC='-non_shared' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in # old Intel for x86_64 which still supported -KPIC. ecc*) lt_prog_compiler_wl_FC='-Wl,' lt_prog_compiler_pic_FC='-KPIC' lt_prog_compiler_static_FC='-static' ;; # icc used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. icc* | ifort*) lt_prog_compiler_wl_FC='-Wl,' lt_prog_compiler_pic_FC='-fPIC' lt_prog_compiler_static_FC='-static' ;; # Lahey Fortran 8.1. lf95*) lt_prog_compiler_wl_FC='-Wl,' lt_prog_compiler_pic_FC='--shared' lt_prog_compiler_static_FC='--static' ;; nagfor*) # NAG Fortran compiler lt_prog_compiler_wl_FC='-Wl,-Wl,,' lt_prog_compiler_pic_FC='-PIC' lt_prog_compiler_static_FC='-Bstatic' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group compilers (*not* the Pentium gcc compiler, # which looks to be a dead project) lt_prog_compiler_wl_FC='-Wl,' lt_prog_compiler_pic_FC='-fpic' lt_prog_compiler_static_FC='-Bstatic' ;; ccc*) lt_prog_compiler_wl_FC='-Wl,' # All Alpha code is PIC. lt_prog_compiler_static_FC='-non_shared' ;; xl* | bgxl* | bgf* | mpixl*) # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene lt_prog_compiler_wl_FC='-Wl,' lt_prog_compiler_pic_FC='-qpic' lt_prog_compiler_static_FC='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [1-7].* | *Sun*Fortran*\ 8.[0-3]*) # Sun Fortran 8.3 passes all unrecognized flags to the linker lt_prog_compiler_pic_FC='-KPIC' lt_prog_compiler_static_FC='-Bstatic' lt_prog_compiler_wl_FC='' ;; *Sun\ F* | *Sun*Fortran*) lt_prog_compiler_pic_FC='-KPIC' lt_prog_compiler_static_FC='-Bstatic' lt_prog_compiler_wl_FC='-Qoption ld ' ;; *Sun\ C*) # Sun C 5.9 lt_prog_compiler_pic_FC='-KPIC' lt_prog_compiler_static_FC='-Bstatic' lt_prog_compiler_wl_FC='-Wl,' ;; *Intel*\ [CF]*Compiler*) lt_prog_compiler_wl_FC='-Wl,' lt_prog_compiler_pic_FC='-fPIC' lt_prog_compiler_static_FC='-static' ;; *Portland\ Group*) lt_prog_compiler_wl_FC='-Wl,' lt_prog_compiler_pic_FC='-fpic' lt_prog_compiler_static_FC='-Bstatic' ;; esac ;; esac ;; newsos6) lt_prog_compiler_pic_FC='-KPIC' lt_prog_compiler_static_FC='-Bstatic' ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic_FC='-fPIC -shared' ;; osf3* | osf4* | osf5*) lt_prog_compiler_wl_FC='-Wl,' # All OSF/1 code is PIC. lt_prog_compiler_static_FC='-non_shared' ;; rdos*) lt_prog_compiler_static_FC='-non_shared' ;; solaris*) lt_prog_compiler_pic_FC='-KPIC' lt_prog_compiler_static_FC='-Bstatic' case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) lt_prog_compiler_wl_FC='-Qoption ld ';; *) lt_prog_compiler_wl_FC='-Wl,';; esac ;; sunos4*) lt_prog_compiler_wl_FC='-Qoption ld ' lt_prog_compiler_pic_FC='-PIC' lt_prog_compiler_static_FC='-Bstatic' ;; sysv4 | sysv4.2uw2* | sysv4.3*) lt_prog_compiler_wl_FC='-Wl,' lt_prog_compiler_pic_FC='-KPIC' lt_prog_compiler_static_FC='-Bstatic' ;; sysv4*MP*) if test -d /usr/nec ;then lt_prog_compiler_pic_FC='-Kconform_pic' lt_prog_compiler_static_FC='-Bstatic' fi ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) lt_prog_compiler_wl_FC='-Wl,' lt_prog_compiler_pic_FC='-KPIC' lt_prog_compiler_static_FC='-Bstatic' ;; unicos*) lt_prog_compiler_wl_FC='-Wl,' lt_prog_compiler_can_build_shared_FC=no ;; uts4*) lt_prog_compiler_pic_FC='-pic' lt_prog_compiler_static_FC='-Bstatic' ;; *) lt_prog_compiler_can_build_shared_FC=no ;; esac fi case $host_os in # For platforms which do not support PIC, -DPIC is meaningless: *djgpp*) lt_prog_compiler_pic_FC= ;; *) lt_prog_compiler_pic_FC="$lt_prog_compiler_pic_FC" ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $compiler option to produce PIC" >&5 $as_echo_n "checking for $compiler option to produce PIC... " >&6; } if ${lt_cv_prog_compiler_pic_FC+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_pic_FC=$lt_prog_compiler_pic_FC fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_FC" >&5 $as_echo "$lt_cv_prog_compiler_pic_FC" >&6; } lt_prog_compiler_pic_FC=$lt_cv_prog_compiler_pic_FC # # Check to make sure the PIC flag actually works. # if test -n "$lt_prog_compiler_pic_FC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler PIC flag $lt_prog_compiler_pic_FC works" >&5 $as_echo_n "checking if $compiler PIC flag $lt_prog_compiler_pic_FC works... " >&6; } if ${lt_cv_prog_compiler_pic_works_FC+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_pic_works_FC=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$lt_prog_compiler_pic_FC" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_pic_works_FC=yes fi fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works_FC" >&5 $as_echo "$lt_cv_prog_compiler_pic_works_FC" >&6; } if test x"$lt_cv_prog_compiler_pic_works_FC" = xyes; then case $lt_prog_compiler_pic_FC in "" | " "*) ;; *) lt_prog_compiler_pic_FC=" $lt_prog_compiler_pic_FC" ;; esac else lt_prog_compiler_pic_FC= lt_prog_compiler_can_build_shared_FC=no fi fi # # Check to make sure the static flag actually works. # wl=$lt_prog_compiler_wl_FC eval lt_tmp_static_flag=\"$lt_prog_compiler_static_FC\" { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler static flag $lt_tmp_static_flag works" >&5 $as_echo_n "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; } if ${lt_cv_prog_compiler_static_works_FC+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_static_works_FC=no save_LDFLAGS="$LDFLAGS" LDFLAGS="$LDFLAGS $lt_tmp_static_flag" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_static_works_FC=yes fi else lt_cv_prog_compiler_static_works_FC=yes fi fi $RM -r conftest* LDFLAGS="$save_LDFLAGS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works_FC" >&5 $as_echo "$lt_cv_prog_compiler_static_works_FC" >&6; } if test x"$lt_cv_prog_compiler_static_works_FC" = xyes; then : else lt_prog_compiler_static_FC= fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 $as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if ${lt_cv_prog_compiler_c_o_FC+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_c_o_FC=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o_FC=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o_FC" >&5 $as_echo "$lt_cv_prog_compiler_c_o_FC" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 $as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if ${lt_cv_prog_compiler_c_o_FC+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_c_o_FC=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o_FC=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o_FC" >&5 $as_echo "$lt_cv_prog_compiler_c_o_FC" >&6; } hard_links="nottested" if test "$lt_cv_prog_compiler_c_o_FC" = no && test "$need_locks" != no; then # do not overwrite the value of need_locks provided by the user { $as_echo "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5 $as_echo_n "checking if we can lock with hard links... " >&6; } hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5 $as_echo "$hard_links" >&6; } if test "$hard_links" = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 $as_echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} need_locks=warn fi else need_locks=no fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 $as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } runpath_var= allow_undefined_flag_FC= always_export_symbols_FC=no archive_cmds_FC= archive_expsym_cmds_FC= compiler_needs_object_FC=no enable_shared_with_static_runtimes_FC=no export_dynamic_flag_spec_FC= export_symbols_cmds_FC='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' hardcode_automatic_FC=no hardcode_direct_FC=no hardcode_direct_absolute_FC=no hardcode_libdir_flag_spec_FC= hardcode_libdir_separator_FC= hardcode_minus_L_FC=no hardcode_shlibpath_var_FC=unsupported inherit_rpath_FC=no link_all_deplibs_FC=unknown module_cmds_FC= module_expsym_cmds_FC= old_archive_from_new_cmds_FC= old_archive_from_expsyms_cmds_FC= thread_safe_flag_spec_FC= whole_archive_flag_spec_FC= # include_expsyms should be a list of space-separated symbols to be *always* # included in the symbol list include_expsyms_FC= # exclude_expsyms can be an extended regexp of symbols to exclude # it will be wrapped by ` (' and `)$', so one must not match beginning or # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', # as well as any symbol that contains `d'. exclude_expsyms_FC='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*' # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out # platforms (ab)use it in PIC code, but their linkers get confused if # the symbol is explicitly referenced. Since portable code cannot # rely on this symbol name, it's probably fine to never include it in # preloaded symbol tables. # Exclude shared library initialization/finalization symbols. extract_expsyms_cmds= case $host_os in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++. if test "$GCC" != yes; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++) with_gnu_ld=yes ;; openbsd*) with_gnu_ld=no ;; linux* | k*bsd*-gnu | gnu*) link_all_deplibs_FC=no ;; esac ld_shlibs_FC=yes # On some targets, GNU ld is compatible enough with the native linker # that we're better off using the native interface for both. lt_use_gnu_ld_interface=no if test "$with_gnu_ld" = yes; then case $host_os in aix*) # The AIX port of GNU ld has always aspired to compatibility # with the native linker. However, as the warning in the GNU ld # block says, versions before 2.19.5* couldn't really create working # shared libraries, regardless of the interface used. case `$LD -v 2>&1` in *\ \(GNU\ Binutils\)\ 2.19.5*) ;; *\ \(GNU\ Binutils\)\ 2.[2-9]*) ;; *\ \(GNU\ Binutils\)\ [3-9]*) ;; *) lt_use_gnu_ld_interface=yes ;; esac ;; *) lt_use_gnu_ld_interface=yes ;; esac fi if test "$lt_use_gnu_ld_interface" = yes; then # If archive_cmds runs LD, not CC, wlarc should be empty wlarc='${wl}' # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. runpath_var=LD_RUN_PATH hardcode_libdir_flag_spec_FC='${wl}-rpath ${wl}$libdir' export_dynamic_flag_spec_FC='${wl}--export-dynamic' # ancient GNU ld didn't support --whole-archive et. al. if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then whole_archive_flag_spec_FC="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' else whole_archive_flag_spec_FC= fi supports_anon_versioning=no case `$LD -v 2>&1` in *GNU\ gold*) supports_anon_versioning=yes ;; *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11 *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... *\ 2.11.*) ;; # other 2.11 versions *) supports_anon_versioning=yes ;; esac # See if GNU ld supports shared libraries. case $host_os in aix[3-9]*) # On AIX/PPC, the GNU linker is very broken if test "$host_cpu" != ia64; then ld_shlibs_FC=no cat <<_LT_EOF 1>&2 *** Warning: the GNU linker, at least up to release 2.19, is reported *** to be unable to reliably create shared libraries on AIX. *** Therefore, libtool is disabling shared libraries support. If you *** really care for shared libraries, you may want to install binutils *** 2.20 or above, or modify your PATH so that a non-GNU linker is found. *** You will then need to restart the configuration process. _LT_EOF fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support archive_cmds_FC='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds_FC='' ;; m68k) archive_cmds_FC='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' hardcode_libdir_flag_spec_FC='-L$libdir' hardcode_minus_L_FC=yes ;; esac ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then allow_undefined_flag_FC=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME archive_cmds_FC='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' else ld_shlibs_FC=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # _LT_TAGVAR(hardcode_libdir_flag_spec, FC) is actually meaningless, # as there is no search path for DLLs. hardcode_libdir_flag_spec_FC='-L$libdir' export_dynamic_flag_spec_FC='${wl}--export-all-symbols' allow_undefined_flag_FC=unsupported always_export_symbols_FC=no enable_shared_with_static_runtimes_FC=yes export_symbols_cmds_FC='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/;s/^.*[ ]__nm__\([^ ]*\)[ ][^ ]*/\1 DATA/;/^I[ ]/d;/^[AITW][ ]/s/.* //'\'' | sort | uniq > $export_symbols' exclude_expsyms_FC='[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname' if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then archive_cmds_FC='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file (1st line # is EXPORTS), use it as is; otherwise, prepend... archive_expsym_cmds_FC='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else ld_shlibs_FC=no fi ;; haiku*) archive_cmds_FC='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' link_all_deplibs_FC=yes ;; interix[3-9]*) hardcode_direct_FC=no hardcode_shlibpath_var_FC=no hardcode_libdir_flag_spec_FC='${wl}-rpath,$libdir' export_dynamic_flag_spec_FC='${wl}-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. archive_cmds_FC='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' archive_expsym_cmds_FC='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) tmp_diet=no if test "$host_os" = linux-dietlibc; then case $cc_basename in diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) esac fi if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ && test "$tmp_diet" = no then tmp_addflag=' $pic_flag' tmp_sharedflag='-shared' case $cc_basename,$host_cpu in pgcc*) # Portland Group C compiler whole_archive_flag_spec_FC='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' tmp_addflag=' $pic_flag' ;; pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group f77 and f90 compilers whole_archive_flag_spec_FC='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' tmp_addflag=' $pic_flag -Mnomain' ;; ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 tmp_addflag=' -i_dynamic' ;; efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 tmp_addflag=' -i_dynamic -nofor_main' ;; ifc* | ifort*) # Intel Fortran compiler tmp_addflag=' -nofor_main' ;; lf95*) # Lahey Fortran 8.1 whole_archive_flag_spec_FC= tmp_sharedflag='--shared' ;; xl[cC]* | bgxl[cC]* | mpixl[cC]*) # IBM XL C 8.0 on PPC (deal with xlf below) tmp_sharedflag='-qmkshrobj' tmp_addflag= ;; nvcc*) # Cuda Compiler Driver 2.2 whole_archive_flag_spec_FC='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' compiler_needs_object_FC=yes ;; esac case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C 5.9 whole_archive_flag_spec_FC='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' compiler_needs_object_FC=yes tmp_sharedflag='-G' ;; *Sun\ F*) # Sun Fortran 8.3 tmp_sharedflag='-G' ;; esac archive_cmds_FC='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' if test "x$supports_anon_versioning" = xyes; then archive_expsym_cmds_FC='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' fi case $cc_basename in xlf* | bgf* | bgxlf* | mpixlf*) # IBM XL Fortran 10.1 on PPC cannot create shared libs itself whole_archive_flag_spec_FC='--whole-archive$convenience --no-whole-archive' hardcode_libdir_flag_spec_FC='${wl}-rpath ${wl}$libdir' archive_cmds_FC='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' if test "x$supports_anon_versioning" = xyes; then archive_expsym_cmds_FC='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' fi ;; esac else ld_shlibs_FC=no fi ;; netbsd* | netbsdelf*-gnu) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds_FC='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' wlarc= else archive_cmds_FC='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds_FC='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' fi ;; solaris*) if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then ld_shlibs_FC=no cat <<_LT_EOF 1>&2 *** Warning: The releases 2.8.* of the GNU linker cannot reliably *** create shared libraries on Solaris systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.9.1 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then archive_cmds_FC='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds_FC='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs_FC=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*) ld_shlibs_FC=no cat <<_LT_EOF 1>&2 *** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not *** reliably create shared libraries on SCO systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.16.91.0.3 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF ;; *) # For security reasons, it is highly recommended that you always # use absolute paths for naming shared libraries, and exclude the # DT_RUNPATH tag from executables and libraries. But doing so # requires that you compile everything twice, which is a pain. if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then hardcode_libdir_flag_spec_FC='${wl}-rpath ${wl}$libdir' archive_cmds_FC='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds_FC='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs_FC=no fi ;; esac ;; sunos4*) archive_cmds_FC='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' wlarc= hardcode_direct_FC=yes hardcode_shlibpath_var_FC=no ;; *) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then archive_cmds_FC='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds_FC='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs_FC=no fi ;; esac if test "$ld_shlibs_FC" = no; then runpath_var= hardcode_libdir_flag_spec_FC= export_dynamic_flag_spec_FC= whole_archive_flag_spec_FC= fi else # PORTME fill in a description of your system's linker (not GNU ld) case $host_os in aix3*) allow_undefined_flag_FC=unsupported always_export_symbols_FC=yes archive_expsym_cmds_FC='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. hardcode_minus_L_FC=yes if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. hardcode_direct_FC=unsupported fi ;; aix[4-9]*) if test "$host_cpu" = ia64; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag="" else # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to AIX nm, but means don't demangle with GNU nm # Also, AIX nm treats weak defined symbols like other global # defined symbols, whereas GNU nm marks them as "W". if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then export_symbols_cmds_FC='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' else export_symbols_cmds_FC='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' fi aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # need to do runtime linking. case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) for ld_flag in $LDFLAGS; do if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then aix_use_runtimelinking=yes break fi done ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. archive_cmds_FC='' hardcode_direct_FC=yes hardcode_direct_absolute_FC=yes hardcode_libdir_separator_FC=':' link_all_deplibs_FC=yes file_list_spec_FC='${wl}-f,' if test "$GCC" = yes; then case $host_os in aix4.[012]|aix4.[012].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`${CC} -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 hardcode_direct_FC=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking hardcode_minus_L_FC=yes hardcode_libdir_flag_spec_FC='-L$libdir' hardcode_libdir_separator_FC= fi ;; esac shared_flag='-shared' if test "$aix_use_runtimelinking" = yes; then shared_flag="$shared_flag "'${wl}-G' fi link_all_deplibs_FC=no else # not using gcc if test "$host_cpu" = ia64; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test "$aix_use_runtimelinking" = yes; then shared_flag='${wl}-G' else shared_flag='${wl}-bM:SRE' fi fi fi export_dynamic_flag_spec_FC='${wl}-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to export. always_export_symbols_FC=yes if test "$aix_use_runtimelinking" = yes; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. allow_undefined_flag_FC='-berok' # Determine the default libpath from the value encoded in an # empty executable. if test "${lt_cv_aix_libpath+set}" = set; then aix_libpath=$lt_cv_aix_libpath else if ${lt_cv_aix_libpath__FC+:} false; then : $as_echo_n "(cached) " >&6 else cat > conftest.$ac_ext <<_ACEOF program main end _ACEOF if ac_fn_fc_try_link "$LINENO"; then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath__FC=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath__FC"; then lt_cv_aix_libpath__FC=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath__FC"; then lt_cv_aix_libpath__FC="/usr/lib:/lib" fi fi aix_libpath=$lt_cv_aix_libpath__FC fi hardcode_libdir_flag_spec_FC='${wl}-blibpath:$libdir:'"$aix_libpath" archive_expsym_cmds_FC='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then func_echo_all "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" else if test "$host_cpu" = ia64; then hardcode_libdir_flag_spec_FC='${wl}-R $libdir:/usr/lib:/lib' allow_undefined_flag_FC="-z nodefs" archive_expsym_cmds_FC="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. if test "${lt_cv_aix_libpath+set}" = set; then aix_libpath=$lt_cv_aix_libpath else if ${lt_cv_aix_libpath__FC+:} false; then : $as_echo_n "(cached) " >&6 else cat > conftest.$ac_ext <<_ACEOF program main end _ACEOF if ac_fn_fc_try_link "$LINENO"; then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath__FC=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath__FC"; then lt_cv_aix_libpath__FC=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath__FC"; then lt_cv_aix_libpath__FC="/usr/lib:/lib" fi fi aix_libpath=$lt_cv_aix_libpath__FC fi hardcode_libdir_flag_spec_FC='${wl}-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. no_undefined_flag_FC=' ${wl}-bernotok' allow_undefined_flag_FC=' ${wl}-berok' if test "$with_gnu_ld" = yes; then # We only use this code for GNU lds that support --whole-archive. whole_archive_flag_spec_FC='${wl}--whole-archive$convenience ${wl}--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives whole_archive_flag_spec_FC='$convenience' fi archive_cmds_need_lc_FC=yes # This is similar to how AIX traditionally builds its shared libraries. archive_expsym_cmds_FC="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' fi fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support archive_cmds_FC='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' archive_expsym_cmds_FC='' ;; m68k) archive_cmds_FC='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' hardcode_libdir_flag_spec_FC='-L$libdir' hardcode_minus_L_FC=yes ;; esac ;; bsdi[45]*) export_dynamic_flag_spec_FC=-rdynamic ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. case $cc_basename in cl*) # Native MSVC hardcode_libdir_flag_spec_FC=' ' allow_undefined_flag_FC=unsupported always_export_symbols_FC=yes file_list_spec_FC='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=".dll" # FIXME: Setting linknames here is a bad hack. archive_cmds_FC='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-dll~linknames=' archive_expsym_cmds_FC='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then sed -n -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' -e '1\\\!p' < $export_symbols > $output_objdir/$soname.exp; else sed -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, FC)='true' enable_shared_with_static_runtimes_FC=yes exclude_expsyms_FC='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' export_symbols_cmds_FC='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1,DATA/'\'' | $SED -e '\''/^[AITW][ ]/s/.*[ ]//'\'' | sort | uniq > $export_symbols' # Don't use ranlib old_postinstall_cmds_FC='chmod 644 $oldlib' postlink_cmds_FC='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile="$lt_outputfile.exe" lt_tool_outputfile="$lt_tool_outputfile.exe" ;; esac~ if test "$MANIFEST_TOOL" != ":" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # Assume MSVC wrapper hardcode_libdir_flag_spec_FC=' ' allow_undefined_flag_FC=unsupported # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=".dll" # FIXME: Setting linknames here is a bad hack. archive_cmds_FC='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' # The linker will automatically build a .lib file if we build a DLL. old_archive_from_new_cmds_FC='true' # FIXME: Should let the user specify the lib program. old_archive_cmds_FC='lib -OUT:$oldlib$oldobjs$old_deplibs' enable_shared_with_static_runtimes_FC=yes ;; esac ;; darwin* | rhapsody*) archive_cmds_need_lc_FC=no hardcode_direct_FC=no hardcode_automatic_FC=yes hardcode_shlibpath_var_FC=unsupported if test "$lt_cv_ld_force_load" = "yes"; then whole_archive_flag_spec_FC='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience ${wl}-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' compiler_needs_object_FC=yes else whole_archive_flag_spec_FC='' fi link_all_deplibs_FC=yes allow_undefined_flag_FC="$_lt_dar_allow_undefined" case $cc_basename in ifort*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test "$_lt_dar_can_shared" = "yes"; then output_verbose_link_cmd=func_echo_all archive_cmds_FC="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}" module_cmds_FC="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" archive_expsym_cmds_FC="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" module_expsym_cmds_FC="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" else ld_shlibs_FC=no fi ;; dgux*) archive_cmds_FC='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec_FC='-L$libdir' hardcode_shlibpath_var_FC=no ;; # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor # support. Future versions do this automatically, but an explicit c++rt0.o # does not break anything, and helps significantly (at the cost of a little # extra space). freebsd2.2*) archive_cmds_FC='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' hardcode_libdir_flag_spec_FC='-R$libdir' hardcode_direct_FC=yes hardcode_shlibpath_var_FC=no ;; # Unfortunately, older versions of FreeBSD 2 do not have this feature. freebsd2.*) archive_cmds_FC='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' hardcode_direct_FC=yes hardcode_minus_L_FC=yes hardcode_shlibpath_var_FC=no ;; # FreeBSD 3 and greater uses gcc -shared to do shared libraries. freebsd* | dragonfly*) archive_cmds_FC='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' hardcode_libdir_flag_spec_FC='-R$libdir' hardcode_direct_FC=yes hardcode_shlibpath_var_FC=no ;; hpux9*) if test "$GCC" = yes; then archive_cmds_FC='$RM $output_objdir/$soname~$CC -shared $pic_flag ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' else archive_cmds_FC='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' fi hardcode_libdir_flag_spec_FC='${wl}+b ${wl}$libdir' hardcode_libdir_separator_FC=: hardcode_direct_FC=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L_FC=yes export_dynamic_flag_spec_FC='${wl}-E' ;; hpux10*) if test "$GCC" = yes && test "$with_gnu_ld" = no; then archive_cmds_FC='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds_FC='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi if test "$with_gnu_ld" = no; then hardcode_libdir_flag_spec_FC='${wl}+b ${wl}$libdir' hardcode_libdir_separator_FC=: hardcode_direct_FC=yes hardcode_direct_absolute_FC=yes export_dynamic_flag_spec_FC='${wl}-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L_FC=yes fi ;; hpux11*) if test "$GCC" = yes && test "$with_gnu_ld" = no; then case $host_cpu in hppa*64*) archive_cmds_FC='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) archive_cmds_FC='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) archive_cmds_FC='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' ;; esac else case $host_cpu in hppa*64*) archive_cmds_FC='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) archive_cmds_FC='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) archive_cmds_FC='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' ;; esac fi if test "$with_gnu_ld" = no; then hardcode_libdir_flag_spec_FC='${wl}+b ${wl}$libdir' hardcode_libdir_separator_FC=: case $host_cpu in hppa*64*|ia64*) hardcode_direct_FC=no hardcode_shlibpath_var_FC=no ;; *) hardcode_direct_FC=yes hardcode_direct_absolute_FC=yes export_dynamic_flag_spec_FC='${wl}-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L_FC=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) if test "$GCC" = yes; then archive_cmds_FC='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' # Try to use the -exported_symbol ld option, if it does not # work, assume that -exports_file does not work either and # implicitly export all symbols. # This should be the same for all languages, so no per-tag cache variable. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $host_os linker accepts -exported_symbol" >&5 $as_echo_n "checking whether the $host_os linker accepts -exported_symbol... " >&6; } if ${lt_cv_irix_exported_symbol+:} false; then : $as_echo_n "(cached) " >&6 else save_LDFLAGS="$LDFLAGS" LDFLAGS="$LDFLAGS -shared ${wl}-exported_symbol ${wl}foo ${wl}-update_registry ${wl}/dev/null" cat > conftest.$ac_ext <<_ACEOF subroutine foo end _ACEOF if ac_fn_fc_try_link "$LINENO"; then : lt_cv_irix_exported_symbol=yes else lt_cv_irix_exported_symbol=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS="$save_LDFLAGS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_irix_exported_symbol" >&5 $as_echo "$lt_cv_irix_exported_symbol" >&6; } if test "$lt_cv_irix_exported_symbol" = yes; then archive_expsym_cmds_FC='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations ${wl}-exports_file ${wl}$export_symbols -o $lib' fi else archive_cmds_FC='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' archive_expsym_cmds_FC='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -exports_file $export_symbols -o $lib' fi archive_cmds_need_lc_FC='no' hardcode_libdir_flag_spec_FC='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator_FC=: inherit_rpath_FC=yes link_all_deplibs_FC=yes ;; netbsd* | netbsdelf*-gnu) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds_FC='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out else archive_cmds_FC='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF fi hardcode_libdir_flag_spec_FC='-R$libdir' hardcode_direct_FC=yes hardcode_shlibpath_var_FC=no ;; newsos6) archive_cmds_FC='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct_FC=yes hardcode_libdir_flag_spec_FC='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator_FC=: hardcode_shlibpath_var_FC=no ;; *nto* | *qnx*) ;; openbsd*) if test -f /usr/libexec/ld.so; then hardcode_direct_FC=yes hardcode_shlibpath_var_FC=no hardcode_direct_absolute_FC=yes if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then archive_cmds_FC='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_FC='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols' hardcode_libdir_flag_spec_FC='${wl}-rpath,$libdir' export_dynamic_flag_spec_FC='${wl}-E' else case $host_os in openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*) archive_cmds_FC='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec_FC='-R$libdir' ;; *) archive_cmds_FC='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' hardcode_libdir_flag_spec_FC='${wl}-rpath,$libdir' ;; esac fi else ld_shlibs_FC=no fi ;; os2*) hardcode_libdir_flag_spec_FC='-L$libdir' hardcode_minus_L_FC=yes allow_undefined_flag_FC=unsupported archive_cmds_FC='$ECHO "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~echo DATA >> $output_objdir/$libname.def~echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' old_archive_from_new_cmds_FC='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' ;; osf3*) if test "$GCC" = yes; then allow_undefined_flag_FC=' ${wl}-expect_unresolved ${wl}\*' archive_cmds_FC='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' else allow_undefined_flag_FC=' -expect_unresolved \*' archive_cmds_FC='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' fi archive_cmds_need_lc_FC='no' hardcode_libdir_flag_spec_FC='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator_FC=: ;; osf4* | osf5*) # as osf3* with the addition of -msym flag if test "$GCC" = yes; then allow_undefined_flag_FC=' ${wl}-expect_unresolved ${wl}\*' archive_cmds_FC='$CC -shared${allow_undefined_flag} $pic_flag $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' hardcode_libdir_flag_spec_FC='${wl}-rpath ${wl}$libdir' else allow_undefined_flag_FC=' -expect_unresolved \*' archive_cmds_FC='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' archive_expsym_cmds_FC='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ $CC -shared${allow_undefined_flag} ${wl}-input ${wl}$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib~$RM $lib.exp' # Both c and cxx compiler support -rpath directly hardcode_libdir_flag_spec_FC='-rpath $libdir' fi archive_cmds_need_lc_FC='no' hardcode_libdir_separator_FC=: ;; solaris*) no_undefined_flag_FC=' -z defs' if test "$GCC" = yes; then wlarc='${wl}' archive_cmds_FC='$CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_FC='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' else case `$CC -V 2>&1` in *"Compilers 5.0"*) wlarc='' archive_cmds_FC='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' archive_expsym_cmds_FC='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' ;; *) wlarc='${wl}' archive_cmds_FC='$CC -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_FC='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' ;; esac fi hardcode_libdir_flag_spec_FC='-R$libdir' hardcode_shlibpath_var_FC=no case $host_os in solaris2.[0-5] | solaris2.[0-5].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands `-z linker_flag'. GCC discards it without `$wl', # but is careful enough not to reorder. # Supported since Solaris 2.6 (maybe 2.5.1?) if test "$GCC" = yes; then whole_archive_flag_spec_FC='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' else whole_archive_flag_spec_FC='-z allextract$convenience -z defaultextract' fi ;; esac link_all_deplibs_FC=yes ;; sunos4*) if test "x$host_vendor" = xsequent; then # Use $CC to link under sequent, because it throws in some extra .o # files that make .init and .fini sections work. archive_cmds_FC='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds_FC='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' fi hardcode_libdir_flag_spec_FC='-L$libdir' hardcode_direct_FC=yes hardcode_minus_L_FC=yes hardcode_shlibpath_var_FC=no ;; sysv4) case $host_vendor in sni) archive_cmds_FC='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct_FC=yes # is this really true??? ;; siemens) ## LD is ld it makes a PLAMLIB ## CC just makes a GrossModule. archive_cmds_FC='$LD -G -o $lib $libobjs $deplibs $linker_flags' reload_cmds_FC='$CC -r -o $output$reload_objs' hardcode_direct_FC=no ;; motorola) archive_cmds_FC='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct_FC=no #Motorola manual says yes, but my tests say they lie ;; esac runpath_var='LD_RUN_PATH' hardcode_shlibpath_var_FC=no ;; sysv4.3*) archive_cmds_FC='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_shlibpath_var_FC=no export_dynamic_flag_spec_FC='-Bexport' ;; sysv4*MP*) if test -d /usr/nec; then archive_cmds_FC='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_shlibpath_var_FC=no runpath_var=LD_RUN_PATH hardcode_runpath_var=yes ld_shlibs_FC=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) no_undefined_flag_FC='${wl}-z,text' archive_cmds_need_lc_FC=no hardcode_shlibpath_var_FC=no runpath_var='LD_RUN_PATH' if test "$GCC" = yes; then archive_cmds_FC='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_FC='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds_FC='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_FC='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We can NOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. no_undefined_flag_FC='${wl}-z,text' allow_undefined_flag_FC='${wl}-z,nodefs' archive_cmds_need_lc_FC=no hardcode_shlibpath_var_FC=no hardcode_libdir_flag_spec_FC='${wl}-R,$libdir' hardcode_libdir_separator_FC=':' link_all_deplibs_FC=yes export_dynamic_flag_spec_FC='${wl}-Bexport' runpath_var='LD_RUN_PATH' if test "$GCC" = yes; then archive_cmds_FC='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_FC='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds_FC='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_FC='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; uts4*) archive_cmds_FC='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec_FC='-L$libdir' hardcode_shlibpath_var_FC=no ;; *) ld_shlibs_FC=no ;; esac if test x$host_vendor = xsni; then case $host in sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) export_dynamic_flag_spec_FC='${wl}-Blargedynsym' ;; esac fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs_FC" >&5 $as_echo "$ld_shlibs_FC" >&6; } test "$ld_shlibs_FC" = no && can_build_shared=no with_gnu_ld_FC=$with_gnu_ld # # Do we need to explicitly link libc? # case "x$archive_cmds_need_lc_FC" in x|xyes) # Assume -lc should be added archive_cmds_need_lc_FC=yes if test "$enable_shared" = yes && test "$GCC" = yes; then case $archive_cmds_FC in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether -lc should be explicitly linked in" >&5 $as_echo_n "checking whether -lc should be explicitly linked in... " >&6; } if ${lt_cv_archive_cmds_need_lc_FC+:} false; then : $as_echo_n "(cached) " >&6 else $RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$lt_prog_compiler_wl_FC pic_flag=$lt_prog_compiler_pic_FC compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$allow_undefined_flag_FC allow_undefined_flag_FC= if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$archive_cmds_FC 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\""; } >&5 (eval $archive_cmds_FC 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } then lt_cv_archive_cmds_need_lc_FC=no else lt_cv_archive_cmds_need_lc_FC=yes fi allow_undefined_flag_FC=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_archive_cmds_need_lc_FC" >&5 $as_echo "$lt_cv_archive_cmds_need_lc_FC" >&6; } archive_cmds_need_lc_FC=$lt_cv_archive_cmds_need_lc_FC ;; esac fi ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking dynamic linker characteristics" >&5 $as_echo_n "checking dynamic linker characteristics... " >&6; } library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=".so" postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='${libname}${release}${shared_ext}$major' ;; aix[4-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test "$host_cpu" = ia64; then # AIX 5 supports IA64 library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line `#! .'. This would cause the generated library to # depend on `.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[01] | aix4.[01].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | ${CC} -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # AIX (on Power*) has no versioning support, so currently we can not hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. if test "$aix_use_runtimelinking" = yes; then # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' else # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='${libname}${release}.a $libname.a' soname_spec='${libname}${release}${shared_ext}$major' fi shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='${libname}${shared_ext}' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[45]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=".dll" need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \${file}`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl*) # Native MSVC libname_spec='$name' soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' library_names_spec='${libname}.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([a-zA-Z]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec="$LIB" if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \${file}`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC wrapper library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext' soname_spec='${libname}${release}${major}$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[23].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[01]* | freebsdelf3.[01]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[2-9]* | freebsdelf3.[2-9]* | \ freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=yes sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' if test "X$HPUX_IA64_MODE" = X32; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" fi sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[3-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test "$lt_cv_prog_gnu_ld" = yes; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='${libname}${release}${shared_ext}$major' library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH if ${lt_cv_shlibpath_overrides_runpath+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$lt_prog_compiler_wl_FC\"; \ LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec_FC\"" cat > conftest.$ac_ext <<_ACEOF program main end _ACEOF if ac_fn_fc_try_link "$LINENO"; then : if ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null; then : lt_cv_shlibpath_overrides_runpath=yes fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS libdir=$save_libdir fi shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Append ld.so.conf contents to the search path if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsdelf*-gnu) version_type=linux need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='NetBSD ld.elf_so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd*) version_type=sunos sys_lib_dlsearch_path_spec="/usr/lib" need_lib_prefix=no # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. case $host_os in openbsd3.3 | openbsd3.3.*) need_version=yes ;; *) need_version=no ;; esac library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then case $host_os in openbsd2.[89] | openbsd2.[89].*) shlibpath_overrides_runpath=no ;; *) shlibpath_overrides_runpath=yes ;; esac else shlibpath_overrides_runpath=yes fi ;; os2*) libname_spec='$name' shrext_cmds=".dll" need_lib_prefix=no library_names_spec='$libname${shared_ext} $libname.a' dynamic_linker='OS/2 ld.exe' shlibpath_var=LIBPATH ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='${libname}${release}${shared_ext}$major' library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test "$with_gnu_ld" = yes; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec ;then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' soname_spec='$libname${shared_ext}.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=freebsd-elf need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test "$with_gnu_ld" = yes; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5 $as_echo "$dynamic_linker" >&6; } test "$dynamic_linker" = no && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test "$GCC" = yes; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec" fi if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec" fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to hardcode library paths into programs" >&5 $as_echo_n "checking how to hardcode library paths into programs... " >&6; } hardcode_action_FC= if test -n "$hardcode_libdir_flag_spec_FC" || test -n "$runpath_var_FC" || test "X$hardcode_automatic_FC" = "Xyes" ; then # We can hardcode non-existent directories. if test "$hardcode_direct_FC" != no && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test "$_LT_TAGVAR(hardcode_shlibpath_var, FC)" != no && test "$hardcode_minus_L_FC" != no; then # Linking always hardcodes the temporary library directory. hardcode_action_FC=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. hardcode_action_FC=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. hardcode_action_FC=unsupported fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hardcode_action_FC" >&5 $as_echo "$hardcode_action_FC" >&6; } if test "$hardcode_action_FC" = relink || test "$inherit_rpath_FC" = yes; then # Fast installation is not supported enable_fast_install=no elif test "$shlibpath_overrides_runpath" = yes || test "$enable_shared" = no; then # Fast installation is not necessary enable_fast_install=needless fi fi # test -n "$compiler" GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS fi # test "$_lt_disable_FC" != yes ac_ext=cpp ac_cpp='$CXXCPP $CPPFLAGS' ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_cxx_compiler_gnu ac_config_commands="$ac_config_commands libtool" # Only expand once: F77=$(FC) FFLAGS=$(FCFLAGS) # Extract the first word of "mpicc", so it can be a program name with args. set dummy mpicc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_path_MPICC+:} false; then : $as_echo_n "(cached) " >&6 else case $MPICC in [\\/]* | ?:[\\/]*) ac_cv_path_MPICC="$MPICC" # Let the user override the test with a path. ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_path_MPICC="$as_dir/$ac_word$ac_exec_ext" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS ;; esac fi MPICC=$ac_cv_path_MPICC if test -n "$MPICC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MPICC" >&5 $as_echo "$MPICC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi # Extract the first word of "perl", so it can be a program name with args. set dummy perl; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_path_PERL+:} false; then : $as_echo_n "(cached) " >&6 else case $PERL in [\\/]* | ?:[\\/]*) ac_cv_path_PERL="$PERL" # Let the user override the test with a path. ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_path_PERL="$as_dir/$ac_word$ac_exec_ext" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS ;; esac fi PERL=$ac_cv_path_PERL if test -n "$PERL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $PERL" >&5 $as_echo "$PERL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi #AC_CHECK_PROG(PERL,perl,yes,missing -- the perl scripting language) # crappy hack: of the macros AC_PROG_{CC,CXX,F77,FC}, only the # first expanded one will check for object file extension etc, # and fail if that doesn't work. if test x$FC = x; then as_fn_error $? "A Fortran compiler is required" "$LINENO" 5 fi cxx_enable=yes if test x$CXX = x; then cxx_enable=no fi # Correct install paths if test x"$prefix" = x -o x"$prefix" = "xNONE"; then : prefix="/usr/local" fi if test x"$exec_prefix" = x -o x"$exec_prefix" = "xNONE"; then : exec_prefix="\${prefix}" fi if test "$docdir" = "\${datarootdir}/doc/\${PACKAGE_TARNAME}"; then : docdir="\${datarootdir}/doc/eztrace" fi top_build_dir=`pwd` get_abs_dirname() { # $1 : relative filename cd $1 && \ pwd &&\ cd - > /dev/null } abs_srcdir=$(get_abs_dirname $srcdir) # Checks for libraries. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlsym in -ldl" >&5 $as_echo_n "checking for dlsym in -ldl... " >&6; } if ${ac_cv_lib_dl_dlsym+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlsym (); int main () { return dlsym (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_dl_dlsym=yes else ac_cv_lib_dl_dlsym=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlsym" >&5 $as_echo "$ac_cv_lib_dl_dlsym" >&6; } if test "x$ac_cv_lib_dl_dlsym" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBDL 1 _ACEOF LIBS="-ldl $LIBS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for cos in -lm" >&5 $as_echo_n "checking for cos in -lm... " >&6; } if ${ac_cv_lib_m_cos+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lm $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char cos (); int main () { return cos (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_m_cos=yes else ac_cv_lib_m_cos=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_m_cos" >&5 $as_echo "$ac_cv_lib_m_cos" >&6; } if test "x$ac_cv_lib_m_cos" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBM 1 _ACEOF LIBS="-lm $LIBS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for pthread_create in -lpthread" >&5 $as_echo_n "checking for pthread_create in -lpthread... " >&6; } if ${ac_cv_lib_pthread_pthread_create+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lpthread $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char pthread_create (); int main () { return pthread_create (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_pthread_pthread_create=yes else ac_cv_lib_pthread_pthread_create=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_pthread_pthread_create" >&5 $as_echo "$ac_cv_lib_pthread_pthread_create" >&6; } if test "x$ac_cv_lib_pthread_pthread_create" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBPTHREAD 1 _ACEOF LIBS="-lpthread $LIBS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for pthread_spin_lock in -lpthread" >&5 $as_echo_n "checking for pthread_spin_lock in -lpthread... " >&6; } if ${ac_cv_lib_pthread_pthread_spin_lock+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lpthread $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char pthread_spin_lock (); int main () { return pthread_spin_lock (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_pthread_pthread_spin_lock=yes else ac_cv_lib_pthread_pthread_spin_lock=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_pthread_pthread_spin_lock" >&5 $as_echo "$ac_cv_lib_pthread_pthread_spin_lock" >&6; } if test "x$ac_cv_lib_pthread_pthread_spin_lock" = xyes; then : have_full_pthread=yes else have_full_pthread=no fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for deflate in -lz" >&5 $as_echo_n "checking for deflate in -lz... " >&6; } if ${ac_cv_lib_z_deflate+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lz $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char deflate (); int main () { return deflate (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_z_deflate=yes else ac_cv_lib_z_deflate=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_z_deflate" >&5 $as_echo "$ac_cv_lib_z_deflate" >&6; } if test "x$ac_cv_lib_z_deflate" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBZ 1 _ACEOF LIBS="-lz $LIBS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for cplus_demangle in -liberty" >&5 $as_echo_n "checking for cplus_demangle in -liberty... " >&6; } if ${ac_cv_lib_iberty_cplus_demangle+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-liberty $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char cplus_demangle (); int main () { return cplus_demangle (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_iberty_cplus_demangle=yes else ac_cv_lib_iberty_cplus_demangle=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_iberty_cplus_demangle" >&5 $as_echo "$ac_cv_lib_iberty_cplus_demangle" >&6; } if test "x$ac_cv_lib_iberty_cplus_demangle" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBIBERTY 1 _ACEOF LIBS="-liberty $LIBS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for bfd_demangle in -lbfd" >&5 $as_echo_n "checking for bfd_demangle in -lbfd... " >&6; } if ${ac_cv_lib_bfd_bfd_demangle+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lbfd $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char bfd_demangle (); int main () { return bfd_demangle (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_bfd_bfd_demangle=yes else ac_cv_lib_bfd_bfd_demangle=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_bfd_bfd_demangle" >&5 $as_echo "$ac_cv_lib_bfd_bfd_demangle" >&6; } if test "x$ac_cv_lib_bfd_bfd_demangle" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBBFD 1 _ACEOF LIBS="-lbfd $LIBS" fi # Check the OS type os_type=`uname -s` if test "x$os_type" = "xLinux" ; then # Linux { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: OS: Linux" >&5 $as_echo "$as_me: WARNING: OS: Linux" >&2;} CFLAGS="$CFLAGS -DHAVE_LINUX -Wno-unused-parameter -Wno-unused-value" DYNLIB_EXT=".so" LD_PRELOAD_NAME="LD_PRELOAD" LD_LIBRARY_PATH_NAME="LD_LIBRARY_PATH" elif test "x$os_type" = "xDarwin" ; then # Mac OS { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: OS: Mac OS" >&5 $as_echo "$as_me: WARNING: OS: Mac OS" >&2;} CFLAGS="$CFLAGS -DHAVE_DARWIN" DYNLIB_EXT=".dylib" LD_PRELOAD_NAME="DYLD_INSERT_LIBRARIES" LD_LIBRARY_PATH_NAME="DYLD_LIBRARY_PATH" else # unknown OS, let's try Linux { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: unknown OS: falling back to Linux" >&5 $as_echo "$as_me: WARNING: unknown OS: falling back to Linux" >&2;} CFLAGS="$CFLAGS -DHAVE_LINUX" DYNLIB_EXT=".so" LD_PRELOAD_NAME="LD_PRELOAD" LD_LIBRARY_PATH_NAME="LD_LIBRARY_PATH" fi # Check the architecture type case "$host" in x86_64-*) cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #if defined(__x86_64__) && defined (__ILP32__) x32_test #endif _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "x32_test" >/dev/null 2>&1; then : SUBARCH='x32' else SUBARCH='64' fi rm -f conftest* if test "$SUBARCH" = "64" ; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: ARCH: X86_64" >&5 $as_echo "$as_me: WARNING: ARCH: X86_64" >&2;} arch_str="X86_64" else { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: unsupported x86_64 architecture. Some features will be disabled" >&5 $as_echo "$as_me: WARNING: unsupported x86_64 architecture. Some features will be disabled" >&2;} fi ;; armv7|arm*-*gnueabihf) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: ARCH: ARM" >&5 $as_echo "$as_me: WARNING: ARCH: ARM" >&2;} arch_str="ARM" CFLAGS="$CFLAGS -marm" ;; *) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: unknown architecture: falling back to x86_64" >&5 $as_echo "$as_me: WARNING: unknown architecture: falling back to x86_64" >&2;} ;; esac # Check for a library with a particular LDFLAGS # this LDFLAGS is not set in the 'final' LDFLAGS # This is usefull if only a small part of your program # needs this library # # example: #CHECK_LIB_LDFLAGS([gtg], # [setTraceType], # "$GTG_LDFLAGS", # , # AC_MSG_ERROR([cannot find libgtg])) # Check for a library with a particular LDFLAGS # this LDFLAGS is not set in the 'final' LDFLAGS # This is usefull if only a small part of your program # needs this library # # example: #CHECK_LIB_TRYLINK("$GTG_LDFLAGS", # [#include "GTG.h"], # [gtg_container_t c;], # [enable_gtg=yes], # AC_MSG_ERROR([cannot find libgtg])) # Check for a header with a particular CPPFLAGS # this CPPFLAGS is not set in the 'final' CPPFLAGS # This is usefull if only a small part of your program # needs this header # # example: # CHECK_HEADER_CPPFLAGS([GTGBasic1.h], # , # "$GTG_CPPFLAGS", # AC_MSG_ERROR([cannot find headers for gtg])) # Checks for programs # Extract the first word of "env", so it can be a program name with args. set dummy env; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_HAVE_ENV+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$HAVE_ENV"; then ac_cv_prog_HAVE_ENV="$HAVE_ENV" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_HAVE_ENV="yes" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS test -z "$ac_cv_prog_HAVE_ENV" && ac_cv_prog_HAVE_ENV="no" fi fi HAVE_ENV=$ac_cv_prog_HAVE_ENV if test -n "$HAVE_ENV"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $HAVE_ENV" >&5 $as_echo "$HAVE_ENV" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test x$HAVE_ENV = xno ; then as_fn_error $? "Cannot find env" "$LINENO" 5 fi # Checks for header files. # this is needed because demangle.h and string.h have confliting versions of the basename function ac_fn_cxx_check_decl "$LINENO" "basename" "ac_cv_have_decl_basename" "#include " if test "x$ac_cv_have_decl_basename" = xyes; then : ac_have_decl=1 else ac_have_decl=0 fi cat >>confdefs.h <<_ACEOF #define HAVE_DECL_BASENAME $ac_have_decl _ACEOF for ac_header in fcntl.h limits.h malloc.h stdint.h stdlib.h string.h sys/time.h unistd.h sys/syscall.h do : as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` ac_fn_cxx_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default" if eval test \"x\$"$as_ac_Header"\" = x"yes"; then : cat >>confdefs.h <<_ACEOF #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 _ACEOF fi done have_demangle=yes ac_fn_cxx_check_header_mongrel "$LINENO" "demangle.h" "ac_cv_header_demangle_h" "$ac_includes_default" if test "x$ac_cv_header_demangle_h" = xyes; then : else have_demangle=no fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for cplus_demangle in -liberty" >&5 $as_echo_n "checking for cplus_demangle in -liberty... " >&6; } if ${ac_cv_lib_iberty_cplus_demangle+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-liberty $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char cplus_demangle (); int main () { return cplus_demangle (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_iberty_cplus_demangle=yes else ac_cv_lib_iberty_cplus_demangle=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_iberty_cplus_demangle" >&5 $as_echo "$ac_cv_lib_iberty_cplus_demangle" >&6; } if test "x$ac_cv_lib_iberty_cplus_demangle" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBIBERTY 1 _ACEOF LIBS="-liberty $LIBS" else have_demangle=no fi if test "x$have_demangle" = xyes; then HAVE_DEMANGLE_TRUE= HAVE_DEMANGLE_FALSE='#' else HAVE_DEMANGLE_TRUE='#' HAVE_DEMANGLE_FALSE= fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for bfd_release in -lbfd" >&5 $as_echo_n "checking for bfd_release in -lbfd... " >&6; } if ${ac_cv_lib_bfd_bfd_release+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lbfd $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char bfd_release (); int main () { return bfd_release (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_bfd_bfd_release=yes else ac_cv_lib_bfd_bfd_release=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_bfd_bfd_release" >&5 $as_echo "$ac_cv_lib_bfd_bfd_release" >&6; } if test "x$ac_cv_lib_bfd_bfd_release" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBBFD 1 _ACEOF LIBS="-lbfd $LIBS" fi # Checks for typedefs, structures, and compiler characteristics. ac_fn_cxx_check_type "$LINENO" "size_t" "ac_cv_type_size_t" "$ac_includes_default" if test "x$ac_cv_type_size_t" = xyes; then : else cat >>confdefs.h <<_ACEOF #define size_t unsigned int _ACEOF fi ac_fn_c_find_uintX_t "$LINENO" "64" "ac_cv_c_uint64_t" case $ac_cv_c_uint64_t in #( no|yes) ;; #( *) $as_echo "#define _UINT64_T 1" >>confdefs.h cat >>confdefs.h <<_ACEOF #define uint64_t $ac_cv_c_uint64_t _ACEOF ;; esac # Checks for library functions. for ac_header in stdlib.h do : ac_fn_cxx_check_header_mongrel "$LINENO" "stdlib.h" "ac_cv_header_stdlib_h" "$ac_includes_default" if test "x$ac_cv_header_stdlib_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_STDLIB_H 1 _ACEOF fi done { $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU libc compatible malloc" >&5 $as_echo_n "checking for GNU libc compatible malloc... " >&6; } if ${ac_cv_func_malloc_0_nonnull+:} false; then : $as_echo_n "(cached) " >&6 else if test "$cross_compiling" = yes; then : ac_cv_func_malloc_0_nonnull=no else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #if defined STDC_HEADERS || defined HAVE_STDLIB_H # include #else char *malloc (); #endif int main () { return ! malloc (0); ; return 0; } _ACEOF if ac_fn_cxx_try_run "$LINENO"; then : ac_cv_func_malloc_0_nonnull=yes else ac_cv_func_malloc_0_nonnull=no fi rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ conftest.$ac_objext conftest.beam conftest.$ac_ext fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_func_malloc_0_nonnull" >&5 $as_echo "$ac_cv_func_malloc_0_nonnull" >&6; } if test $ac_cv_func_malloc_0_nonnull = yes; then : $as_echo "#define HAVE_MALLOC 1" >>confdefs.h else $as_echo "#define HAVE_MALLOC 0" >>confdefs.h case " $LIBOBJS " in *" malloc.$ac_objext "* ) ;; *) LIBOBJS="$LIBOBJS malloc.$ac_objext" ;; esac $as_echo "#define malloc rpl_malloc" >>confdefs.h fi for ac_func in atexit do : ac_fn_cxx_check_func "$LINENO" "atexit" "ac_cv_func_atexit" if test "x$ac_cv_func_atexit" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_ATEXIT 1 _ACEOF fi done build_doc=no # Check whether --with-doc was given. if test "${with_doc+set}" = set; then : withval=$with_doc; if test x$withval != xno ; then build_doc=yes fi else build_doc=no fi if test "x$build_doc" = "xyes" ; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: Documentation will be generated" >&5 $as_echo "Documentation will be generated" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: Documentation will not be generated" >&5 $as_echo "Documentation will not be generated" >&6; } fi # pptrace stuff use_pptrace=yes # Check whether --enable-pptrace was given. if test "${enable_pptrace+set}" = set; then : enableval=$enable_pptrace; fi if test "x$enable_pptrace" = xno; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: PPTrace explicitly disabled" >&5 $as_echo "PPTrace explicitly disabled" >&6; } use_pptrace=no fi if test "x$use_pptrace" = xyes; then pptrace_lib_found=yes#no pptrace_binary_type=1 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for bfd_release in -lbfd" >&5 $as_echo_n "checking for bfd_release in -lbfd... " >&6; } if ${ac_cv_lib_bfd_bfd_release+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lbfd $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char bfd_release (); int main () { return bfd_release (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_bfd_bfd_release=yes else ac_cv_lib_bfd_bfd_release=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_bfd_bfd_release" >&5 $as_echo "$ac_cv_lib_bfd_bfd_release" >&6; } if test "x$ac_cv_lib_bfd_bfd_release" = xyes; then : pptrace_binary_type=1 else as_fn_error $? "Error! You need to have libbfd" "$LINENO" 5 fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for deflate in -lz" >&5 $as_echo_n "checking for deflate in -lz... " >&6; } if ${ac_cv_lib_z_deflate+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lz $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char deflate (); int main () { return deflate (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_z_deflate=yes else ac_cv_lib_z_deflate=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_z_deflate" >&5 $as_echo "$ac_cv_lib_z_deflate" >&6; } if test "x$ac_cv_lib_z_deflate" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBZ 1 _ACEOF LIBS="-lz $LIBS" else as_fn_error $? "Error! Missing dependancy for libbfd (libiberty)" "$LINENO" 5 fi # check if the arch/OS is supported by pptrace if test "x$arch_str" = "xX86_64" || test "x$arch_str" = "xARM" ; then if test "x$os_type" = "xLinux" ; then use_pptrace=yes else use_pptrace=no { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: The target OS is not supported by pptrace. The instrumentation will be limited to shared libraries" >&5 $as_echo "$as_me: WARNING: The target OS is not supported by pptrace. The instrumentation will be limited to shared libraries" >&2;} fi else { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: The target architecture is not supported by pptrace. The instrumentation will be limited to shared libraries" >&5 $as_echo "$as_me: WARNING: The target architecture is not supported by pptrace. The instrumentation will be limited to shared libraries" >&2;} use_pptrace=no fi if test "x$use_pptrace" = xyes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: PPTrace enabled" >&5 $as_echo "PPTrace enabled" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: PPTrace cannot be installed" >&5 $as_echo "PPTrace cannot be installed" >&6; } fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for disassembler in -lopcodes" >&5 $as_echo_n "checking for disassembler in -lopcodes... " >&6; } if ${ac_cv_lib_opcodes_disassembler+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lopcodes $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char disassembler (); int main () { return disassembler (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_opcodes_disassembler=yes else ac_cv_lib_opcodes_disassembler=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_opcodes_disassembler" >&5 $as_echo "$ac_cv_lib_opcodes_disassembler" >&6; } if test "x$ac_cv_lib_opcodes_disassembler" = xyes; then : libopcode_found=yes HAVE_LIBOPCODE=1 { $as_echo "$as_me:${as_lineno-$LINENO}: result: libopcode found." >&5 $as_echo "libopcode found." >&6; } else libopcode_found=no fi if test "$libopcode_found" = yes; then HAVE_LIBOPCODE_TRUE= HAVE_LIBOPCODE_FALSE='#' else HAVE_LIBOPCODE_TRUE='#' HAVE_LIBOPCODE_FALSE= fi if test "$use_pptrace" = yes; then USE_PPTRACE_TRUE= USE_PPTRACE_FALSE='#' else USE_PPTRACE_TRUE='#' USE_PPTRACE_FALSE= fi PPTRACE_BINARY_TYPE=1 ac_fn_cxx_check_header_mongrel "$LINENO" "sys/prctl.h" "ac_cv_header_sys_prctl_h" "$ac_includes_default" if test "x$ac_cv_header_sys_prctl_h" = xyes; then : ac_fn_cxx_check_func "$LINENO" "prctl" "ac_cv_func_prctl" if test "x$ac_cv_func_prctl" = xyes; then : have_prctl_h=1 else have_prctl_h=0 fi else have_prctl_h=0 fi HAVE_PRCTL_H=$have_prctl_h # -m32 & -m64 flags for tests { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC supports -m32 and -m64" >&5 $as_echo_n "checking whether $CC supports -m32 and -m64... " >&6; } _save_cflags="$CFLAGS" _save_ldflags="$LDFLAGS" CFLAGS="$CFLAGS -m32" LDFLAGS="$LDFLAGS -m32" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main(void) { printf("Hello, World!\n"); return 0;} _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : m32_flag=yes else m32_flag=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext; CFLAGS="$_save_cflags -m64" LDFLAGS="$_save_ldflags -m64" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main(void) { printf("Hello, World!\n"); return 0;} _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : m64_flag=yes else m64_flag=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext; CFLAGS="$_save_cflags" LDFLAGS="$_save_ldflags" if test "x$m64_flag" = "xyes"; then if test "x$m32_flag" = "xyes"; then available_target_bits="32 64" supported_mXX_flags="-m32 -m64" else available_target_bits="64" supported_mXX_flags="-m64" fi else if test "x$m32_flag" = "xyes"; then available_target_bits="32" supported_mXX_flags="-m32" else available_target_bits="" supported_mXX_flags="" fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: supports $supported_mXX_flags" >&5 $as_echo "supports $supported_mXX_flags" >&6; } TARGET_BITS=$available_target_bits use_starpu=yes # Check whether --with-starpu was given. if test "${with_starpu+set}" = set; then : withval=$with_starpu; if test x$withval != xno; then # use specified path starpudir=$withval { $as_echo "$as_me:${as_lineno-$LINENO}: result: starpu using $starpudir" >&5 $as_echo "starpu using $starpudir" >&6; } STARPU_ROOT=$starpudir PKG_CONFIG_PATH=${PKG_CONFIG_PATH}${PKG_CONFIG_PATH:+:}${starpudir}/lib/pkgconfig else use_starpu=no fi else use_starpu=no fi if test x$use_starpu = xyes ; then use_starpu=no for STARPU in starpu-1.1 starpu-1.3 do if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}pkg-config", so it can be a program name with args. set dummy ${ac_tool_prefix}pkg-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_path_PKG_CONFIG+:} false; then : $as_echo_n "(cached) " >&6 else case $PKG_CONFIG in [\\/]* | ?:[\\/]*) ac_cv_path_PKG_CONFIG="$PKG_CONFIG" # Let the user override the test with a path. ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_path_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS ;; esac fi PKG_CONFIG=$ac_cv_path_PKG_CONFIG if test -n "$PKG_CONFIG"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $PKG_CONFIG" >&5 $as_echo "$PKG_CONFIG" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_path_PKG_CONFIG"; then ac_pt_PKG_CONFIG=$PKG_CONFIG # Extract the first word of "pkg-config", so it can be a program name with args. set dummy pkg-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_path_ac_pt_PKG_CONFIG+:} false; then : $as_echo_n "(cached) " >&6 else case $ac_pt_PKG_CONFIG in [\\/]* | ?:[\\/]*) ac_cv_path_ac_pt_PKG_CONFIG="$ac_pt_PKG_CONFIG" # Let the user override the test with a path. ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_path_ac_pt_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS ;; esac fi ac_pt_PKG_CONFIG=$ac_cv_path_ac_pt_PKG_CONFIG if test -n "$ac_pt_PKG_CONFIG"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_pt_PKG_CONFIG" >&5 $as_echo "$ac_pt_PKG_CONFIG" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_pt_PKG_CONFIG" = x; then PKG_CONFIG="" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac PKG_CONFIG=$ac_pt_PKG_CONFIG fi else PKG_CONFIG="$ac_cv_path_PKG_CONFIG" fi fi if test -n "$PKG_CONFIG"; then _pkg_min_version=0.9.0 { $as_echo "$as_me:${as_lineno-$LINENO}: checking pkg-config is at least version $_pkg_min_version" >&5 $as_echo_n "checking pkg-config is at least version $_pkg_min_version... " >&6; } if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } PKG_CONFIG="" fi fi pkg_failed=no { $as_echo "$as_me:${as_lineno-$LINENO}: checking for STARPU" >&5 $as_echo_n "checking for STARPU... " >&6; } if test -n "$STARPU_CFLAGS"; then pkg_cv_STARPU_CFLAGS="$STARPU_CFLAGS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"\$STARPU\""; } >&5 ($PKG_CONFIG --exists --print-errors "$STARPU") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_STARPU_CFLAGS=`$PKG_CONFIG --cflags "$STARPU" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test -n "$STARPU_LIBS"; then pkg_cv_STARPU_LIBS="$STARPU_LIBS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"\$STARPU\""; } >&5 ($PKG_CONFIG --exists --print-errors "$STARPU") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_STARPU_LIBS=`$PKG_CONFIG --libs "$STARPU" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test $pkg_failed = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi if test $_pkg_short_errors_supported = yes; then STARPU_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "$STARPU" 2>&1` else STARPU_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "$STARPU" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$STARPU_PKG_ERRORS" >&5 starpu_found=no elif test $pkg_failed = untried; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } starpu_found=no else STARPU_CFLAGS=$pkg_cv_STARPU_CFLAGS STARPU_LIBS=$pkg_cv_STARPU_LIBS { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } starpu_found=yes fi if test x$starpu_found = xyes then break; fi done STARPU_CPPFLAGS=$STARPU_CFLAGS STARPU_LDFLAGS=$STARPU_LIBS #check for starpu headers save_CPPFLAGS="$CPPFLAGS" CPPFLAGS="$CPPFLAGS "$STARPU_CPPFLAGS"" for ac_header in starpu.h do : ac_fn_cxx_check_header_mongrel "$LINENO" "starpu.h" "ac_cv_header_starpu_h" "$ac_includes_default" if test "x$ac_cv_header_starpu_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_STARPU_H 1 _ACEOF use_starpu=yes else { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cannot find starpu.h" >&5 $as_echo "$as_me: WARNING: cannot find starpu.h" >&2;} fi done CPPFLAGS="$save_CPPFLAGS" if test x$use_starpu = xyes ; then save_LDFLAGS="$LDFLAGS" save_LIBS="$LIBS" LDFLAGS="$LDFLAGS "$STARPU_LDFLAGS"" as_ac_Lib=`$as_echo "ac_cv_lib_$STARPU''_starpu_task_submit" | $as_tr_sh` { $as_echo "$as_me:${as_lineno-$LINENO}: checking for starpu_task_submit in -l$STARPU" >&5 $as_echo_n "checking for starpu_task_submit in -l$STARPU... " >&6; } if eval \${$as_ac_Lib+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-l$STARPU $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char starpu_task_submit (); int main () { return starpu_task_submit (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : eval "$as_ac_Lib=yes" else eval "$as_ac_Lib=no" fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi eval ac_res=\$$as_ac_Lib { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } if eval test \"x\$"$as_ac_Lib"\" = x"yes"; then : use_starpu=yes else { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cannot find libstarpu" >&5 $as_echo "$as_me: WARNING: cannot find libstarpu" >&2;} use_starpu=no fi LDFLAGS="$save_LDFLAGS" LIBS="$save_LIBS" fi fi use_litl=yes use_extern_litl=no LITL_PRINT=${top_build_dir}/extlib/litl/utils/litl_print # Check whether --with-litl was given. if test "${with_litl+set}" = set; then : withval=$with_litl; if test x$withval != xno; then use_litl=yes if test x$withval = xyes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else # use specified path use_extern_litl=yes litldir=$withval { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes using $litldir" >&5 $as_echo "yes using $litldir" >&6; } LITL_ROOT=$litldir LITL_PRINT=$litldir/bin/litl_print fi else use_litl=no as_fn_error $? "\"LiTL is required for eztrace\"" "$LINENO" 5 fi fi # --> LiTL if test x$use_extern_litl = xyes; then # use an external installation of LiTL extern_litl_found=yes use_intern_litl=no use_extern_litl=yes TL_CPPFLAGS="${TL_CPPFLAGS} -I${litldir}/include" TL_LDFLAGS="${TL_LDFLAGS} -L${litldir}/lib -Wl,-rpath,${litldir}/lib" TL_LIB="-llitl" TL_EXT_CPPFLAGS="$TL_CPPFLAGS" TL_EXT_LDFLAGS="$TL_LDFLAGS" TL_EXT_LIB="$TL_LIB" else # use the LiTL version shipped with eztrace extern_litl_found=no use_intern_litl=yes use_extern_litl=no litl_parent_dir=`pwd` litl_dir="extlib/litl" { $as_echo "$as_me:${as_lineno-$LINENO}: configuring in litl_dir ($litl_parent_dir/$litl_dir)" >&5 $as_echo "$as_me: configuring in litl_dir ($litl_parent_dir/$litl_dir)" >&6;} if test "$srcdir" != "."; then : test -d "$litl_dir" || mkdir -p "$litl_dir" || as_fn_error $? "cannot create $litl_dir" "$LINENO" 5 fi case $srcdir in .) litl_srcdir="$srcdir" ;; /*) litl_srcdir="$srcdir/$litl_dir" ;; *) litl_srcdir="../../$srcdir/$litl_dir" ;; esac litl_conf_cmd="$litl_srcdir/configure" litl_conf_args="$litl_conf_args --prefix=\"$prefix\" --exec-prefix=\"$exec_prefix\" --bindir=\"$bindir\" --libdir=\"$libdir\" --includedir=\"$includedir\" --docdir=\"$docdir/litl\" $TLFLAGS --cache-file=\"/dev/null\" --srcdir=\"$litl_srcdir\"" if test "x$build_doc" = "xyes" ; then litl_conf_args="$litl_conf_args --with-doc=\"$build_doc\"" fi { $as_echo "$as_me:${as_lineno-$LINENO}: running $SHELL $litl_conf_cmd $litl_conf_args" >&5 $as_echo "$as_me: running $SHELL $litl_conf_cmd $litl_conf_args" >&6;} cd $litl_dir eval "$SHELL '$litl_conf_cmd' $litl_conf_args" if test $? != "0"; then : as_fn_error $? "$litl_conf_cmd failed for $litl_dir" "$LINENO" 5 fi cd $litl_parent_dir if test x"$TLLIB" = x; then : TLLIB="-llitl" fi TL_CPPFLAGS="$TL_CPPFLAGS -I${abs_srcdir}/extlib/litl/src -I${top_build_dir}/extlib/litl/src" TL_LDFLAGS="${top_build_dir}/extlib/litl/src/liblitl.la" TL_LIB="" TL_EXT_CPPFLAGS="-I${prefix}/include/" TL_EXT_LDFLAGS="-L${prefix}/lib/" TL_EXT_LIB="-llitl" fi #TL_LIB="-llitl" if test x$extern_litl_found = xyes ; then CPPFLAGS="${CPPFLAGS} ${TL_CPPFLAGS}" LDFLAGS="${LDFLAGS} ${TL_LDFLAGS}" ac_fn_cxx_check_header_mongrel "$LINENO" "litl_types.h" "ac_cv_header_litl_types_h" "$ac_includes_default" if test "x$ac_cv_header_litl_types_h" = xyes; then : else as_fn_error $? "cannot find headers for LiTL" "$LINENO" 5 fi ac_fn_cxx_check_header_mongrel "$LINENO" "litl_write.h" "ac_cv_header_litl_write_h" "$ac_includes_default" if test "x$ac_cv_header_litl_write_h" = xyes; then : else as_fn_error $? "cannot find headers for LiTL" "$LINENO" 5 fi ac_fn_cxx_check_header_mongrel "$LINENO" "litl_read.h" "ac_cv_header_litl_read_h" "$ac_includes_default" if test "x$ac_cv_header_litl_read_h" = xyes; then : else as_fn_error $? "cannot find headers for LiTL" "$LINENO" 5 fi fi # <-- LiTL L_CPPFLAGS="${TL_CPPFLAGS} -DUSE_LITL -DRECORD_PACKED_EVENTS" L_EXT_CPPFLAGS="${TL_EXT_CPPFLAGS} -DUSE_LITL -DRECORD_PACKED_EVENTS" # by default tid recording is enabled LiTL TID_RECORDING_ENABLED=yes if test "x$TID_RECORDING_ENABLED" = xyes ; then CFLAGS="$CFLAGS -DTID_RECORDING_ENABLED" TL_CPPFLAGS="${TL_CPPFLAGS} -DTID_RECORDING_ENABLED" TL_EXT_CPPFLAGS="${TL_EXT_CPPFLAGS} -DTID_RECORDING_ENABLED" fi # check for openmp save_CPPFLAGS="$CPPFLAGS" CPPFLAGS="$CPPFLAGS "-fopenmp"" for ac_header in omp.h do : ac_fn_cxx_check_header_mongrel "$LINENO" "omp.h" "ac_cv_header_omp_h" "$ac_includes_default" if test "x$ac_cv_header_omp_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_OMP_H 1 _ACEOF openmp_found=yes else { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cannot find omp.h" >&5 $as_echo "$as_me: WARNING: cannot find omp.h" >&2;} fi done CPPFLAGS="$save_CPPFLAGS" use_papi=yes # Check whether --with-papi was given. if test "${with_papi+set}" = set; then : withval=$with_papi; if test x$withval != xno; then use_papi=yes if test x$withval = xyes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } use_papi_from_system=yes else # use specified path use_papi_from_system=no papidir=$withval { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes using $papidir" >&5 $as_echo "yes using $papidir" >&6; } PAPIDIR=$papidir fi else use_papi=no { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi USE_PAPIDIR_FROM_USER=$use_papi_from_system if test x$use_papi_from_system = xno; then PAPI_LIBDIR=$papidir/lib PAPI_CPPFLAGS="-I$papidir/include/" PAPI_LDFLAGS="-L${PAPI_LIBDIR} -Xlinker -rpath=${PAPI_LIBDIR}" elif test x$use_papi = xyes ; then if test -d "/usr/include/papi" ; then PAPI_CPPFLAGS="-I/usr/include/papi/" fi if test -d "/usr/lib/PAPI" ; then PAPI_LIBDIR=/usr/lib/papi PAPI_LDFLAGS="-L/usr/lib/papi -Xlinker -rpath=/usr/lib/papi" fi fi enable_papi=no if test x$use_papi = xyes ; then save_CPPFLAGS="$CPPFLAGS" CPPFLAGS="$CPPFLAGS $PAPI_CPPFLAGS" save_LDFLAGS="$LDFLAGS" save_LIBS="$LIBS" LDFLAGS="$LDFLAGS $PAPI_LDFLAGS -lpapi" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main () { PAPI_event_info_t plop; ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : enable_papi=yes else { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cannot find PAPI lib" >&5 $as_echo "$as_me: WARNING: cannot find PAPI lib" >&2;} fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS="$save_LDFLAGS" LIBS="$save_LIBS" CPPFLAGS="$save_CPPFLAGS" if test x$enable_papi = xyes; then enable_papi=no save_CPPFLAGS="$CPPFLAGS" CPPFLAGS="$CPPFLAGS "$PAPI_CPPFLAGS"" for ac_header in papi.h do : ac_fn_cxx_check_header_mongrel "$LINENO" "papi.h" "ac_cv_header_papi_h" "$ac_includes_default" if test "x$ac_cv_header_papi_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_PAPI_H 1 _ACEOF enable_papi=yes else { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cannot find headers for PAPI" >&5 $as_echo "$as_me: WARNING: cannot find headers for PAPI" >&2;} fi done CPPFLAGS="$save_CPPFLAGS" fi if test x$enable_papi = xyes; then CFLAGS="$CFLAGS -DUSE_PAPI" fi fi # MPI stuff MPI_ROOT= MPI_INC= use_mpi=yes use_mpi3=no use_mpi_from_system=yes # Check whether --with-mpi was given. if test "${with_mpi+set}" = set; then : withval=$with_mpi; if test x$withval != xno; then if test x$withval = xyes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } use_mpi_from_system=yes else # use specified path use_mpi_from_system=no mpidir=$withval { $as_echo "$as_me:${as_lineno-$LINENO}: result: Using MPI installation: $mpidir" >&5 $as_echo "Using MPI installation: $mpidir" >&6; } MPI_ROOT=$mpidir MPI_ROOT=$mpidir fi else # either --without-mpi or --with-mpi=no is set use_mpi=no fi fi # Check whether --with-mpi-include was given. if test "${with_mpi_include+set}" = set; then : withval=$with_mpi_include; if test x$withval != xno; then if test x$withval = xyes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } use_mpi_from_system=yes else # use specified path use_mpi_from_system=no mpidir=$withval { $as_echo "$as_me:${as_lineno-$LINENO}: result: MPI include directory: $mpidir" >&5 $as_echo "MPI include directory: $mpidir" >&6; } MPI_INC=$mpidir MPI_INC=$mpidir fi fi fi if test x$MPI_INC != x; then # use the value supplied by --with-mpi-include CPPFLAGS="${CPPFLAGS} -I$MPI_INC/" FCFLAGS="${FCFLAGS} -I$MPI_INC/" elif test x$MPI_ROOT != x; then # use the value supplied by --with-mpi CPPFLAGS="${CPPFLAGS} -I$MPI_ROOT/include/ " FCFLAGS="${FCFLAGS} -I$MPI_ROOT/include/ " fi mpi_ldflags= # Check whether --with-mpi-ldflags was given. if test "${with_mpi_ldflags+set}" = set; then : withval=$with_mpi_ldflags; if test "x$withval" != "xno"; then # use specified path mpi_ldflags=$withval { $as_echo "$as_me:${as_lineno-$LINENO}: result: MPI LDFLAGS: $mpi_ldflags" >&5 $as_echo "MPI LDFLAGS: $mpi_ldflags" >&6; } MPI_LDFLAGS=mpi_ldflags fi fi MPI_LDFLAGS="-lmpi" if test "x$mpi_ldflags" != "x"; then # use the value supplied by --with-mpi-include MPI_LDFLAGS="$mpi_ldflags" elif test x$MPI_ROOT != x; then # use the value supplied by --with-mpi MPI_LDFLAGS="-L$MPI_ROOT/lib -lmpi" fi if test $use_mpi = yes ; then USE_MPIDIR_FROM_USER=$use_mpi_from_system # MPI header ac_fn_cxx_check_header_mongrel "$LINENO" "mpi.h" "ac_cv_header_mpi_h" "$ac_includes_default" if test "x$ac_cv_header_mpi_h" = xyes; then : enable_mpi=yes else { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cannot find headers for MPI" >&5 $as_echo "$as_me: WARNING: cannot find headers for MPI" >&2;} fi if test $enable_mpi = yes ; then ac_fn_cxx_check_decl "$LINENO" "MPI_Ibarrier" "ac_cv_have_decl_MPI_Ibarrier" "#include " if test "x$ac_cv_have_decl_MPI_Ibarrier" = xyes; then : ac_have_decl=1 else ac_have_decl=0 fi cat >>confdefs.h <<_ACEOF #define HAVE_DECL_MPI_IBARRIER $ac_have_decl _ACEOF if test $ac_have_decl = 1; then : use_mpi3=yes else use_mpi3=no fi fi else enable_mpi=no fi mpi_module_name=mpi # Check whether --with-mpi-module-name was given. if test "${with_mpi_module_name+set}" = set; then : withval=$with_mpi_module_name; if test x$withval != x; then mpi_module_name=$withval { $as_echo "$as_me:${as_lineno-$LINENO}: result: Changing the name of the MPI module to $mpi_module_name" >&5 $as_echo "Changing the name of the MPI module to $mpi_module_name" >&6; } else # either --without-mpi or --with-mpi=no is set { $as_echo "$as_me:${as_lineno-$LINENO}: result: Please provide a name to the --with-mpi-module-name option" >&5 $as_echo "Please provide a name to the --with-mpi-module-name option" >&6; } fi fi mpi_event_id=4 # Check whether --with-mpi-event-id was given. if test "${with_mpi_event_id+set}" = set; then : withval=$with_mpi_event_id; if test x$withval != x; then mpi_event_id=$withval { $as_echo "$as_me:${as_lineno-$LINENO}: result: Changing the ID of MPI events $mpi_event_id" >&5 $as_echo "Changing the ID of MPI events $mpi_event_id" >&6; } else # either --without-mpi or --with-mpi=no is set { $as_echo "$as_me:${as_lineno-$LINENO}: result: Please provide an ID to the --with-mpi-event-id option" >&5 $as_echo "Please provide an ID to the --with-mpi-event-id option" >&6; } fi fi MPI_LDFLAGS=$MPI_LDFLAGS MPI_MODULE_NAME=$mpi_module_name MPI_EVENT_ID=$mpi_event_id # GTG stuff use_extern_gtg=no # Check whether --with-gtg was given. if test "${with_gtg+set}" = set; then : withval=$with_gtg; if test x$withval != xno; then if test x$withval = xyes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else # use specified path use_extern_gtg=yes gtgdir=$withval { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes using gtgdir" >&5 $as_echo "yes using gtgdir" >&6; } GTGDIR=$gtgdir fi else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } as_fn_error $? "Cannot find GTG" "$LINENO" 5 fi fi if test x$use_extern_gtg = xyes; then GTG_CPPFLAGS="${CPPFLAGS} -I$gtgdir/include/" GTG_LDFLAGS="${LDFLAGS} -L$gtgdir/lib/" GTG_DEPENDENCIES="" GTG_LIB="-lgtg" GTG_EXT_CPPFLAGS="${GTG_CPPFLAGS}" GTG_EXT_LDFLAGS="$GTGLDFLAGS" GTG_EXT_LIB="-lgtg" save_LDFLAGS="$LDFLAGS" save_LIBS="$LIBS" LDFLAGS="$LDFLAGS "$GTG_LDFLAGS"" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for setTraceType in -lgtg" >&5 $as_echo_n "checking for setTraceType in -lgtg... " >&6; } if ${ac_cv_lib_gtg_setTraceType+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lgtg $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char setTraceType (); int main () { return setTraceType (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_gtg_setTraceType=yes else ac_cv_lib_gtg_setTraceType=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_gtg_setTraceType" >&5 $as_echo "$ac_cv_lib_gtg_setTraceType" >&6; } if test "x$ac_cv_lib_gtg_setTraceType" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBGTG 1 _ACEOF LIBS="-lgtg $LIBS" else as_fn_error $? "cannot find libgtg" "$LINENO" 5 fi LDFLAGS="$save_LDFLAGS" LIBS="$save_LIBS" save_LDFLAGS="$LDFLAGS" save_LIBS="$LIBS" LDFLAGS="$LDFLAGS "$GTG_LDFLAGS"" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for gtg_record in -lgtg" >&5 $as_echo_n "checking for gtg_record in -lgtg... " >&6; } if ${ac_cv_lib_gtg_gtg_record+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lgtg $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char gtg_record (); int main () { return gtg_record (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_gtg_gtg_record=yes else ac_cv_lib_gtg_gtg_record=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_gtg_gtg_record" >&5 $as_echo "$ac_cv_lib_gtg_gtg_record" >&6; } if test "x$ac_cv_lib_gtg_gtg_record" = xyes; then : GTG_OUT_OF_ORDER=1 else GTG_OUT_OF_ORDER=0 fi LDFLAGS="$save_LDFLAGS" LIBS="$save_LIBS" save_CPPFLAGS="$CPPFLAGS" CPPFLAGS="$CPPFLAGS "$GTG_CPPFLAGS"" for ac_header in GTG.h do : ac_fn_cxx_check_header_mongrel "$LINENO" "GTG.h" "ac_cv_header_GTG_h" "$ac_includes_default" if test "x$ac_cv_header_GTG_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_GTG_H 1 _ACEOF else as_fn_error $? "cannot find headers for gtg" "$LINENO" 5 fi done CPPFLAGS="$save_CPPFLAGS" else GTG_OUT_OF_ORDER=1 gtg_parent_dir=`pwd` gtg_dir="extlib/gtg" { $as_echo "$as_me:${as_lineno-$LINENO}: configuring in gtg_dir ($gtg_parent_dir/$gtg_dir)" >&5 $as_echo "$as_me: configuring in gtg_dir ($gtg_parent_dir/$gtg_dir)" >&6;} if test "$srcdir" != "."; then : test -d "$gtg_dir" || mkdir -p "$gtg_dir" || as_fn_error $? "cannot create $gtg_dir" "$LINENO" 5 fi case $srcdir in .) gtg_srcdir="$srcdir" ;; /*) gtg_srcdir="$srcdir/$gtg_dir" ;; *) gtg_srcdir="../../$srcdir/$gtg_dir" ;; esac gtg_conf_cmd="$gtg_srcdir/configure" gtg_conf_args="$gtg_conf_args --prefix=\"$prefix\" --exec-prefix=\"$exec_prefix\" --bindir=\"$bindir\" --libdir=\"$libdir\" --includedir=\"$includedir\" --docdir=\"$docdir/gtg\" $GTGFLAGS --cache-file=\"/dev/null\" --srcdir=\"$gtg_srcdir\" --with-mpi=no" if test "x$build_doc" = "xyes" ; then gtg_conf_args="$gtg_conf_args --with-doc=\"$build_doc\"" fi { $as_echo "$as_me:${as_lineno-$LINENO}: running $SHELL $gtg_conf_cmd $gtg_conf_args" >&5 $as_echo "$as_me: running $SHELL $gtg_conf_cmd $gtg_conf_args" >&6;} cd $gtg_dir eval "$SHELL '$gtg_conf_cmd' $gtg_conf_args" if test $? != "0"; then : as_fn_error $? "$gtg_conf_cmd failed for $gtg_dir" "$LINENO" 5 fi cd $gtg_parent_dir GTG_CPPFLAGS="$GTG_CPPFLAGS -I${abs_srcdir}/${gtg_dir}/inc -I${top_build_dir}/${gtg_dir}/inc" GTG_LDFLAGS="${top_build_dir}/${gtg_dir}/src/libgtg.la" GTG_DEPENDENCIES="$GTG_LDFLAGS" GTG_LIB="" GTG_EXT_CPPFLAGS="-I${prefix}/include" GTG_EXT_LDFLAGS="-L${prefix}/lib" GTG_EXT_LIB="-lgtg" fi if test "$GTG_OUT_OF_ORDER" = "1" ; then GTG_CPPFLAGS="${GTG_CPPFLAGS} -DGTG_OUT_OF_ORDER" GTG_EXT_CPPFLAGS="${GTG_EXT_CPPFLAGS} -DGTG_OUT_OF_ORDER" fi # Check for presence of pdfLaTeX # Extract the first word of "pdflatex", so it can be a program name with args. set dummy pdflatex; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_PDFLATEX+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$PDFLATEX"; then ac_cv_prog_PDFLATEX="$PDFLATEX" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_PDFLATEX="pdflatex" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi PDFLATEX=$ac_cv_prog_PDFLATEX if test -n "$PDFLATEX"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $PDFLATEX" >&5 $as_echo "$PDFLATEX" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test -z "$PDFLATEX"; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: Unable to create PDF version of the user manual -- pdflatex is missing!" >&5 $as_echo "$as_me: WARNING: Unable to create PDF version of the user manual -- pdflatex is missing!" >&2;} fi if test -n "$PDFLATEX"; then HAVE_PDFLATEX_TRUE= HAVE_PDFLATEX_FALSE='#' else HAVE_PDFLATEX_TRUE='#' HAVE_PDFLATEX_FALSE= fi # Check for presence of latexmk # Extract the first word of "latexmk", so it can be a program name with args. set dummy latexmk; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_LATEXMK+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$LATEXMK"; then ac_cv_prog_LATEXMK="$LATEXMK" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_LATEXMK="latexmk" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi LATEXMK=$ac_cv_prog_LATEXMK if test -n "$LATEXMK"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LATEXMK" >&5 $as_echo "$LATEXMK" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test -z "$LATEXMK"; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: Unable to create PDF version of the user manual -- latemk is missing!" >&5 $as_echo "$as_me: WARNING: Unable to create PDF version of the user manual -- latemk is missing!" >&2;} fi if test -n "$LATEXMK"; then HAVE_LATEXMK_TRUE= HAVE_LATEXMK_FALSE='#' else HAVE_LATEXMK_TRUE='#' HAVE_LATEXMK_FALSE= fi # CUDA stuff CUDA_ROOT=/usr/local/cuda use_cuda=yes use_cuda_from_system=yes # Check whether --with-cuda was given. if test "${with_cuda+set}" = set; then : withval=$with_cuda; if test x$withval != xno; then if test x$withval = xyes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } use_cuda_from_system=yes else # use specified path use_cuda_from_system=no cudadir=$withval { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes using $cudadir" >&5 $as_echo "yes using $cudadir" >&6; } CUDA_ROOT=$cudadir CUDA_ROOT=$cudadir fi else # either --without-cuda or --with-cuda=no is set use_cuda=no fi fi enable_cuda=yes if test $use_cuda = yes ; then CUDA_INC=${CUDA_ROOT}/include CUDA_CFLAGS="-I${CUDA_INC}" CUDA_LIBS="-lcudart" CUDA_LDFLAGS="-L${CUDA_ROOT}/lib -Wl,-rpath -Wl,${CUDA_ROOT}/lib" if test x$CUPTI_ROOT = x ; then CUPTI_ROOT="${CUDA_ROOT}/extras/CUPTI" fi CUPTI_INC=${CUPTI_ROOT}/include CUPTI_CFLAGS="-I${CUPTI_INC}" CUPTI_LIBS="-lcupti" CUPTI_LDFLAGS="-L${CUPTI_ROOT}/lib -Wl,-rpath -Wl,${CUPTI_ROOT}/lib" # 64-bits systems CUDA_LDFLAGS="${CUDA_LDFLAGS} -L${CUDA_ROOT}/lib64 -Wl,-rpath -Wl,${CUDA_ROOT}/lib64" CUPTI_LDFLAGS="${CUPTI_LDFLAGS} -L${CUPTI_ROOT}/lib64 -Wl,-rpath -Wl,${CUPTI_ROOT}/lib64 ${CUDA_LDFLAGS}" NVCC="${CUDA_ROOT}/bin/nvcc" USE_CUDADIR_FROM_USER=$use_cuda_from_system # CUDA compiler { $as_echo "$as_me:${as_lineno-$LINENO}: checking for CUDA compiler in $CUDA_ROOT/bin" >&5 $as_echo_n "checking for CUDA compiler in $CUDA_ROOT/bin... " >&6; } if test -x "${NVCC}" ; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: nvcc not found" >&5 $as_echo "nvcc not found" >&6; } enable_cuda=no fi fi if test $enable_cuda = yes ; then # CUDA header { $as_echo "$as_me:${as_lineno-$LINENO}: checking for CUDA header in $CUDA_INC" >&5 $as_echo_n "checking for CUDA header in $CUDA_INC... " >&6; } if test -f "${CUDA_INC}/cuda.h" ; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: cuda.h not found" >&5 $as_echo "cuda.h not found" >&6; } enable_cuda=no fi fi if test $enable_cuda = yes ; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for CUPTI header in $CUPTI_INC" >&5 $as_echo_n "checking for CUPTI header in $CUPTI_INC... " >&6; } if test -f "${CUPTI_INC}/cupti.h" ; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: cupti.h not found" >&5 $as_echo "cupti.h not found" >&6; } enable_cuda=no fi fi if test $enable_cuda = yes ; then save_LDFLAGS="$LDFLAGS" save_LIBS="$LIBS" LDFLAGS="$LDFLAGS "$CUDA_LDFLAGS"" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for cudaMalloc in -lcudart" >&5 $as_echo_n "checking for cudaMalloc in -lcudart... " >&6; } if ${ac_cv_lib_cudart_cudaMalloc+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lcudart $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char cudaMalloc (); int main () { return cudaMalloc (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_cudart_cudaMalloc=yes else ac_cv_lib_cudart_cudaMalloc=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_cudart_cudaMalloc" >&5 $as_echo "$ac_cv_lib_cudart_cudaMalloc" >&6; } if test "x$ac_cv_lib_cudart_cudaMalloc" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBCUDART 1 _ACEOF LIBS="-lcudart $LIBS" else as_fn_error $? "cannot find libcudart" "$LINENO" 5 fi LDFLAGS="$save_LDFLAGS" LIBS="$save_LIBS" save_LDFLAGS="$LDFLAGS" save_LIBS="$LIBS" LDFLAGS="$LDFLAGS "$CUPTI_LDFLAGS"" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for cuptiSubscribe in -lcupti" >&5 $as_echo_n "checking for cuptiSubscribe in -lcupti... " >&6; } if ${ac_cv_lib_cupti_cuptiSubscribe+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lcupti $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char cuptiSubscribe (); int main () { return cuptiSubscribe (); ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO"; then : ac_cv_lib_cupti_cuptiSubscribe=yes else ac_cv_lib_cupti_cuptiSubscribe=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_cupti_cuptiSubscribe" >&5 $as_echo "$ac_cv_lib_cupti_cuptiSubscribe" >&6; } if test "x$ac_cv_lib_cupti_cuptiSubscribe" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBCUPTI 1 _ACEOF LIBS="-lcupti $LIBS" else as_fn_error $? "cannot find libcupti" "$LINENO" 5 fi LDFLAGS="$save_LDFLAGS" LIBS="$save_LIBS" else use_cuda=no enable_cuda=no fi if test x$enable_cuda != xyes ; then CUDA_INC= CUDA_CFLAGS= CUDA_LDFLAGS= CUDA_LIBS= CUPTI_INC= CUPTI_CFLAGS= CUPTI_LDFLAGS= CUPTI_LIBS= NVCC= NVCCFLAGS= fi # Check whether --enable-gettid was given. if test "${enable_gettid+set}" = set; then : enableval=$enable_gettid; fi if test "x$enable_gettid" = xyes; then $as_echo "#define USE_GETTID 1" >>confdefs.h fi # cppflags for compiling eztrace # cppflags for compiling an application that uses eztrace # cppflags for compiling eztrace # cppflags for compiling an application that uses eztrace if test "$GTG_OUT_OF_ORDER" = "1" ; then GTG_OUT_OF_ORDER_TRUE= GTG_OUT_OF_ORDER_FALSE='#' else GTG_OUT_OF_ORDER_TRUE='#' GTG_OUT_OF_ORDER_FALSE= fi if test "x$openmp_found" = xyes; then OPENMP_FOUND_TRUE= OPENMP_FOUND_FALSE='#' else OPENMP_FOUND_TRUE='#' OPENMP_FOUND_FALSE= fi PAPI_ENABLED="$enable_api" if test "$enable_papi" = yes; then USE_PAPI_TRUE= USE_PAPI_FALSE='#' else USE_PAPI_TRUE='#' USE_PAPI_FALSE= fi if test "$enable_cuda" = yes; then USE_CUDA_TRUE= USE_CUDA_FALSE='#' else USE_CUDA_TRUE='#' USE_CUDA_FALSE= fi if test "$enable_mpi" = yes; then USE_MPI_TRUE= USE_MPI_FALSE='#' else USE_MPI_TRUE='#' USE_MPI_FALSE= fi if test "$use_mpi3" = yes; then USE_MPI3_TRUE= USE_MPI3_FALSE='#' else USE_MPI3_TRUE='#' USE_MPI3_FALSE= fi if test "$have_full_pthread" = yes; then USE_PTHREAD_TRUE= USE_PTHREAD_FALSE='#' else USE_PTHREAD_TRUE='#' USE_PTHREAD_FALSE= fi if test "$use_starpu" = yes; then USE_STARPU_TRUE= USE_STARPU_FALSE='#' else USE_STARPU_TRUE='#' USE_STARPU_FALSE= fi if test "x$use_litl" = xyes; then USE_LITL_TRUE= USE_LITL_FALSE='#' else USE_LITL_TRUE='#' USE_LITL_FALSE= fi if test "x$use_extern_litl" = xyes; then AMEXTERNLITL_TRUE= AMEXTERNLITL_FALSE='#' else AMEXTERNLITL_TRUE='#' AMEXTERNLITL_FALSE= fi if test "x$use_extern_gtg" = xyes; then AMEXTERNGTG_TRUE= AMEXTERNGTG_FALSE='#' else AMEXTERNGTG_TRUE='#' AMEXTERNGTG_FALSE= fi if test "x$arch_str" = "xX86_64"; then X86_64_TRUE= X86_64_FALSE='#' else X86_64_TRUE='#' X86_64_FALSE= fi if test "x$arch_str" = "xARM"; then ARM_TRUE= ARM_FALSE='#' else ARM_TRUE='#' ARM_FALSE= fi if test "$build_doc" = "yes"; then WITHDOC_TRUE= WITHDOC_FALSE='#' else WITHDOC_TRUE='#' WITHDOC_FALSE= fi subdirs="$subdirs extlib/opari2 extlib/litl" ac_config_files="$ac_config_files Makefile eztrace.pc extlib/Makefile src/core/Makefile src/modules/omp/Makefile src/modules/mpi/Makefile src/modules/cuda/Makefile src/modules/pthread/Makefile src/modules/stdio/Makefile src/modules/memory/Makefile src/modules/papi/Makefile src/modules/starpu/Makefile src/core/eztrace_create_plugin src/core/eztrace_plugin_generator src/core/input/Makefile.template src/modules/omp/eztrace_cc test/mpi/Makefile test/openmp/Makefile src/core/eztrace.c src/core/eztrace.preload src/core/eztrace_config.h test/static/Makefile test/stdio/Makefile test/memory/Makefile test/pthread/Makefile test/automake/Makefile test/automake/testcommon.h test/pptrace/automatic/Makefile doc/Makefile src/modules/omp/pomp-lib-dummy/Makefile" cat >confcache <<\_ACEOF # This file is a shell script that caches the results of configure # tests run on this system so they can be shared between configure # scripts and configure runs, see configure's option --config-cache. # It is not useful on other systems. If it contains results you don't # want to keep, you may remove or edit it. # # config.status only pays attention to the cache file if you give it # the --recheck option to rerun configure. # # `ac_cv_env_foo' variables (set or unset) will be overridden when # loading this file, other *unset* `ac_cv_foo' will be assigned the # following values. _ACEOF # The following way of writing the cache mishandles newlines in values, # but we know of no workaround that is simple, portable, and efficient. # So, we kill variables containing newlines. # Ultrix sh set writes to stderr and can't be redirected directly, # and sets the high bit in the cache file unless we assign to the vars. ( for ac_var in `(set) 2>&1 | sed -n 's/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'`; do eval ac_val=\$$ac_var case $ac_val in #( *${as_nl}*) case $ac_var in #( *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 $as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; esac case $ac_var in #( _ | IFS | as_nl) ;; #( BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( *) { eval $ac_var=; unset $ac_var;} ;; esac ;; esac done (set) 2>&1 | case $as_nl`(ac_space=' '; set) 2>&1` in #( *${as_nl}ac_space=\ *) # `set' does not quote correctly, so add quotes: double-quote # substitution turns \\\\ into \\, and sed turns \\ into \. sed -n \ "s/'/'\\\\''/g; s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p" ;; #( *) # `set' quotes correctly as required by POSIX, so do not add quotes. sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" ;; esac | sort ) | sed ' /^ac_cv_env_/b end t clear :clear s/^\([^=]*\)=\(.*[{}].*\)$/test "${\1+set}" = set || &/ t end s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/ :end' >>confcache if diff "$cache_file" confcache >/dev/null 2>&1; then :; else if test -w "$cache_file"; then if test "x$cache_file" != "x/dev/null"; then { $as_echo "$as_me:${as_lineno-$LINENO}: updating cache $cache_file" >&5 $as_echo "$as_me: updating cache $cache_file" >&6;} if test ! -f "$cache_file" || test -h "$cache_file"; then cat confcache >"$cache_file" else case $cache_file in #( */* | ?:*) mv -f confcache "$cache_file"$$ && mv -f "$cache_file"$$ "$cache_file" ;; #( *) mv -f confcache "$cache_file" ;; esac fi fi else { $as_echo "$as_me:${as_lineno-$LINENO}: not updating unwritable cache $cache_file" >&5 $as_echo "$as_me: not updating unwritable cache $cache_file" >&6;} fi fi rm -f confcache test "x$prefix" = xNONE && prefix=$ac_default_prefix # Let make expand exec_prefix. test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' # Transform confdefs.h into DEFS. # Protect against shell expansion while executing Makefile rules. # Protect against Makefile macro expansion. # # If the first sed substitution is executed (which looks for macros that # take arguments), then branch to the quote section. Otherwise, # look for a macro that doesn't take arguments. ac_script=' :mline /\\$/{ N s,\\\n,, b mline } t clear :clear s/^[ ]*#[ ]*define[ ][ ]*\([^ (][^ (]*([^)]*)\)[ ]*\(.*\)/-D\1=\2/g t quote s/^[ ]*#[ ]*define[ ][ ]*\([^ ][^ ]*\)[ ]*\(.*\)/-D\1=\2/g t quote b any :quote s/[ `~#$^&*(){}\\|;'\''"<>?]/\\&/g s/\[/\\&/g s/\]/\\&/g s/\$/$$/g H :any ${ g s/^\n// s/\n/ /g p } ' DEFS=`sed -n "$ac_script" confdefs.h` ac_libobjs= ac_ltlibobjs= U= for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue # 1. Remove the extension, and $U if already installed. ac_script='s/\$U\././;s/\.o$//;s/\.obj$//' ac_i=`$as_echo "$ac_i" | sed "$ac_script"` # 2. Prepend LIBOBJDIR. When used with automake>=1.10 LIBOBJDIR # will be set to the directory where LIBOBJS objects are built. as_fn_append ac_libobjs " \${LIBOBJDIR}$ac_i\$U.$ac_objext" as_fn_append ac_ltlibobjs " \${LIBOBJDIR}$ac_i"'$U.lo' done LIBOBJS=$ac_libobjs LTLIBOBJS=$ac_ltlibobjs { $as_echo "$as_me:${as_lineno-$LINENO}: checking that generated files are newer than configure" >&5 $as_echo_n "checking that generated files are newer than configure... " >&6; } if test -n "$am_sleep_pid"; then # Hide warnings about reused PIDs. wait $am_sleep_pid 2>/dev/null fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: done" >&5 $as_echo "done" >&6; } if test -n "$EXEEXT"; then am__EXEEXT_TRUE= am__EXEEXT_FALSE='#' else am__EXEEXT_TRUE='#' am__EXEEXT_FALSE= fi if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then as_fn_error $? "conditional \"AMDEP\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then as_fn_error $? "conditional \"am__fastdepCC\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${am__fastdepCXX_TRUE}" && test -z "${am__fastdepCXX_FALSE}"; then as_fn_error $? "conditional \"am__fastdepCXX\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${HAVE_DEMANGLE_TRUE}" && test -z "${HAVE_DEMANGLE_FALSE}"; then as_fn_error $? "conditional \"HAVE_DEMANGLE\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${HAVE_LIBOPCODE_TRUE}" && test -z "${HAVE_LIBOPCODE_FALSE}"; then as_fn_error $? "conditional \"HAVE_LIBOPCODE\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${USE_PPTRACE_TRUE}" && test -z "${USE_PPTRACE_FALSE}"; then as_fn_error $? "conditional \"USE_PPTRACE\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${HAVE_PDFLATEX_TRUE}" && test -z "${HAVE_PDFLATEX_FALSE}"; then as_fn_error $? "conditional \"HAVE_PDFLATEX\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${HAVE_LATEXMK_TRUE}" && test -z "${HAVE_LATEXMK_FALSE}"; then as_fn_error $? "conditional \"HAVE_LATEXMK\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${GTG_OUT_OF_ORDER_TRUE}" && test -z "${GTG_OUT_OF_ORDER_FALSE}"; then as_fn_error $? "conditional \"GTG_OUT_OF_ORDER\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${OPENMP_FOUND_TRUE}" && test -z "${OPENMP_FOUND_FALSE}"; then as_fn_error $? "conditional \"OPENMP_FOUND\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${USE_PAPI_TRUE}" && test -z "${USE_PAPI_FALSE}"; then as_fn_error $? "conditional \"USE_PAPI\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${USE_CUDA_TRUE}" && test -z "${USE_CUDA_FALSE}"; then as_fn_error $? "conditional \"USE_CUDA\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${USE_MPI_TRUE}" && test -z "${USE_MPI_FALSE}"; then as_fn_error $? "conditional \"USE_MPI\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${USE_MPI3_TRUE}" && test -z "${USE_MPI3_FALSE}"; then as_fn_error $? "conditional \"USE_MPI3\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${USE_PTHREAD_TRUE}" && test -z "${USE_PTHREAD_FALSE}"; then as_fn_error $? "conditional \"USE_PTHREAD\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${USE_STARPU_TRUE}" && test -z "${USE_STARPU_FALSE}"; then as_fn_error $? "conditional \"USE_STARPU\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${USE_LITL_TRUE}" && test -z "${USE_LITL_FALSE}"; then as_fn_error $? "conditional \"USE_LITL\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${AMEXTERNLITL_TRUE}" && test -z "${AMEXTERNLITL_FALSE}"; then as_fn_error $? "conditional \"AMEXTERNLITL\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${AMEXTERNGTG_TRUE}" && test -z "${AMEXTERNGTG_FALSE}"; then as_fn_error $? "conditional \"AMEXTERNGTG\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${X86_64_TRUE}" && test -z "${X86_64_FALSE}"; then as_fn_error $? "conditional \"X86_64\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${ARM_TRUE}" && test -z "${ARM_FALSE}"; then as_fn_error $? "conditional \"ARM\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${WITHDOC_TRUE}" && test -z "${WITHDOC_FALSE}"; then as_fn_error $? "conditional \"WITHDOC\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi : "${CONFIG_STATUS=./config.status}" ac_write_fail=0 ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files $CONFIG_STATUS" { $as_echo "$as_me:${as_lineno-$LINENO}: creating $CONFIG_STATUS" >&5 $as_echo "$as_me: creating $CONFIG_STATUS" >&6;} as_write_fail=0 cat >$CONFIG_STATUS <<_ASEOF || as_write_fail=1 #! $SHELL # Generated by $as_me. # Run this file to recreate the current configuration. # Compiler output produced by configure, useful for debugging # configure, is in config.log if it exists. debug=false ac_cs_recheck=false ac_cs_silent=false SHELL=\${CONFIG_SHELL-$SHELL} export SHELL _ASEOF cat >>$CONFIG_STATUS <<\_ASEOF || as_write_fail=1 ## -------------------- ## ## M4sh Initialization. ## ## -------------------- ## # Be more Bourne compatible DUALCASE=1; export DUALCASE # for MKS sh if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi as_nl=' ' export as_nl # Printing a long string crashes Solaris 7 /usr/bin/printf. as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo # Prefer a ksh shell builtin over an external printf program on Solaris, # but without wasting forks for bash or zsh. if test -z "$BASH_VERSION$ZSH_VERSION" \ && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='print -r --' as_echo_n='print -rn --' elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='printf %s\n' as_echo_n='printf %s' else if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' as_echo_n='/usr/ucb/echo -n' else as_echo_body='eval expr "X$1" : "X\\(.*\\)"' as_echo_n_body='eval arg=$1; case $arg in #( *"$as_nl"*) expr "X$arg" : "X\\(.*\\)$as_nl"; arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; esac; expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" ' export as_echo_n_body as_echo_n='sh -c $as_echo_n_body as_echo' fi export as_echo_body as_echo='sh -c $as_echo_body as_echo' fi # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi # IFS # We need space, tab and new line, in precisely that order. Quoting is # there to prevent editors from complaining about space-tab. # (If _AS_PATH_WALK were called with IFS unset, it would disable word # splitting by setting IFS to empty value.) IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break done IFS=$as_save_IFS ;; esac # We did not find ourselves, most probably we were run as `sh COMMAND' # in which case we are not to be found in the path. if test "x$as_myself" = x; then as_myself=$0 fi if test ! -f "$as_myself"; then $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 exit 1 fi # Unset variables that we do not need and which cause bugs (e.g. in # pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" # suppresses any "Segmentation fault" message there. '((' could # trigger a bug in pdksh 5.2.14. for as_var in BASH_ENV ENV MAIL MAILPATH do eval test x\${$as_var+set} = xset \ && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : done PS1='$ ' PS2='> ' PS4='+ ' # NLS nuisances. LC_ALL=C export LC_ALL LANGUAGE=C export LANGUAGE # CDPATH. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH # as_fn_error STATUS ERROR [LINENO LOG_FD] # ---------------------------------------- # Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are # provided, also output the error to LOG_FD, referencing LINENO. Then exit the # script with STATUS, using 1 if that was 0. as_fn_error () { as_status=$1; test $as_status -eq 0 && as_status=1 if test "$4"; then as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack $as_echo "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 fi $as_echo "$as_me: error: $2" >&2 as_fn_exit $as_status } # as_fn_error # as_fn_set_status STATUS # ----------------------- # Set $? to STATUS, without forking. as_fn_set_status () { return $1 } # as_fn_set_status # as_fn_exit STATUS # ----------------- # Exit the shell with STATUS, even in a "trap 0" or "set -e" context. as_fn_exit () { set +e as_fn_set_status $1 exit $1 } # as_fn_exit # as_fn_unset VAR # --------------- # Portably unset VAR. as_fn_unset () { { eval $1=; unset $1;} } as_unset=as_fn_unset # as_fn_append VAR VALUE # ---------------------- # Append the text in VALUE to the end of the definition contained in VAR. Take # advantage of any shell optimizations that allow amortized linear growth over # repeated appends, instead of the typical quadratic growth present in naive # implementations. if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : eval 'as_fn_append () { eval $1+=\$2 }' else as_fn_append () { eval $1=\$$1\$2 } fi # as_fn_append # as_fn_arith ARG... # ------------------ # Perform arithmetic evaluation on the ARGs, and store the result in the # global $as_val. Take advantage of shells that can avoid forks. The arguments # must be portable across $(()) and expr. if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : eval 'as_fn_arith () { as_val=$(( $* )) }' else as_fn_arith () { as_val=`expr "$@" || test $? -eq 1` } fi # as_fn_arith if expr a : '\(a\)' >/dev/null 2>&1 && test "X`expr 00001 : '.*\(...\)'`" = X001; then as_expr=expr else as_expr=false fi if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then as_basename=basename else as_basename=false fi if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then as_dirname=dirname else as_dirname=false fi as_me=`$as_basename -- "$0" || $as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ X"$0" : 'X\(//\)$' \| \ X"$0" : 'X\(/\)' \| . 2>/dev/null || $as_echo X/"$0" | sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/ q } /^X\/\(\/\/\)$/{ s//\1/ q } /^X\/\(\/\).*/{ s//\1/ q } s/.*/./; q'` # Avoid depending upon Character Ranges. as_cr_letters='abcdefghijklmnopqrstuvwxyz' as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' as_cr_Letters=$as_cr_letters$as_cr_LETTERS as_cr_digits='0123456789' as_cr_alnum=$as_cr_Letters$as_cr_digits ECHO_C= ECHO_N= ECHO_T= case `echo -n x` in #((((( -n*) case `echo 'xy\c'` in *c*) ECHO_T=' ';; # ECHO_T is single tab character. xy) ECHO_C='\c';; *) echo `echo ksh88 bug on AIX 6.1` > /dev/null ECHO_T=' ';; esac;; *) ECHO_N='-n';; esac rm -f conf$$ conf$$.exe conf$$.file if test -d conf$$.dir; then rm -f conf$$.dir/conf$$.file else rm -f conf$$.dir mkdir conf$$.dir 2>/dev/null fi if (echo >conf$$.file) 2>/dev/null; then if ln -s conf$$.file conf$$ 2>/dev/null; then as_ln_s='ln -s' # ... but there are two gotchas: # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. # In both cases, we have to default to `cp -pR'. ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || as_ln_s='cp -pR' elif ln conf$$.file conf$$ 2>/dev/null; then as_ln_s=ln else as_ln_s='cp -pR' fi else as_ln_s='cp -pR' fi rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file rmdir conf$$.dir 2>/dev/null # as_fn_mkdir_p # ------------- # Create "$as_dir" as a directory, including parents if necessary. as_fn_mkdir_p () { case $as_dir in #( -*) as_dir=./$as_dir;; esac test -d "$as_dir" || eval $as_mkdir_p || { as_dirs= while :; do case $as_dir in #( *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( *) as_qdir=$as_dir;; esac as_dirs="'$as_qdir' $as_dirs" as_dir=`$as_dirname -- "$as_dir" || $as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_dir" : 'X\(//\)[^/]' \| \ X"$as_dir" : 'X\(//\)$' \| \ X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$as_dir" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` test -d "$as_dir" && break done test -z "$as_dirs" || eval "mkdir $as_dirs" } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" } # as_fn_mkdir_p if mkdir -p . 2>/dev/null; then as_mkdir_p='mkdir -p "$as_dir"' else test -d ./-p && rmdir ./-p as_mkdir_p=false fi # as_fn_executable_p FILE # ----------------------- # Test if FILE is an executable regular file. as_fn_executable_p () { test -f "$1" && test -x "$1" } # as_fn_executable_p as_test_x='test -x' as_executable_p=as_fn_executable_p # Sed expression to map a string onto a valid CPP name. as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" # Sed expression to map a string onto a valid variable name. as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" exec 6>&1 ## ----------------------------------- ## ## Main body of $CONFIG_STATUS script. ## ## ----------------------------------- ## _ASEOF test $as_write_fail = 0 && chmod +x $CONFIG_STATUS || ac_write_fail=1 cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # Save the log message, to keep $0 and so on meaningful, and to # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" This file was extended by eztrace $as_me 1.1-2, which was generated by GNU Autoconf 2.69. Invocation command line was CONFIG_FILES = $CONFIG_FILES CONFIG_HEADERS = $CONFIG_HEADERS CONFIG_LINKS = $CONFIG_LINKS CONFIG_COMMANDS = $CONFIG_COMMANDS $ $0 $@ on `(hostname || uname -n) 2>/dev/null | sed 1q` " _ACEOF case $ac_config_files in *" "*) set x $ac_config_files; shift; ac_config_files=$*;; esac cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 # Files that config.status was made for. config_files="$ac_config_files" config_commands="$ac_config_commands" _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 ac_cs_usage="\ \`$as_me' instantiates files and other configuration actions from templates according to the current configuration. Unless the files and actions are specified as TAGs, all are instantiated by default. Usage: $0 [OPTION]... [TAG]... -h, --help print this help, then exit -V, --version print version number and configuration settings, then exit --config print configuration, then exit -q, --quiet, --silent do not print progress messages -d, --debug don't remove temporary files --recheck update $as_me by reconfiguring in the same conditions --file=FILE[:TEMPLATE] instantiate the configuration file FILE Configuration files: $config_files Configuration commands: $config_commands Report bugs to ." _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" ac_cs_version="\\ eztrace config.status 1.1-2 configured by $0, generated by GNU Autoconf 2.69, with options \\"\$ac_cs_config\\" Copyright (C) 2012 Free Software Foundation, Inc. This config.status script is free software; the Free Software Foundation gives unlimited permission to copy, distribute and modify it." ac_pwd='$ac_pwd' srcdir='$srcdir' INSTALL='$INSTALL' MKDIR_P='$MKDIR_P' AWK='$AWK' test -n "\$AWK" || AWK=awk _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # The default lists apply if the user does not specify any file. ac_need_defaults=: while test $# != 0 do case $1 in --*=?*) ac_option=`expr "X$1" : 'X\([^=]*\)='` ac_optarg=`expr "X$1" : 'X[^=]*=\(.*\)'` ac_shift=: ;; --*=) ac_option=`expr "X$1" : 'X\([^=]*\)='` ac_optarg= ac_shift=: ;; *) ac_option=$1 ac_optarg=$2 ac_shift=shift ;; esac case $ac_option in # Handling of the options. -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) ac_cs_recheck=: ;; --version | --versio | --versi | --vers | --ver | --ve | --v | -V ) $as_echo "$ac_cs_version"; exit ;; --config | --confi | --conf | --con | --co | --c ) $as_echo "$ac_cs_config"; exit ;; --debug | --debu | --deb | --de | --d | -d ) debug=: ;; --file | --fil | --fi | --f ) $ac_shift case $ac_optarg in *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; '') as_fn_error $? "missing file argument" ;; esac as_fn_append CONFIG_FILES " '$ac_optarg'" ac_need_defaults=false;; --he | --h | --help | --hel | -h ) $as_echo "$ac_cs_usage"; exit ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil | --si | --s) ac_cs_silent=: ;; # This is an error. -*) as_fn_error $? "unrecognized option: \`$1' Try \`$0 --help' for more information." ;; *) as_fn_append ac_config_targets " $1" ac_need_defaults=false ;; esac shift done ac_configure_extra_args= if $ac_cs_silent; then exec 6>/dev/null ac_configure_extra_args="$ac_configure_extra_args --silent" fi _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 if \$ac_cs_recheck; then set X $SHELL '$0' $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion shift \$as_echo "running CONFIG_SHELL=$SHELL \$*" >&6 CONFIG_SHELL='$SHELL' export CONFIG_SHELL exec "\$@" fi _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 exec 5>>config.log { echo sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX ## Running $as_me. ## _ASBOX $as_echo "$ac_log" } >&5 _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 # # INIT-COMMANDS # AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir" # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH sed_quote_subst='$sed_quote_subst' double_quote_subst='$double_quote_subst' delay_variable_subst='$delay_variable_subst' macro_version='`$ECHO "$macro_version" | $SED "$delay_single_quote_subst"`' macro_revision='`$ECHO "$macro_revision" | $SED "$delay_single_quote_subst"`' enable_shared='`$ECHO "$enable_shared" | $SED "$delay_single_quote_subst"`' enable_static='`$ECHO "$enable_static" | $SED "$delay_single_quote_subst"`' pic_mode='`$ECHO "$pic_mode" | $SED "$delay_single_quote_subst"`' enable_fast_install='`$ECHO "$enable_fast_install" | $SED "$delay_single_quote_subst"`' SHELL='`$ECHO "$SHELL" | $SED "$delay_single_quote_subst"`' ECHO='`$ECHO "$ECHO" | $SED "$delay_single_quote_subst"`' PATH_SEPARATOR='`$ECHO "$PATH_SEPARATOR" | $SED "$delay_single_quote_subst"`' host_alias='`$ECHO "$host_alias" | $SED "$delay_single_quote_subst"`' host='`$ECHO "$host" | $SED "$delay_single_quote_subst"`' host_os='`$ECHO "$host_os" | $SED "$delay_single_quote_subst"`' build_alias='`$ECHO "$build_alias" | $SED "$delay_single_quote_subst"`' build='`$ECHO "$build" | $SED "$delay_single_quote_subst"`' build_os='`$ECHO "$build_os" | $SED "$delay_single_quote_subst"`' SED='`$ECHO "$SED" | $SED "$delay_single_quote_subst"`' Xsed='`$ECHO "$Xsed" | $SED "$delay_single_quote_subst"`' GREP='`$ECHO "$GREP" | $SED "$delay_single_quote_subst"`' EGREP='`$ECHO "$EGREP" | $SED "$delay_single_quote_subst"`' FGREP='`$ECHO "$FGREP" | $SED "$delay_single_quote_subst"`' LD='`$ECHO "$LD" | $SED "$delay_single_quote_subst"`' NM='`$ECHO "$NM" | $SED "$delay_single_quote_subst"`' LN_S='`$ECHO "$LN_S" | $SED "$delay_single_quote_subst"`' max_cmd_len='`$ECHO "$max_cmd_len" | $SED "$delay_single_quote_subst"`' ac_objext='`$ECHO "$ac_objext" | $SED "$delay_single_quote_subst"`' exeext='`$ECHO "$exeext" | $SED "$delay_single_quote_subst"`' lt_unset='`$ECHO "$lt_unset" | $SED "$delay_single_quote_subst"`' lt_SP2NL='`$ECHO "$lt_SP2NL" | $SED "$delay_single_quote_subst"`' lt_NL2SP='`$ECHO "$lt_NL2SP" | $SED "$delay_single_quote_subst"`' lt_cv_to_host_file_cmd='`$ECHO "$lt_cv_to_host_file_cmd" | $SED "$delay_single_quote_subst"`' lt_cv_to_tool_file_cmd='`$ECHO "$lt_cv_to_tool_file_cmd" | $SED "$delay_single_quote_subst"`' reload_flag='`$ECHO "$reload_flag" | $SED "$delay_single_quote_subst"`' reload_cmds='`$ECHO "$reload_cmds" | $SED "$delay_single_quote_subst"`' OBJDUMP='`$ECHO "$OBJDUMP" | $SED "$delay_single_quote_subst"`' deplibs_check_method='`$ECHO "$deplibs_check_method" | $SED "$delay_single_quote_subst"`' file_magic_cmd='`$ECHO "$file_magic_cmd" | $SED "$delay_single_quote_subst"`' file_magic_glob='`$ECHO "$file_magic_glob" | $SED "$delay_single_quote_subst"`' want_nocaseglob='`$ECHO "$want_nocaseglob" | $SED "$delay_single_quote_subst"`' DLLTOOL='`$ECHO "$DLLTOOL" | $SED "$delay_single_quote_subst"`' sharedlib_from_linklib_cmd='`$ECHO "$sharedlib_from_linklib_cmd" | $SED "$delay_single_quote_subst"`' AR='`$ECHO "$AR" | $SED "$delay_single_quote_subst"`' AR_FLAGS='`$ECHO "$AR_FLAGS" | $SED "$delay_single_quote_subst"`' archiver_list_spec='`$ECHO "$archiver_list_spec" | $SED "$delay_single_quote_subst"`' STRIP='`$ECHO "$STRIP" | $SED "$delay_single_quote_subst"`' RANLIB='`$ECHO "$RANLIB" | $SED "$delay_single_quote_subst"`' old_postinstall_cmds='`$ECHO "$old_postinstall_cmds" | $SED "$delay_single_quote_subst"`' old_postuninstall_cmds='`$ECHO "$old_postuninstall_cmds" | $SED "$delay_single_quote_subst"`' old_archive_cmds='`$ECHO "$old_archive_cmds" | $SED "$delay_single_quote_subst"`' lock_old_archive_extraction='`$ECHO "$lock_old_archive_extraction" | $SED "$delay_single_quote_subst"`' CC='`$ECHO "$CC" | $SED "$delay_single_quote_subst"`' CFLAGS='`$ECHO "$CFLAGS" | $SED "$delay_single_quote_subst"`' compiler='`$ECHO "$compiler" | $SED "$delay_single_quote_subst"`' GCC='`$ECHO "$GCC" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_pipe='`$ECHO "$lt_cv_sys_global_symbol_pipe" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_cdecl='`$ECHO "$lt_cv_sys_global_symbol_to_cdecl" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_c_name_address='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_c_name_address_lib_prefix='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address_lib_prefix" | $SED "$delay_single_quote_subst"`' nm_file_list_spec='`$ECHO "$nm_file_list_spec" | $SED "$delay_single_quote_subst"`' lt_sysroot='`$ECHO "$lt_sysroot" | $SED "$delay_single_quote_subst"`' objdir='`$ECHO "$objdir" | $SED "$delay_single_quote_subst"`' MAGIC_CMD='`$ECHO "$MAGIC_CMD" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_no_builtin_flag='`$ECHO "$lt_prog_compiler_no_builtin_flag" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_pic='`$ECHO "$lt_prog_compiler_pic" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_wl='`$ECHO "$lt_prog_compiler_wl" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_static='`$ECHO "$lt_prog_compiler_static" | $SED "$delay_single_quote_subst"`' lt_cv_prog_compiler_c_o='`$ECHO "$lt_cv_prog_compiler_c_o" | $SED "$delay_single_quote_subst"`' need_locks='`$ECHO "$need_locks" | $SED "$delay_single_quote_subst"`' MANIFEST_TOOL='`$ECHO "$MANIFEST_TOOL" | $SED "$delay_single_quote_subst"`' DSYMUTIL='`$ECHO "$DSYMUTIL" | $SED "$delay_single_quote_subst"`' NMEDIT='`$ECHO "$NMEDIT" | $SED "$delay_single_quote_subst"`' LIPO='`$ECHO "$LIPO" | $SED "$delay_single_quote_subst"`' OTOOL='`$ECHO "$OTOOL" | $SED "$delay_single_quote_subst"`' OTOOL64='`$ECHO "$OTOOL64" | $SED "$delay_single_quote_subst"`' libext='`$ECHO "$libext" | $SED "$delay_single_quote_subst"`' shrext_cmds='`$ECHO "$shrext_cmds" | $SED "$delay_single_quote_subst"`' extract_expsyms_cmds='`$ECHO "$extract_expsyms_cmds" | $SED "$delay_single_quote_subst"`' archive_cmds_need_lc='`$ECHO "$archive_cmds_need_lc" | $SED "$delay_single_quote_subst"`' enable_shared_with_static_runtimes='`$ECHO "$enable_shared_with_static_runtimes" | $SED "$delay_single_quote_subst"`' export_dynamic_flag_spec='`$ECHO "$export_dynamic_flag_spec" | $SED "$delay_single_quote_subst"`' whole_archive_flag_spec='`$ECHO "$whole_archive_flag_spec" | $SED "$delay_single_quote_subst"`' compiler_needs_object='`$ECHO "$compiler_needs_object" | $SED "$delay_single_quote_subst"`' old_archive_from_new_cmds='`$ECHO "$old_archive_from_new_cmds" | $SED "$delay_single_quote_subst"`' old_archive_from_expsyms_cmds='`$ECHO "$old_archive_from_expsyms_cmds" | $SED "$delay_single_quote_subst"`' archive_cmds='`$ECHO "$archive_cmds" | $SED "$delay_single_quote_subst"`' archive_expsym_cmds='`$ECHO "$archive_expsym_cmds" | $SED "$delay_single_quote_subst"`' module_cmds='`$ECHO "$module_cmds" | $SED "$delay_single_quote_subst"`' module_expsym_cmds='`$ECHO "$module_expsym_cmds" | $SED "$delay_single_quote_subst"`' with_gnu_ld='`$ECHO "$with_gnu_ld" | $SED "$delay_single_quote_subst"`' allow_undefined_flag='`$ECHO "$allow_undefined_flag" | $SED "$delay_single_quote_subst"`' no_undefined_flag='`$ECHO "$no_undefined_flag" | $SED "$delay_single_quote_subst"`' hardcode_libdir_flag_spec='`$ECHO "$hardcode_libdir_flag_spec" | $SED "$delay_single_quote_subst"`' hardcode_libdir_separator='`$ECHO "$hardcode_libdir_separator" | $SED "$delay_single_quote_subst"`' hardcode_direct='`$ECHO "$hardcode_direct" | $SED "$delay_single_quote_subst"`' hardcode_direct_absolute='`$ECHO "$hardcode_direct_absolute" | $SED "$delay_single_quote_subst"`' hardcode_minus_L='`$ECHO "$hardcode_minus_L" | $SED "$delay_single_quote_subst"`' hardcode_shlibpath_var='`$ECHO "$hardcode_shlibpath_var" | $SED "$delay_single_quote_subst"`' hardcode_automatic='`$ECHO "$hardcode_automatic" | $SED "$delay_single_quote_subst"`' inherit_rpath='`$ECHO "$inherit_rpath" | $SED "$delay_single_quote_subst"`' link_all_deplibs='`$ECHO "$link_all_deplibs" | $SED "$delay_single_quote_subst"`' always_export_symbols='`$ECHO "$always_export_symbols" | $SED "$delay_single_quote_subst"`' export_symbols_cmds='`$ECHO "$export_symbols_cmds" | $SED "$delay_single_quote_subst"`' exclude_expsyms='`$ECHO "$exclude_expsyms" | $SED "$delay_single_quote_subst"`' include_expsyms='`$ECHO "$include_expsyms" | $SED "$delay_single_quote_subst"`' prelink_cmds='`$ECHO "$prelink_cmds" | $SED "$delay_single_quote_subst"`' postlink_cmds='`$ECHO "$postlink_cmds" | $SED "$delay_single_quote_subst"`' file_list_spec='`$ECHO "$file_list_spec" | $SED "$delay_single_quote_subst"`' variables_saved_for_relink='`$ECHO "$variables_saved_for_relink" | $SED "$delay_single_quote_subst"`' need_lib_prefix='`$ECHO "$need_lib_prefix" | $SED "$delay_single_quote_subst"`' need_version='`$ECHO "$need_version" | $SED "$delay_single_quote_subst"`' version_type='`$ECHO "$version_type" | $SED "$delay_single_quote_subst"`' runpath_var='`$ECHO "$runpath_var" | $SED "$delay_single_quote_subst"`' shlibpath_var='`$ECHO "$shlibpath_var" | $SED "$delay_single_quote_subst"`' shlibpath_overrides_runpath='`$ECHO "$shlibpath_overrides_runpath" | $SED "$delay_single_quote_subst"`' libname_spec='`$ECHO "$libname_spec" | $SED "$delay_single_quote_subst"`' library_names_spec='`$ECHO "$library_names_spec" | $SED "$delay_single_quote_subst"`' soname_spec='`$ECHO "$soname_spec" | $SED "$delay_single_quote_subst"`' install_override_mode='`$ECHO "$install_override_mode" | $SED "$delay_single_quote_subst"`' postinstall_cmds='`$ECHO "$postinstall_cmds" | $SED "$delay_single_quote_subst"`' postuninstall_cmds='`$ECHO "$postuninstall_cmds" | $SED "$delay_single_quote_subst"`' finish_cmds='`$ECHO "$finish_cmds" | $SED "$delay_single_quote_subst"`' finish_eval='`$ECHO "$finish_eval" | $SED "$delay_single_quote_subst"`' hardcode_into_libs='`$ECHO "$hardcode_into_libs" | $SED "$delay_single_quote_subst"`' sys_lib_search_path_spec='`$ECHO "$sys_lib_search_path_spec" | $SED "$delay_single_quote_subst"`' sys_lib_dlsearch_path_spec='`$ECHO "$sys_lib_dlsearch_path_spec" | $SED "$delay_single_quote_subst"`' hardcode_action='`$ECHO "$hardcode_action" | $SED "$delay_single_quote_subst"`' enable_dlopen='`$ECHO "$enable_dlopen" | $SED "$delay_single_quote_subst"`' enable_dlopen_self='`$ECHO "$enable_dlopen_self" | $SED "$delay_single_quote_subst"`' enable_dlopen_self_static='`$ECHO "$enable_dlopen_self_static" | $SED "$delay_single_quote_subst"`' old_striplib='`$ECHO "$old_striplib" | $SED "$delay_single_quote_subst"`' striplib='`$ECHO "$striplib" | $SED "$delay_single_quote_subst"`' compiler_lib_search_dirs='`$ECHO "$compiler_lib_search_dirs" | $SED "$delay_single_quote_subst"`' predep_objects='`$ECHO "$predep_objects" | $SED "$delay_single_quote_subst"`' postdep_objects='`$ECHO "$postdep_objects" | $SED "$delay_single_quote_subst"`' predeps='`$ECHO "$predeps" | $SED "$delay_single_quote_subst"`' postdeps='`$ECHO "$postdeps" | $SED "$delay_single_quote_subst"`' compiler_lib_search_path='`$ECHO "$compiler_lib_search_path" | $SED "$delay_single_quote_subst"`' LD_CXX='`$ECHO "$LD_CXX" | $SED "$delay_single_quote_subst"`' LD_FC='`$ECHO "$LD_FC" | $SED "$delay_single_quote_subst"`' reload_flag_CXX='`$ECHO "$reload_flag_CXX" | $SED "$delay_single_quote_subst"`' reload_flag_FC='`$ECHO "$reload_flag_FC" | $SED "$delay_single_quote_subst"`' reload_cmds_CXX='`$ECHO "$reload_cmds_CXX" | $SED "$delay_single_quote_subst"`' reload_cmds_FC='`$ECHO "$reload_cmds_FC" | $SED "$delay_single_quote_subst"`' old_archive_cmds_CXX='`$ECHO "$old_archive_cmds_CXX" | $SED "$delay_single_quote_subst"`' old_archive_cmds_FC='`$ECHO "$old_archive_cmds_FC" | $SED "$delay_single_quote_subst"`' compiler_CXX='`$ECHO "$compiler_CXX" | $SED "$delay_single_quote_subst"`' compiler_FC='`$ECHO "$compiler_FC" | $SED "$delay_single_quote_subst"`' GCC_CXX='`$ECHO "$GCC_CXX" | $SED "$delay_single_quote_subst"`' GCC_FC='`$ECHO "$GCC_FC" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_no_builtin_flag_CXX='`$ECHO "$lt_prog_compiler_no_builtin_flag_CXX" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_no_builtin_flag_FC='`$ECHO "$lt_prog_compiler_no_builtin_flag_FC" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_pic_CXX='`$ECHO "$lt_prog_compiler_pic_CXX" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_pic_FC='`$ECHO "$lt_prog_compiler_pic_FC" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_wl_CXX='`$ECHO "$lt_prog_compiler_wl_CXX" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_wl_FC='`$ECHO "$lt_prog_compiler_wl_FC" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_static_CXX='`$ECHO "$lt_prog_compiler_static_CXX" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_static_FC='`$ECHO "$lt_prog_compiler_static_FC" | $SED "$delay_single_quote_subst"`' lt_cv_prog_compiler_c_o_CXX='`$ECHO "$lt_cv_prog_compiler_c_o_CXX" | $SED "$delay_single_quote_subst"`' lt_cv_prog_compiler_c_o_FC='`$ECHO "$lt_cv_prog_compiler_c_o_FC" | $SED "$delay_single_quote_subst"`' archive_cmds_need_lc_CXX='`$ECHO "$archive_cmds_need_lc_CXX" | $SED "$delay_single_quote_subst"`' archive_cmds_need_lc_FC='`$ECHO "$archive_cmds_need_lc_FC" | $SED "$delay_single_quote_subst"`' enable_shared_with_static_runtimes_CXX='`$ECHO "$enable_shared_with_static_runtimes_CXX" | $SED "$delay_single_quote_subst"`' enable_shared_with_static_runtimes_FC='`$ECHO "$enable_shared_with_static_runtimes_FC" | $SED "$delay_single_quote_subst"`' export_dynamic_flag_spec_CXX='`$ECHO "$export_dynamic_flag_spec_CXX" | $SED "$delay_single_quote_subst"`' export_dynamic_flag_spec_FC='`$ECHO "$export_dynamic_flag_spec_FC" | $SED "$delay_single_quote_subst"`' whole_archive_flag_spec_CXX='`$ECHO "$whole_archive_flag_spec_CXX" | $SED "$delay_single_quote_subst"`' whole_archive_flag_spec_FC='`$ECHO "$whole_archive_flag_spec_FC" | $SED "$delay_single_quote_subst"`' compiler_needs_object_CXX='`$ECHO "$compiler_needs_object_CXX" | $SED "$delay_single_quote_subst"`' compiler_needs_object_FC='`$ECHO "$compiler_needs_object_FC" | $SED "$delay_single_quote_subst"`' old_archive_from_new_cmds_CXX='`$ECHO "$old_archive_from_new_cmds_CXX" | $SED "$delay_single_quote_subst"`' old_archive_from_new_cmds_FC='`$ECHO "$old_archive_from_new_cmds_FC" | $SED "$delay_single_quote_subst"`' old_archive_from_expsyms_cmds_CXX='`$ECHO "$old_archive_from_expsyms_cmds_CXX" | $SED "$delay_single_quote_subst"`' old_archive_from_expsyms_cmds_FC='`$ECHO "$old_archive_from_expsyms_cmds_FC" | $SED "$delay_single_quote_subst"`' archive_cmds_CXX='`$ECHO "$archive_cmds_CXX" | $SED "$delay_single_quote_subst"`' archive_cmds_FC='`$ECHO "$archive_cmds_FC" | $SED "$delay_single_quote_subst"`' archive_expsym_cmds_CXX='`$ECHO "$archive_expsym_cmds_CXX" | $SED "$delay_single_quote_subst"`' archive_expsym_cmds_FC='`$ECHO "$archive_expsym_cmds_FC" | $SED "$delay_single_quote_subst"`' module_cmds_CXX='`$ECHO "$module_cmds_CXX" | $SED "$delay_single_quote_subst"`' module_cmds_FC='`$ECHO "$module_cmds_FC" | $SED "$delay_single_quote_subst"`' module_expsym_cmds_CXX='`$ECHO "$module_expsym_cmds_CXX" | $SED "$delay_single_quote_subst"`' module_expsym_cmds_FC='`$ECHO "$module_expsym_cmds_FC" | $SED "$delay_single_quote_subst"`' with_gnu_ld_CXX='`$ECHO "$with_gnu_ld_CXX" | $SED "$delay_single_quote_subst"`' with_gnu_ld_FC='`$ECHO "$with_gnu_ld_FC" | $SED "$delay_single_quote_subst"`' allow_undefined_flag_CXX='`$ECHO "$allow_undefined_flag_CXX" | $SED "$delay_single_quote_subst"`' allow_undefined_flag_FC='`$ECHO "$allow_undefined_flag_FC" | $SED "$delay_single_quote_subst"`' no_undefined_flag_CXX='`$ECHO "$no_undefined_flag_CXX" | $SED "$delay_single_quote_subst"`' no_undefined_flag_FC='`$ECHO "$no_undefined_flag_FC" | $SED "$delay_single_quote_subst"`' hardcode_libdir_flag_spec_CXX='`$ECHO "$hardcode_libdir_flag_spec_CXX" | $SED "$delay_single_quote_subst"`' hardcode_libdir_flag_spec_FC='`$ECHO "$hardcode_libdir_flag_spec_FC" | $SED "$delay_single_quote_subst"`' hardcode_libdir_separator_CXX='`$ECHO "$hardcode_libdir_separator_CXX" | $SED "$delay_single_quote_subst"`' hardcode_libdir_separator_FC='`$ECHO "$hardcode_libdir_separator_FC" | $SED "$delay_single_quote_subst"`' hardcode_direct_CXX='`$ECHO "$hardcode_direct_CXX" | $SED "$delay_single_quote_subst"`' hardcode_direct_FC='`$ECHO "$hardcode_direct_FC" | $SED "$delay_single_quote_subst"`' hardcode_direct_absolute_CXX='`$ECHO "$hardcode_direct_absolute_CXX" | $SED "$delay_single_quote_subst"`' hardcode_direct_absolute_FC='`$ECHO "$hardcode_direct_absolute_FC" | $SED "$delay_single_quote_subst"`' hardcode_minus_L_CXX='`$ECHO "$hardcode_minus_L_CXX" | $SED "$delay_single_quote_subst"`' hardcode_minus_L_FC='`$ECHO "$hardcode_minus_L_FC" | $SED "$delay_single_quote_subst"`' hardcode_shlibpath_var_CXX='`$ECHO "$hardcode_shlibpath_var_CXX" | $SED "$delay_single_quote_subst"`' hardcode_shlibpath_var_FC='`$ECHO "$hardcode_shlibpath_var_FC" | $SED "$delay_single_quote_subst"`' hardcode_automatic_CXX='`$ECHO "$hardcode_automatic_CXX" | $SED "$delay_single_quote_subst"`' hardcode_automatic_FC='`$ECHO "$hardcode_automatic_FC" | $SED "$delay_single_quote_subst"`' inherit_rpath_CXX='`$ECHO "$inherit_rpath_CXX" | $SED "$delay_single_quote_subst"`' inherit_rpath_FC='`$ECHO "$inherit_rpath_FC" | $SED "$delay_single_quote_subst"`' link_all_deplibs_CXX='`$ECHO "$link_all_deplibs_CXX" | $SED "$delay_single_quote_subst"`' link_all_deplibs_FC='`$ECHO "$link_all_deplibs_FC" | $SED "$delay_single_quote_subst"`' always_export_symbols_CXX='`$ECHO "$always_export_symbols_CXX" | $SED "$delay_single_quote_subst"`' always_export_symbols_FC='`$ECHO "$always_export_symbols_FC" | $SED "$delay_single_quote_subst"`' export_symbols_cmds_CXX='`$ECHO "$export_symbols_cmds_CXX" | $SED "$delay_single_quote_subst"`' export_symbols_cmds_FC='`$ECHO "$export_symbols_cmds_FC" | $SED "$delay_single_quote_subst"`' exclude_expsyms_CXX='`$ECHO "$exclude_expsyms_CXX" | $SED "$delay_single_quote_subst"`' exclude_expsyms_FC='`$ECHO "$exclude_expsyms_FC" | $SED "$delay_single_quote_subst"`' include_expsyms_CXX='`$ECHO "$include_expsyms_CXX" | $SED "$delay_single_quote_subst"`' include_expsyms_FC='`$ECHO "$include_expsyms_FC" | $SED "$delay_single_quote_subst"`' prelink_cmds_CXX='`$ECHO "$prelink_cmds_CXX" | $SED "$delay_single_quote_subst"`' prelink_cmds_FC='`$ECHO "$prelink_cmds_FC" | $SED "$delay_single_quote_subst"`' postlink_cmds_CXX='`$ECHO "$postlink_cmds_CXX" | $SED "$delay_single_quote_subst"`' postlink_cmds_FC='`$ECHO "$postlink_cmds_FC" | $SED "$delay_single_quote_subst"`' file_list_spec_CXX='`$ECHO "$file_list_spec_CXX" | $SED "$delay_single_quote_subst"`' file_list_spec_FC='`$ECHO "$file_list_spec_FC" | $SED "$delay_single_quote_subst"`' hardcode_action_CXX='`$ECHO "$hardcode_action_CXX" | $SED "$delay_single_quote_subst"`' hardcode_action_FC='`$ECHO "$hardcode_action_FC" | $SED "$delay_single_quote_subst"`' compiler_lib_search_dirs_CXX='`$ECHO "$compiler_lib_search_dirs_CXX" | $SED "$delay_single_quote_subst"`' compiler_lib_search_dirs_FC='`$ECHO "$compiler_lib_search_dirs_FC" | $SED "$delay_single_quote_subst"`' predep_objects_CXX='`$ECHO "$predep_objects_CXX" | $SED "$delay_single_quote_subst"`' predep_objects_FC='`$ECHO "$predep_objects_FC" | $SED "$delay_single_quote_subst"`' postdep_objects_CXX='`$ECHO "$postdep_objects_CXX" | $SED "$delay_single_quote_subst"`' postdep_objects_FC='`$ECHO "$postdep_objects_FC" | $SED "$delay_single_quote_subst"`' predeps_CXX='`$ECHO "$predeps_CXX" | $SED "$delay_single_quote_subst"`' predeps_FC='`$ECHO "$predeps_FC" | $SED "$delay_single_quote_subst"`' postdeps_CXX='`$ECHO "$postdeps_CXX" | $SED "$delay_single_quote_subst"`' postdeps_FC='`$ECHO "$postdeps_FC" | $SED "$delay_single_quote_subst"`' compiler_lib_search_path_CXX='`$ECHO "$compiler_lib_search_path_CXX" | $SED "$delay_single_quote_subst"`' compiler_lib_search_path_FC='`$ECHO "$compiler_lib_search_path_FC" | $SED "$delay_single_quote_subst"`' LTCC='$LTCC' LTCFLAGS='$LTCFLAGS' compiler='$compiler_DEFAULT' # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$1 _LTECHO_EOF' } # Quote evaled strings. for var in SHELL \ ECHO \ PATH_SEPARATOR \ SED \ GREP \ EGREP \ FGREP \ LD \ NM \ LN_S \ lt_SP2NL \ lt_NL2SP \ reload_flag \ OBJDUMP \ deplibs_check_method \ file_magic_cmd \ file_magic_glob \ want_nocaseglob \ DLLTOOL \ sharedlib_from_linklib_cmd \ AR \ AR_FLAGS \ archiver_list_spec \ STRIP \ RANLIB \ CC \ CFLAGS \ compiler \ lt_cv_sys_global_symbol_pipe \ lt_cv_sys_global_symbol_to_cdecl \ lt_cv_sys_global_symbol_to_c_name_address \ lt_cv_sys_global_symbol_to_c_name_address_lib_prefix \ nm_file_list_spec \ lt_prog_compiler_no_builtin_flag \ lt_prog_compiler_pic \ lt_prog_compiler_wl \ lt_prog_compiler_static \ lt_cv_prog_compiler_c_o \ need_locks \ MANIFEST_TOOL \ DSYMUTIL \ NMEDIT \ LIPO \ OTOOL \ OTOOL64 \ shrext_cmds \ export_dynamic_flag_spec \ whole_archive_flag_spec \ compiler_needs_object \ with_gnu_ld \ allow_undefined_flag \ no_undefined_flag \ hardcode_libdir_flag_spec \ hardcode_libdir_separator \ exclude_expsyms \ include_expsyms \ file_list_spec \ variables_saved_for_relink \ libname_spec \ library_names_spec \ soname_spec \ install_override_mode \ finish_eval \ old_striplib \ striplib \ compiler_lib_search_dirs \ predep_objects \ postdep_objects \ predeps \ postdeps \ compiler_lib_search_path \ LD_CXX \ LD_FC \ reload_flag_CXX \ reload_flag_FC \ compiler_CXX \ compiler_FC \ lt_prog_compiler_no_builtin_flag_CXX \ lt_prog_compiler_no_builtin_flag_FC \ lt_prog_compiler_pic_CXX \ lt_prog_compiler_pic_FC \ lt_prog_compiler_wl_CXX \ lt_prog_compiler_wl_FC \ lt_prog_compiler_static_CXX \ lt_prog_compiler_static_FC \ lt_cv_prog_compiler_c_o_CXX \ lt_cv_prog_compiler_c_o_FC \ export_dynamic_flag_spec_CXX \ export_dynamic_flag_spec_FC \ whole_archive_flag_spec_CXX \ whole_archive_flag_spec_FC \ compiler_needs_object_CXX \ compiler_needs_object_FC \ with_gnu_ld_CXX \ with_gnu_ld_FC \ allow_undefined_flag_CXX \ allow_undefined_flag_FC \ no_undefined_flag_CXX \ no_undefined_flag_FC \ hardcode_libdir_flag_spec_CXX \ hardcode_libdir_flag_spec_FC \ hardcode_libdir_separator_CXX \ hardcode_libdir_separator_FC \ exclude_expsyms_CXX \ exclude_expsyms_FC \ include_expsyms_CXX \ include_expsyms_FC \ file_list_spec_CXX \ file_list_spec_FC \ compiler_lib_search_dirs_CXX \ compiler_lib_search_dirs_FC \ predep_objects_CXX \ predep_objects_FC \ postdep_objects_CXX \ postdep_objects_FC \ predeps_CXX \ predeps_FC \ postdeps_CXX \ postdeps_FC \ compiler_lib_search_path_CXX \ compiler_lib_search_path_FC; do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[\\\\\\\`\\"\\\$]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done # Double-quote double-evaled strings. for var in reload_cmds \ old_postinstall_cmds \ old_postuninstall_cmds \ old_archive_cmds \ extract_expsyms_cmds \ old_archive_from_new_cmds \ old_archive_from_expsyms_cmds \ archive_cmds \ archive_expsym_cmds \ module_cmds \ module_expsym_cmds \ export_symbols_cmds \ prelink_cmds \ postlink_cmds \ postinstall_cmds \ postuninstall_cmds \ finish_cmds \ sys_lib_search_path_spec \ sys_lib_dlsearch_path_spec \ reload_cmds_CXX \ reload_cmds_FC \ old_archive_cmds_CXX \ old_archive_cmds_FC \ old_archive_from_new_cmds_CXX \ old_archive_from_new_cmds_FC \ old_archive_from_expsyms_cmds_CXX \ old_archive_from_expsyms_cmds_FC \ archive_cmds_CXX \ archive_cmds_FC \ archive_expsym_cmds_CXX \ archive_expsym_cmds_FC \ module_cmds_CXX \ module_cmds_FC \ module_expsym_cmds_CXX \ module_expsym_cmds_FC \ export_symbols_cmds_CXX \ export_symbols_cmds_FC \ prelink_cmds_CXX \ prelink_cmds_FC \ postlink_cmds_CXX \ postlink_cmds_FC; do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[\\\\\\\`\\"\\\$]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done ac_aux_dir='$ac_aux_dir' xsi_shell='$xsi_shell' lt_shell_append='$lt_shell_append' # See if we are running on zsh, and set the options which allow our # commands through without removal of \ escapes INIT. if test -n "\${ZSH_VERSION+set}" ; then setopt NO_GLOB_SUBST fi PACKAGE='$PACKAGE' VERSION='$VERSION' TIMESTAMP='$TIMESTAMP' RM='$RM' ofile='$ofile' _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # Handling of arguments. for ac_config_target in $ac_config_targets do case $ac_config_target in "depfiles") CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; "libtool") CONFIG_COMMANDS="$CONFIG_COMMANDS libtool" ;; "Makefile") CONFIG_FILES="$CONFIG_FILES Makefile" ;; "eztrace.pc") CONFIG_FILES="$CONFIG_FILES eztrace.pc" ;; "extlib/Makefile") CONFIG_FILES="$CONFIG_FILES extlib/Makefile" ;; "src/core/Makefile") CONFIG_FILES="$CONFIG_FILES src/core/Makefile" ;; "src/modules/omp/Makefile") CONFIG_FILES="$CONFIG_FILES src/modules/omp/Makefile" ;; "src/modules/mpi/Makefile") CONFIG_FILES="$CONFIG_FILES src/modules/mpi/Makefile" ;; "src/modules/cuda/Makefile") CONFIG_FILES="$CONFIG_FILES src/modules/cuda/Makefile" ;; "src/modules/pthread/Makefile") CONFIG_FILES="$CONFIG_FILES src/modules/pthread/Makefile" ;; "src/modules/stdio/Makefile") CONFIG_FILES="$CONFIG_FILES src/modules/stdio/Makefile" ;; "src/modules/memory/Makefile") CONFIG_FILES="$CONFIG_FILES src/modules/memory/Makefile" ;; "src/modules/papi/Makefile") CONFIG_FILES="$CONFIG_FILES src/modules/papi/Makefile" ;; "src/modules/starpu/Makefile") CONFIG_FILES="$CONFIG_FILES src/modules/starpu/Makefile" ;; "src/core/eztrace_create_plugin") CONFIG_FILES="$CONFIG_FILES src/core/eztrace_create_plugin" ;; "src/core/eztrace_plugin_generator") CONFIG_FILES="$CONFIG_FILES src/core/eztrace_plugin_generator" ;; "src/core/input/Makefile.template") CONFIG_FILES="$CONFIG_FILES src/core/input/Makefile.template" ;; "src/modules/omp/eztrace_cc") CONFIG_FILES="$CONFIG_FILES src/modules/omp/eztrace_cc" ;; "test/mpi/Makefile") CONFIG_FILES="$CONFIG_FILES test/mpi/Makefile" ;; "test/openmp/Makefile") CONFIG_FILES="$CONFIG_FILES test/openmp/Makefile" ;; "src/core/eztrace.c") CONFIG_FILES="$CONFIG_FILES src/core/eztrace.c" ;; "src/core/eztrace.preload") CONFIG_FILES="$CONFIG_FILES src/core/eztrace.preload" ;; "src/core/eztrace_config.h") CONFIG_FILES="$CONFIG_FILES src/core/eztrace_config.h" ;; "test/static/Makefile") CONFIG_FILES="$CONFIG_FILES test/static/Makefile" ;; "test/stdio/Makefile") CONFIG_FILES="$CONFIG_FILES test/stdio/Makefile" ;; "test/memory/Makefile") CONFIG_FILES="$CONFIG_FILES test/memory/Makefile" ;; "test/pthread/Makefile") CONFIG_FILES="$CONFIG_FILES test/pthread/Makefile" ;; "test/automake/Makefile") CONFIG_FILES="$CONFIG_FILES test/automake/Makefile" ;; "test/automake/testcommon.h") CONFIG_FILES="$CONFIG_FILES test/automake/testcommon.h" ;; "test/pptrace/automatic/Makefile") CONFIG_FILES="$CONFIG_FILES test/pptrace/automatic/Makefile" ;; "doc/Makefile") CONFIG_FILES="$CONFIG_FILES doc/Makefile" ;; "src/modules/omp/pomp-lib-dummy/Makefile") CONFIG_FILES="$CONFIG_FILES src/modules/omp/pomp-lib-dummy/Makefile" ;; *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; esac done # If the user did not use the arguments to specify the items to instantiate, # then the envvar interface is used. Set only those that are not. # We use the long form for the default assignment because of an extremely # bizarre bug on SunOS 4.1.3. if $ac_need_defaults; then test "${CONFIG_FILES+set}" = set || CONFIG_FILES=$config_files test "${CONFIG_COMMANDS+set}" = set || CONFIG_COMMANDS=$config_commands fi # Have a temporary directory for convenience. Make it in the build tree # simply because there is no reason against having it here, and in addition, # creating and moving files from /tmp can sometimes cause problems. # Hook for its removal unless debugging. # Note that there is a small window in which the directory will not be cleaned: # after its creation but before its name has been assigned to `$tmp'. $debug || { tmp= ac_tmp= trap 'exit_status=$? : "${ac_tmp:=$tmp}" { test ! -d "$ac_tmp" || rm -fr "$ac_tmp"; } && exit $exit_status ' 0 trap 'as_fn_exit 1' 1 2 13 15 } # Create a (secure) tmp directory for tmp files. { tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && test -d "$tmp" } || { tmp=./conf$$-$RANDOM (umask 077 && mkdir "$tmp") } || as_fn_error $? "cannot create a temporary directory in ." "$LINENO" 5 ac_tmp=$tmp # Set up the scripts for CONFIG_FILES section. # No need to generate them if there are no CONFIG_FILES. # This happens for instance with `./config.status config.h'. if test -n "$CONFIG_FILES"; then ac_cr=`echo X | tr X '\015'` # On cygwin, bash can eat \r inside `` if the user requested igncr. # But we know of no other shell where ac_cr would be empty at this # point, so we can use a bashism as a fallback. if test "x$ac_cr" = x; then eval ac_cr=\$\'\\r\' fi ac_cs_awk_cr=`$AWK 'BEGIN { print "a\rb" }' /dev/null` if test "$ac_cs_awk_cr" = "a${ac_cr}b"; then ac_cs_awk_cr='\\r' else ac_cs_awk_cr=$ac_cr fi echo 'BEGIN {' >"$ac_tmp/subs1.awk" && _ACEOF { echo "cat >conf$$subs.awk <<_ACEOF" && echo "$ac_subst_vars" | sed 's/.*/&!$&$ac_delim/' && echo "_ACEOF" } >conf$$subs.sh || as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 ac_delim_num=`echo "$ac_subst_vars" | grep -c '^'` ac_delim='%!_!# ' for ac_last_try in false false false false false :; do . ./conf$$subs.sh || as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 ac_delim_n=`sed -n "s/.*$ac_delim\$/X/p" conf$$subs.awk | grep -c X` if test $ac_delim_n = $ac_delim_num; then break elif $ac_last_try; then as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 else ac_delim="$ac_delim!$ac_delim _$ac_delim!! " fi done rm -f conf$$subs.sh cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 cat >>"\$ac_tmp/subs1.awk" <<\\_ACAWK && _ACEOF sed -n ' h s/^/S["/; s/!.*/"]=/ p g s/^[^!]*!// :repl t repl s/'"$ac_delim"'$// t delim :nl h s/\(.\{148\}\)..*/\1/ t more1 s/["\\]/\\&/g; s/^/"/; s/$/\\n"\\/ p n b repl :more1 s/["\\]/\\&/g; s/^/"/; s/$/"\\/ p g s/.\{148\}// t nl :delim h s/\(.\{148\}\)..*/\1/ t more2 s/["\\]/\\&/g; s/^/"/; s/$/"/ p b :more2 s/["\\]/\\&/g; s/^/"/; s/$/"\\/ p g s/.\{148\}// t delim ' >$CONFIG_STATUS || ac_write_fail=1 rm -f conf$$subs.awk cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 _ACAWK cat >>"\$ac_tmp/subs1.awk" <<_ACAWK && for (key in S) S_is_set[key] = 1 FS = "" } { line = $ 0 nfields = split(line, field, "@") substed = 0 len = length(field[1]) for (i = 2; i < nfields; i++) { key = field[i] keylen = length(key) if (S_is_set[key]) { value = S[key] line = substr(line, 1, len) "" value "" substr(line, len + keylen + 3) len += length(value) + length(field[++i]) substed = 1 } else len += 1 + keylen } print line } _ACAWK _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g" else cat fi < "$ac_tmp/subs1.awk" > "$ac_tmp/subs.awk" \ || as_fn_error $? "could not setup config files machinery" "$LINENO" 5 _ACEOF # VPATH may cause trouble with some makes, so we remove sole $(srcdir), # ${srcdir} and @srcdir@ entries from VPATH if srcdir is ".", strip leading and # trailing colons and then remove the whole line if VPATH becomes empty # (actually we leave an empty line to preserve line numbers). if test "x$srcdir" = x.; then ac_vpsub='/^[ ]*VPATH[ ]*=[ ]*/{ h s/// s/^/:/ s/[ ]*$/:/ s/:\$(srcdir):/:/g s/:\${srcdir}:/:/g s/:@srcdir@:/:/g s/^:*// s/:*$// x s/\(=[ ]*\).*/\1/ G s/\n// s/^[^=]*=[ ]*$// }' fi cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 fi # test -n "$CONFIG_FILES" eval set X " :F $CONFIG_FILES :C $CONFIG_COMMANDS" shift for ac_tag do case $ac_tag in :[FHLC]) ac_mode=$ac_tag; continue;; esac case $ac_mode$ac_tag in :[FHL]*:*);; :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5;; :[FH]-) ac_tag=-:-;; :[FH]*) ac_tag=$ac_tag:$ac_tag.in;; esac ac_save_IFS=$IFS IFS=: set x $ac_tag IFS=$ac_save_IFS shift ac_file=$1 shift case $ac_mode in :L) ac_source=$1;; :[FH]) ac_file_inputs= for ac_f do case $ac_f in -) ac_f="$ac_tmp/stdin";; *) # Look for the file first in the build tree, then in the source tree # (if the path is not absolute). The absolute path cannot be DOS-style, # because $ac_f cannot contain `:'. test -f "$ac_f" || case $ac_f in [\\/$]*) false;; *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; esac || as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5;; esac case $ac_f in *\'*) ac_f=`$as_echo "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac as_fn_append ac_file_inputs " '$ac_f'" done # Let's still pretend it is `configure' which instantiates (i.e., don't # use $as_me), people would be surprised to read: # /* config.h. Generated by config.status. */ configure_input='Generated from '` $as_echo "$*" | sed 's|^[^:]*/||;s|:[^:]*/|, |g' `' by configure.' if test x"$ac_file" != x-; then configure_input="$ac_file. $configure_input" { $as_echo "$as_me:${as_lineno-$LINENO}: creating $ac_file" >&5 $as_echo "$as_me: creating $ac_file" >&6;} fi # Neutralize special characters interpreted by sed in replacement strings. case $configure_input in #( *\&* | *\|* | *\\* ) ac_sed_conf_input=`$as_echo "$configure_input" | sed 's/[\\\\&|]/\\\\&/g'`;; #( *) ac_sed_conf_input=$configure_input;; esac case $ac_tag in *:-:* | *:-) cat >"$ac_tmp/stdin" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; esac ;; esac ac_dir=`$as_dirname -- "$ac_file" || $as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$ac_file" : 'X\(//\)[^/]' \| \ X"$ac_file" : 'X\(//\)$' \| \ X"$ac_file" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$ac_file" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` as_dir="$ac_dir"; as_fn_mkdir_p ac_builddir=. case "$ac_dir" in .) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` # A ".." for each directory in $ac_dir_suffix. ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` case $ac_top_builddir_sub in "") ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; esac ;; esac ac_abs_top_builddir=$ac_pwd ac_abs_builddir=$ac_pwd$ac_dir_suffix # for backward compatibility: ac_top_builddir=$ac_top_build_prefix case $srcdir in .) # We are building in place. ac_srcdir=. ac_top_srcdir=$ac_top_builddir_sub ac_abs_top_srcdir=$ac_pwd ;; [\\/]* | ?:[\\/]* ) # Absolute name. ac_srcdir=$srcdir$ac_dir_suffix; ac_top_srcdir=$srcdir ac_abs_top_srcdir=$srcdir ;; *) # Relative name. ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix ac_top_srcdir=$ac_top_build_prefix$srcdir ac_abs_top_srcdir=$ac_pwd/$srcdir ;; esac ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix case $ac_mode in :F) # # CONFIG_FILE # case $INSTALL in [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;; *) ac_INSTALL=$ac_top_build_prefix$INSTALL ;; esac ac_MKDIR_P=$MKDIR_P case $MKDIR_P in [\\/$]* | ?:[\\/]* ) ;; */*) ac_MKDIR_P=$ac_top_build_prefix$MKDIR_P ;; esac _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # If the template does not know about datarootdir, expand it. # FIXME: This hack should be removed a few years after 2.60. ac_datarootdir_hack=; ac_datarootdir_seen= ac_sed_dataroot=' /datarootdir/ { p q } /@datadir@/p /@docdir@/p /@infodir@/p /@localedir@/p /@mandir@/p' case `eval "sed -n \"\$ac_sed_dataroot\" $ac_file_inputs"` in *datarootdir*) ac_datarootdir_seen=yes;; *@datadir@*|*@docdir@*|*@infodir@*|*@localedir@*|*@mandir@*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&5 $as_echo "$as_me: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&2;} _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_datarootdir_hack=' s&@datadir@&$datadir&g s&@docdir@&$docdir&g s&@infodir@&$infodir&g s&@localedir@&$localedir&g s&@mandir@&$mandir&g s&\\\${datarootdir}&$datarootdir&g' ;; esac _ACEOF # Neutralize VPATH when `$srcdir' = `.'. # Shell code in configure.ac might set extrasub. # FIXME: do we really want to maintain this feature? cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_sed_extra="$ac_vpsub $extrasub _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 :t /@[a-zA-Z_][a-zA-Z_0-9]*@/!b s|@configure_input@|$ac_sed_conf_input|;t t s&@top_builddir@&$ac_top_builddir_sub&;t t s&@top_build_prefix@&$ac_top_build_prefix&;t t s&@srcdir@&$ac_srcdir&;t t s&@abs_srcdir@&$ac_abs_srcdir&;t t s&@top_srcdir@&$ac_top_srcdir&;t t s&@abs_top_srcdir@&$ac_abs_top_srcdir&;t t s&@builddir@&$ac_builddir&;t t s&@abs_builddir@&$ac_abs_builddir&;t t s&@abs_top_builddir@&$ac_abs_top_builddir&;t t s&@INSTALL@&$ac_INSTALL&;t t s&@MKDIR_P@&$ac_MKDIR_P&;t t $ac_datarootdir_hack " eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$ac_tmp/subs.awk" \ >$ac_tmp/out || as_fn_error $? "could not create $ac_file" "$LINENO" 5 test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && { ac_out=`sed -n '/\${datarootdir}/p' "$ac_tmp/out"`; test -n "$ac_out"; } && { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' \ "$ac_tmp/out"`; test -z "$ac_out"; } && { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&5 $as_echo "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&2;} rm -f "$ac_tmp/stdin" case $ac_file in -) cat "$ac_tmp/out" && rm -f "$ac_tmp/out";; *) rm -f "$ac_file" && mv "$ac_tmp/out" "$ac_file";; esac \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; :C) { $as_echo "$as_me:${as_lineno-$LINENO}: executing $ac_file commands" >&5 $as_echo "$as_me: executing $ac_file commands" >&6;} ;; esac case $ac_file$ac_mode in "depfiles":C) test x"$AMDEP_TRUE" != x"" || { # Older Autoconf quotes --file arguments for eval, but not when files # are listed without --file. Let's play safe and only enable the eval # if we detect the quoting. case $CONFIG_FILES in *\'*) eval set x "$CONFIG_FILES" ;; *) set x $CONFIG_FILES ;; esac shift for mf do # Strip MF so we end up with the name of the file. mf=`echo "$mf" | sed -e 's/:.*$//'` # Check whether this is an Automake generated Makefile or not. # We used to match only the files named 'Makefile.in', but # some people rename them; so instead we look at the file content. # Grep'ing the first line is not enough: some people post-process # each Makefile.in and add a new line on top of each file to say so. # Grep'ing the whole file is not good either: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then dirpart=`$as_dirname -- "$mf" || $as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$mf" : 'X\(//\)[^/]' \| \ X"$mf" : 'X\(//\)$' \| \ X"$mf" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$mf" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` else continue fi # Extract the definition of DEPDIR, am__include, and am__quote # from the Makefile without running 'make'. DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` test -z "$DEPDIR" && continue am__include=`sed -n 's/^am__include = //p' < "$mf"` test -z "$am__include" && continue am__quote=`sed -n 's/^am__quote = //p' < "$mf"` # Find all dependency output files, they are included files with # $(DEPDIR) in their names. We invoke sed twice because it is the # simplest approach to changing $(DEPDIR) to its actual value in the # expansion. for file in `sed -n " s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do # Make sure the directory exists. test -f "$dirpart/$file" && continue fdir=`$as_dirname -- "$file" || $as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$file" : 'X\(//\)[^/]' \| \ X"$file" : 'X\(//\)$' \| \ X"$file" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$file" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` as_dir=$dirpart/$fdir; as_fn_mkdir_p # echo "creating $dirpart/$file" echo '# dummy' > "$dirpart/$file" done done } ;; "libtool":C) # See if we are running on zsh, and set the options which allow our # commands through without removal of \ escapes. if test -n "${ZSH_VERSION+set}" ; then setopt NO_GLOB_SUBST fi cfgfile="${ofile}T" trap "$RM \"$cfgfile\"; exit 1" 1 2 15 $RM "$cfgfile" cat <<_LT_EOF >> "$cfgfile" #! $SHELL # `$ECHO "$ofile" | sed 's%^.*/%%'` - Provide generalized library-building support services. # Generated automatically by $as_me ($PACKAGE$TIMESTAMP) $VERSION # Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: # NOTE: Changes made to this file will be lost: look at ltmain.sh. # # Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, # 2006, 2007, 2008, 2009, 2010, 2011 Free Software # Foundation, Inc. # Written by Gordon Matzigkeit, 1996 # # This file is part of GNU Libtool. # # GNU Libtool is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License as # published by the Free Software Foundation; either version 2 of # the License, or (at your option) any later version. # # As a special exception to the GNU General Public License, # if you distribute this file as part of a program or library that # is built using GNU Libtool, you may include this file under the # same distribution terms that you use for the rest of that program. # # GNU Libtool is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with GNU Libtool; see the file COPYING. If not, a copy # can be downloaded from http://www.gnu.org/licenses/gpl.html, or # obtained by writing to the Free Software Foundation, Inc., # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. # The names of the tagged configurations supported by this script. available_tags="CXX FC " # ### BEGIN LIBTOOL CONFIG # Which release of libtool.m4 was used? macro_version=$macro_version macro_revision=$macro_revision # Whether or not to build shared libraries. build_libtool_libs=$enable_shared # Whether or not to build static libraries. build_old_libs=$enable_static # What type of objects to build. pic_mode=$pic_mode # Whether or not to optimize for fast installation. fast_install=$enable_fast_install # Shell to use when invoking shell scripts. SHELL=$lt_SHELL # An echo program that protects backslashes. ECHO=$lt_ECHO # The PATH separator for the build system. PATH_SEPARATOR=$lt_PATH_SEPARATOR # The host system. host_alias=$host_alias host=$host host_os=$host_os # The build system. build_alias=$build_alias build=$build build_os=$build_os # A sed program that does not truncate output. SED=$lt_SED # Sed that helps us avoid accidentally triggering echo(1) options like -n. Xsed="\$SED -e 1s/^X//" # A grep program that handles long lines. GREP=$lt_GREP # An ERE matcher. EGREP=$lt_EGREP # A literal string matcher. FGREP=$lt_FGREP # A BSD- or MS-compatible name lister. NM=$lt_NM # Whether we need soft or hard links. LN_S=$lt_LN_S # What is the maximum length of a command? max_cmd_len=$max_cmd_len # Object file suffix (normally "o"). objext=$ac_objext # Executable file suffix (normally ""). exeext=$exeext # whether the shell understands "unset". lt_unset=$lt_unset # turn spaces into newlines. SP2NL=$lt_lt_SP2NL # turn newlines into spaces. NL2SP=$lt_lt_NL2SP # convert \$build file names to \$host format. to_host_file_cmd=$lt_cv_to_host_file_cmd # convert \$build files to toolchain format. to_tool_file_cmd=$lt_cv_to_tool_file_cmd # An object symbol dumper. OBJDUMP=$lt_OBJDUMP # Method to check whether dependent libraries are shared objects. deplibs_check_method=$lt_deplibs_check_method # Command to use when deplibs_check_method = "file_magic". file_magic_cmd=$lt_file_magic_cmd # How to find potential files when deplibs_check_method = "file_magic". file_magic_glob=$lt_file_magic_glob # Find potential files using nocaseglob when deplibs_check_method = "file_magic". want_nocaseglob=$lt_want_nocaseglob # DLL creation program. DLLTOOL=$lt_DLLTOOL # Command to associate shared and link libraries. sharedlib_from_linklib_cmd=$lt_sharedlib_from_linklib_cmd # The archiver. AR=$lt_AR # Flags to create an archive. AR_FLAGS=$lt_AR_FLAGS # How to feed a file listing to the archiver. archiver_list_spec=$lt_archiver_list_spec # A symbol stripping program. STRIP=$lt_STRIP # Commands used to install an old-style archive. RANLIB=$lt_RANLIB old_postinstall_cmds=$lt_old_postinstall_cmds old_postuninstall_cmds=$lt_old_postuninstall_cmds # Whether to use a lock for old archive extraction. lock_old_archive_extraction=$lock_old_archive_extraction # A C compiler. LTCC=$lt_CC # LTCC compiler flags. LTCFLAGS=$lt_CFLAGS # Take the output of nm and produce a listing of raw symbols and C names. global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe # Transform the output of nm in a proper C declaration. global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl # Transform the output of nm in a C name address pair. global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address # Transform the output of nm in a C name address pair when lib prefix is needed. global_symbol_to_c_name_address_lib_prefix=$lt_lt_cv_sys_global_symbol_to_c_name_address_lib_prefix # Specify filename containing input files for \$NM. nm_file_list_spec=$lt_nm_file_list_spec # The root where to search for dependent libraries,and in which our libraries should be installed. lt_sysroot=$lt_sysroot # The name of the directory that contains temporary libtool files. objdir=$objdir # Used to examine libraries when file_magic_cmd begins with "file". MAGIC_CMD=$MAGIC_CMD # Must we lock files when doing compilation? need_locks=$lt_need_locks # Manifest tool. MANIFEST_TOOL=$lt_MANIFEST_TOOL # Tool to manipulate archived DWARF debug symbol files on Mac OS X. DSYMUTIL=$lt_DSYMUTIL # Tool to change global to local symbols on Mac OS X. NMEDIT=$lt_NMEDIT # Tool to manipulate fat objects and archives on Mac OS X. LIPO=$lt_LIPO # ldd/readelf like tool for Mach-O binaries on Mac OS X. OTOOL=$lt_OTOOL # ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4. OTOOL64=$lt_OTOOL64 # Old archive suffix (normally "a"). libext=$libext # Shared library suffix (normally ".so"). shrext_cmds=$lt_shrext_cmds # The commands to extract the exported symbol list from a shared archive. extract_expsyms_cmds=$lt_extract_expsyms_cmds # Variables whose values should be saved in libtool wrapper scripts and # restored at link time. variables_saved_for_relink=$lt_variables_saved_for_relink # Do we need the "lib" prefix for modules? need_lib_prefix=$need_lib_prefix # Do we need a version for libraries? need_version=$need_version # Library versioning type. version_type=$version_type # Shared library runtime path variable. runpath_var=$runpath_var # Shared library path variable. shlibpath_var=$shlibpath_var # Is shlibpath searched before the hard-coded library search path? shlibpath_overrides_runpath=$shlibpath_overrides_runpath # Format of library name prefix. libname_spec=$lt_libname_spec # List of archive names. First name is the real one, the rest are links. # The last name is the one that the linker finds with -lNAME library_names_spec=$lt_library_names_spec # The coded name of the library, if different from the real name. soname_spec=$lt_soname_spec # Permission mode override for installation of shared libraries. install_override_mode=$lt_install_override_mode # Command to use after installation of a shared archive. postinstall_cmds=$lt_postinstall_cmds # Command to use after uninstallation of a shared archive. postuninstall_cmds=$lt_postuninstall_cmds # Commands used to finish a libtool library installation in a directory. finish_cmds=$lt_finish_cmds # As "finish_cmds", except a single script fragment to be evaled but # not shown. finish_eval=$lt_finish_eval # Whether we should hardcode library paths into libraries. hardcode_into_libs=$hardcode_into_libs # Compile-time system search path for libraries. sys_lib_search_path_spec=$lt_sys_lib_search_path_spec # Run-time system search path for libraries. sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec # Whether dlopen is supported. dlopen_support=$enable_dlopen # Whether dlopen of programs is supported. dlopen_self=$enable_dlopen_self # Whether dlopen of statically linked programs is supported. dlopen_self_static=$enable_dlopen_self_static # Commands to strip libraries. old_striplib=$lt_old_striplib striplib=$lt_striplib # The linker used to build libraries. LD=$lt_LD # How to create reloadable object files. reload_flag=$lt_reload_flag reload_cmds=$lt_reload_cmds # Commands used to build an old-style archive. old_archive_cmds=$lt_old_archive_cmds # A language specific compiler. CC=$lt_compiler # Is the compiler the GNU compiler? with_gcc=$GCC # Compiler flag to turn off builtin functions. no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag # Additional compiler flags for building library objects. pic_flag=$lt_lt_prog_compiler_pic # How to pass a linker flag through the compiler. wl=$lt_lt_prog_compiler_wl # Compiler flag to prevent dynamic linking. link_static_flag=$lt_lt_prog_compiler_static # Does compiler simultaneously support -c and -o options? compiler_c_o=$lt_lt_cv_prog_compiler_c_o # Whether or not to add -lc for building shared libraries. build_libtool_need_lc=$archive_cmds_need_lc # Whether or not to disallow shared libs when runtime libs are static. allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes # Compiler flag to allow reflexive dlopens. export_dynamic_flag_spec=$lt_export_dynamic_flag_spec # Compiler flag to generate shared objects directly from archives. whole_archive_flag_spec=$lt_whole_archive_flag_spec # Whether the compiler copes with passing no objects directly. compiler_needs_object=$lt_compiler_needs_object # Create an old-style archive from a shared archive. old_archive_from_new_cmds=$lt_old_archive_from_new_cmds # Create a temporary old-style archive to link instead of a shared archive. old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds # Commands used to build a shared archive. archive_cmds=$lt_archive_cmds archive_expsym_cmds=$lt_archive_expsym_cmds # Commands used to build a loadable module if different from building # a shared archive. module_cmds=$lt_module_cmds module_expsym_cmds=$lt_module_expsym_cmds # Whether we are building with GNU ld or not. with_gnu_ld=$lt_with_gnu_ld # Flag that allows shared libraries with undefined symbols to be built. allow_undefined_flag=$lt_allow_undefined_flag # Flag that enforces no undefined symbols. no_undefined_flag=$lt_no_undefined_flag # Flag to hardcode \$libdir into a binary during linking. # This must work even if \$libdir does not exist hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec # Whether we need a single "-rpath" flag with a separated argument. hardcode_libdir_separator=$lt_hardcode_libdir_separator # Set to "yes" if using DIR/libNAME\${shared_ext} during linking hardcodes # DIR into the resulting binary. hardcode_direct=$hardcode_direct # Set to "yes" if using DIR/libNAME\${shared_ext} during linking hardcodes # DIR into the resulting binary and the resulting library dependency is # "absolute",i.e impossible to change by setting \${shlibpath_var} if the # library is relocated. hardcode_direct_absolute=$hardcode_direct_absolute # Set to "yes" if using the -LDIR flag during linking hardcodes DIR # into the resulting binary. hardcode_minus_L=$hardcode_minus_L # Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR # into the resulting binary. hardcode_shlibpath_var=$hardcode_shlibpath_var # Set to "yes" if building a shared library automatically hardcodes DIR # into the library and all subsequent libraries and executables linked # against it. hardcode_automatic=$hardcode_automatic # Set to yes if linker adds runtime paths of dependent libraries # to runtime path list. inherit_rpath=$inherit_rpath # Whether libtool must link a program against all its dependency libraries. link_all_deplibs=$link_all_deplibs # Set to "yes" if exported symbols are required. always_export_symbols=$always_export_symbols # The commands to list exported symbols. export_symbols_cmds=$lt_export_symbols_cmds # Symbols that should not be listed in the preloaded symbols. exclude_expsyms=$lt_exclude_expsyms # Symbols that must always be exported. include_expsyms=$lt_include_expsyms # Commands necessary for linking programs (against libraries) with templates. prelink_cmds=$lt_prelink_cmds # Commands necessary for finishing linking programs. postlink_cmds=$lt_postlink_cmds # Specify filename containing input files. file_list_spec=$lt_file_list_spec # How to hardcode a shared library path into an executable. hardcode_action=$hardcode_action # The directories searched by this compiler when creating a shared library. compiler_lib_search_dirs=$lt_compiler_lib_search_dirs # Dependencies to place before and after the objects being linked to # create a shared library. predep_objects=$lt_predep_objects postdep_objects=$lt_postdep_objects predeps=$lt_predeps postdeps=$lt_postdeps # The library search path used internally by the compiler when linking # a shared library. compiler_lib_search_path=$lt_compiler_lib_search_path # ### END LIBTOOL CONFIG _LT_EOF case $host_os in aix3*) cat <<\_LT_EOF >> "$cfgfile" # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test "X${COLLECT_NAMES+set}" != Xset; then COLLECT_NAMES= export COLLECT_NAMES fi _LT_EOF ;; esac ltmain="$ac_aux_dir/ltmain.sh" # We use sed instead of cat because bash on DJGPP gets confused if # if finds mixed CR/LF and LF-only lines. Since sed operates in # text mode, it properly converts lines to CR/LF. This bash problem # is reportedly fixed, but why not run on old versions too? sed '$q' "$ltmain" >> "$cfgfile" \ || (rm -f "$cfgfile"; exit 1) if test x"$xsi_shell" = xyes; then sed -e '/^func_dirname ()$/,/^} # func_dirname /c\ func_dirname ()\ {\ \ case ${1} in\ \ */*) func_dirname_result="${1%/*}${2}" ;;\ \ * ) func_dirname_result="${3}" ;;\ \ esac\ } # Extended-shell func_dirname implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: sed -e '/^func_basename ()$/,/^} # func_basename /c\ func_basename ()\ {\ \ func_basename_result="${1##*/}"\ } # Extended-shell func_basename implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: sed -e '/^func_dirname_and_basename ()$/,/^} # func_dirname_and_basename /c\ func_dirname_and_basename ()\ {\ \ case ${1} in\ \ */*) func_dirname_result="${1%/*}${2}" ;;\ \ * ) func_dirname_result="${3}" ;;\ \ esac\ \ func_basename_result="${1##*/}"\ } # Extended-shell func_dirname_and_basename implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: sed -e '/^func_stripname ()$/,/^} # func_stripname /c\ func_stripname ()\ {\ \ # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are\ \ # positional parameters, so assign one to ordinary parameter first.\ \ func_stripname_result=${3}\ \ func_stripname_result=${func_stripname_result#"${1}"}\ \ func_stripname_result=${func_stripname_result%"${2}"}\ } # Extended-shell func_stripname implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: sed -e '/^func_split_long_opt ()$/,/^} # func_split_long_opt /c\ func_split_long_opt ()\ {\ \ func_split_long_opt_name=${1%%=*}\ \ func_split_long_opt_arg=${1#*=}\ } # Extended-shell func_split_long_opt implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: sed -e '/^func_split_short_opt ()$/,/^} # func_split_short_opt /c\ func_split_short_opt ()\ {\ \ func_split_short_opt_arg=${1#??}\ \ func_split_short_opt_name=${1%"$func_split_short_opt_arg"}\ } # Extended-shell func_split_short_opt implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: sed -e '/^func_lo2o ()$/,/^} # func_lo2o /c\ func_lo2o ()\ {\ \ case ${1} in\ \ *.lo) func_lo2o_result=${1%.lo}.${objext} ;;\ \ *) func_lo2o_result=${1} ;;\ \ esac\ } # Extended-shell func_lo2o implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: sed -e '/^func_xform ()$/,/^} # func_xform /c\ func_xform ()\ {\ func_xform_result=${1%.*}.lo\ } # Extended-shell func_xform implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: sed -e '/^func_arith ()$/,/^} # func_arith /c\ func_arith ()\ {\ func_arith_result=$(( $* ))\ } # Extended-shell func_arith implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: sed -e '/^func_len ()$/,/^} # func_len /c\ func_len ()\ {\ func_len_result=${#1}\ } # Extended-shell func_len implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: fi if test x"$lt_shell_append" = xyes; then sed -e '/^func_append ()$/,/^} # func_append /c\ func_append ()\ {\ eval "${1}+=\\${2}"\ } # Extended-shell func_append implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: sed -e '/^func_append_quoted ()$/,/^} # func_append_quoted /c\ func_append_quoted ()\ {\ \ func_quote_for_eval "${2}"\ \ eval "${1}+=\\\\ \\$func_quote_for_eval_result"\ } # Extended-shell func_append_quoted implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: # Save a `func_append' function call where possible by direct use of '+=' sed -e 's%func_append \([a-zA-Z_]\{1,\}\) "%\1+="%g' $cfgfile > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: else # Save a `func_append' function call even when '+=' is not available sed -e 's%func_append \([a-zA-Z_]\{1,\}\) "%\1="$\1%g' $cfgfile > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: fi if test x"$_lt_function_replace_fail" = x":"; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: Unable to substitute extended shell functions in $ofile" >&5 $as_echo "$as_me: WARNING: Unable to substitute extended shell functions in $ofile" >&2;} fi mv -f "$cfgfile" "$ofile" || (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") chmod +x "$ofile" cat <<_LT_EOF >> "$ofile" # ### BEGIN LIBTOOL TAG CONFIG: CXX # The linker used to build libraries. LD=$lt_LD_CXX # How to create reloadable object files. reload_flag=$lt_reload_flag_CXX reload_cmds=$lt_reload_cmds_CXX # Commands used to build an old-style archive. old_archive_cmds=$lt_old_archive_cmds_CXX # A language specific compiler. CC=$lt_compiler_CXX # Is the compiler the GNU compiler? with_gcc=$GCC_CXX # Compiler flag to turn off builtin functions. no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag_CXX # Additional compiler flags for building library objects. pic_flag=$lt_lt_prog_compiler_pic_CXX # How to pass a linker flag through the compiler. wl=$lt_lt_prog_compiler_wl_CXX # Compiler flag to prevent dynamic linking. link_static_flag=$lt_lt_prog_compiler_static_CXX # Does compiler simultaneously support -c and -o options? compiler_c_o=$lt_lt_cv_prog_compiler_c_o_CXX # Whether or not to add -lc for building shared libraries. build_libtool_need_lc=$archive_cmds_need_lc_CXX # Whether or not to disallow shared libs when runtime libs are static. allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes_CXX # Compiler flag to allow reflexive dlopens. export_dynamic_flag_spec=$lt_export_dynamic_flag_spec_CXX # Compiler flag to generate shared objects directly from archives. whole_archive_flag_spec=$lt_whole_archive_flag_spec_CXX # Whether the compiler copes with passing no objects directly. compiler_needs_object=$lt_compiler_needs_object_CXX # Create an old-style archive from a shared archive. old_archive_from_new_cmds=$lt_old_archive_from_new_cmds_CXX # Create a temporary old-style archive to link instead of a shared archive. old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds_CXX # Commands used to build a shared archive. archive_cmds=$lt_archive_cmds_CXX archive_expsym_cmds=$lt_archive_expsym_cmds_CXX # Commands used to build a loadable module if different from building # a shared archive. module_cmds=$lt_module_cmds_CXX module_expsym_cmds=$lt_module_expsym_cmds_CXX # Whether we are building with GNU ld or not. with_gnu_ld=$lt_with_gnu_ld_CXX # Flag that allows shared libraries with undefined symbols to be built. allow_undefined_flag=$lt_allow_undefined_flag_CXX # Flag that enforces no undefined symbols. no_undefined_flag=$lt_no_undefined_flag_CXX # Flag to hardcode \$libdir into a binary during linking. # This must work even if \$libdir does not exist hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_CXX # Whether we need a single "-rpath" flag with a separated argument. hardcode_libdir_separator=$lt_hardcode_libdir_separator_CXX # Set to "yes" if using DIR/libNAME\${shared_ext} during linking hardcodes # DIR into the resulting binary. hardcode_direct=$hardcode_direct_CXX # Set to "yes" if using DIR/libNAME\${shared_ext} during linking hardcodes # DIR into the resulting binary and the resulting library dependency is # "absolute",i.e impossible to change by setting \${shlibpath_var} if the # library is relocated. hardcode_direct_absolute=$hardcode_direct_absolute_CXX # Set to "yes" if using the -LDIR flag during linking hardcodes DIR # into the resulting binary. hardcode_minus_L=$hardcode_minus_L_CXX # Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR # into the resulting binary. hardcode_shlibpath_var=$hardcode_shlibpath_var_CXX # Set to "yes" if building a shared library automatically hardcodes DIR # into the library and all subsequent libraries and executables linked # against it. hardcode_automatic=$hardcode_automatic_CXX # Set to yes if linker adds runtime paths of dependent libraries # to runtime path list. inherit_rpath=$inherit_rpath_CXX # Whether libtool must link a program against all its dependency libraries. link_all_deplibs=$link_all_deplibs_CXX # Set to "yes" if exported symbols are required. always_export_symbols=$always_export_symbols_CXX # The commands to list exported symbols. export_symbols_cmds=$lt_export_symbols_cmds_CXX # Symbols that should not be listed in the preloaded symbols. exclude_expsyms=$lt_exclude_expsyms_CXX # Symbols that must always be exported. include_expsyms=$lt_include_expsyms_CXX # Commands necessary for linking programs (against libraries) with templates. prelink_cmds=$lt_prelink_cmds_CXX # Commands necessary for finishing linking programs. postlink_cmds=$lt_postlink_cmds_CXX # Specify filename containing input files. file_list_spec=$lt_file_list_spec_CXX # How to hardcode a shared library path into an executable. hardcode_action=$hardcode_action_CXX # The directories searched by this compiler when creating a shared library. compiler_lib_search_dirs=$lt_compiler_lib_search_dirs_CXX # Dependencies to place before and after the objects being linked to # create a shared library. predep_objects=$lt_predep_objects_CXX postdep_objects=$lt_postdep_objects_CXX predeps=$lt_predeps_CXX postdeps=$lt_postdeps_CXX # The library search path used internally by the compiler when linking # a shared library. compiler_lib_search_path=$lt_compiler_lib_search_path_CXX # ### END LIBTOOL TAG CONFIG: CXX _LT_EOF cat <<_LT_EOF >> "$ofile" # ### BEGIN LIBTOOL TAG CONFIG: FC # The linker used to build libraries. LD=$lt_LD_FC # How to create reloadable object files. reload_flag=$lt_reload_flag_FC reload_cmds=$lt_reload_cmds_FC # Commands used to build an old-style archive. old_archive_cmds=$lt_old_archive_cmds_FC # A language specific compiler. CC=$lt_compiler_FC # Is the compiler the GNU compiler? with_gcc=$GCC_FC # Compiler flag to turn off builtin functions. no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag_FC # Additional compiler flags for building library objects. pic_flag=$lt_lt_prog_compiler_pic_FC # How to pass a linker flag through the compiler. wl=$lt_lt_prog_compiler_wl_FC # Compiler flag to prevent dynamic linking. link_static_flag=$lt_lt_prog_compiler_static_FC # Does compiler simultaneously support -c and -o options? compiler_c_o=$lt_lt_cv_prog_compiler_c_o_FC # Whether or not to add -lc for building shared libraries. build_libtool_need_lc=$archive_cmds_need_lc_FC # Whether or not to disallow shared libs when runtime libs are static. allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes_FC # Compiler flag to allow reflexive dlopens. export_dynamic_flag_spec=$lt_export_dynamic_flag_spec_FC # Compiler flag to generate shared objects directly from archives. whole_archive_flag_spec=$lt_whole_archive_flag_spec_FC # Whether the compiler copes with passing no objects directly. compiler_needs_object=$lt_compiler_needs_object_FC # Create an old-style archive from a shared archive. old_archive_from_new_cmds=$lt_old_archive_from_new_cmds_FC # Create a temporary old-style archive to link instead of a shared archive. old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds_FC # Commands used to build a shared archive. archive_cmds=$lt_archive_cmds_FC archive_expsym_cmds=$lt_archive_expsym_cmds_FC # Commands used to build a loadable module if different from building # a shared archive. module_cmds=$lt_module_cmds_FC module_expsym_cmds=$lt_module_expsym_cmds_FC # Whether we are building with GNU ld or not. with_gnu_ld=$lt_with_gnu_ld_FC # Flag that allows shared libraries with undefined symbols to be built. allow_undefined_flag=$lt_allow_undefined_flag_FC # Flag that enforces no undefined symbols. no_undefined_flag=$lt_no_undefined_flag_FC # Flag to hardcode \$libdir into a binary during linking. # This must work even if \$libdir does not exist hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_FC # Whether we need a single "-rpath" flag with a separated argument. hardcode_libdir_separator=$lt_hardcode_libdir_separator_FC # Set to "yes" if using DIR/libNAME\${shared_ext} during linking hardcodes # DIR into the resulting binary. hardcode_direct=$hardcode_direct_FC # Set to "yes" if using DIR/libNAME\${shared_ext} during linking hardcodes # DIR into the resulting binary and the resulting library dependency is # "absolute",i.e impossible to change by setting \${shlibpath_var} if the # library is relocated. hardcode_direct_absolute=$hardcode_direct_absolute_FC # Set to "yes" if using the -LDIR flag during linking hardcodes DIR # into the resulting binary. hardcode_minus_L=$hardcode_minus_L_FC # Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR # into the resulting binary. hardcode_shlibpath_var=$hardcode_shlibpath_var_FC # Set to "yes" if building a shared library automatically hardcodes DIR # into the library and all subsequent libraries and executables linked # against it. hardcode_automatic=$hardcode_automatic_FC # Set to yes if linker adds runtime paths of dependent libraries # to runtime path list. inherit_rpath=$inherit_rpath_FC # Whether libtool must link a program against all its dependency libraries. link_all_deplibs=$link_all_deplibs_FC # Set to "yes" if exported symbols are required. always_export_symbols=$always_export_symbols_FC # The commands to list exported symbols. export_symbols_cmds=$lt_export_symbols_cmds_FC # Symbols that should not be listed in the preloaded symbols. exclude_expsyms=$lt_exclude_expsyms_FC # Symbols that must always be exported. include_expsyms=$lt_include_expsyms_FC # Commands necessary for linking programs (against libraries) with templates. prelink_cmds=$lt_prelink_cmds_FC # Commands necessary for finishing linking programs. postlink_cmds=$lt_postlink_cmds_FC # Specify filename containing input files. file_list_spec=$lt_file_list_spec_FC # How to hardcode a shared library path into an executable. hardcode_action=$hardcode_action_FC # The directories searched by this compiler when creating a shared library. compiler_lib_search_dirs=$lt_compiler_lib_search_dirs_FC # Dependencies to place before and after the objects being linked to # create a shared library. predep_objects=$lt_predep_objects_FC postdep_objects=$lt_postdep_objects_FC predeps=$lt_predeps_FC postdeps=$lt_postdeps_FC # The library search path used internally by the compiler when linking # a shared library. compiler_lib_search_path=$lt_compiler_lib_search_path_FC # ### END LIBTOOL TAG CONFIG: FC _LT_EOF ;; esac done # for ac_tag as_fn_exit 0 _ACEOF ac_clean_files=$ac_clean_files_save test $ac_write_fail = 0 || as_fn_error $? "write failure creating $CONFIG_STATUS" "$LINENO" 5 # configure is writing to config.log, and then calls config.status. # config.status does its own redirection, appending to config.log. # Unfortunately, on DOS this fails, as config.log is still kept open # by configure, so config.status won't be able to write to it; its # output is simply discarded. So we exec the FD to /dev/null, # effectively closing config.log, so it can be properly (re)opened and # appended to by config.status. When coming back to configure, we # need to make the FD available again. if test "$no_create" != yes; then ac_cs_success=: ac_config_status_args= test "$silent" = yes && ac_config_status_args="$ac_config_status_args --quiet" exec 5>/dev/null $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false exec 5>>config.log # Use ||, not &&, to avoid exiting from the if with $? = 1, which # would make configure fail if this is the last instruction. $ac_cs_success || as_fn_exit 1 fi # # CONFIG_SUBDIRS section. # if test "$no_recursion" != yes; then # Remove --cache-file, --srcdir, and --disable-option-checking arguments # so they do not pile up. ac_sub_configure_args= ac_prev= eval "set x $ac_configure_args" shift for ac_arg do if test -n "$ac_prev"; then ac_prev= continue fi case $ac_arg in -cache-file | --cache-file | --cache-fil | --cache-fi \ | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) ac_prev=cache_file ;; -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* \ | --c=*) ;; --config-cache | -C) ;; -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) ac_prev=srcdir ;; -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) ;; -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) ac_prev=prefix ;; -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) ;; --disable-option-checking) ;; *) case $ac_arg in *\'*) ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; esac as_fn_append ac_sub_configure_args " '$ac_arg'" ;; esac done # Always prepend --prefix to ensure using the same prefix # in subdir configurations. ac_arg="--prefix=$prefix" case $ac_arg in *\'*) ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; esac ac_sub_configure_args="'$ac_arg' $ac_sub_configure_args" # Pass --silent if test "$silent" = yes; then ac_sub_configure_args="--silent $ac_sub_configure_args" fi # Always prepend --disable-option-checking to silence warnings, since # different subdirs can have different --enable and --with options. ac_sub_configure_args="--disable-option-checking $ac_sub_configure_args" ac_popdir=`pwd` for ac_dir in : $subdirs; do test "x$ac_dir" = x: && continue # Do not complain, so a configure script can configure whichever # parts of a large source tree are present. test -d "$srcdir/$ac_dir" || continue ac_msg="=== configuring in $ac_dir (`pwd`/$ac_dir)" $as_echo "$as_me:${as_lineno-$LINENO}: $ac_msg" >&5 $as_echo "$ac_msg" >&6 as_dir="$ac_dir"; as_fn_mkdir_p ac_builddir=. case "$ac_dir" in .) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` # A ".." for each directory in $ac_dir_suffix. ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` case $ac_top_builddir_sub in "") ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; esac ;; esac ac_abs_top_builddir=$ac_pwd ac_abs_builddir=$ac_pwd$ac_dir_suffix # for backward compatibility: ac_top_builddir=$ac_top_build_prefix case $srcdir in .) # We are building in place. ac_srcdir=. ac_top_srcdir=$ac_top_builddir_sub ac_abs_top_srcdir=$ac_pwd ;; [\\/]* | ?:[\\/]* ) # Absolute name. ac_srcdir=$srcdir$ac_dir_suffix; ac_top_srcdir=$srcdir ac_abs_top_srcdir=$srcdir ;; *) # Relative name. ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix ac_top_srcdir=$ac_top_build_prefix$srcdir ac_abs_top_srcdir=$ac_pwd/$srcdir ;; esac ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix cd "$ac_dir" # Check for guested configure; otherwise get Cygnus style configure. if test -f "$ac_srcdir/configure.gnu"; then ac_sub_configure=$ac_srcdir/configure.gnu elif test -f "$ac_srcdir/configure"; then ac_sub_configure=$ac_srcdir/configure elif test -f "$ac_srcdir/configure.in"; then # This should be Cygnus configure. ac_sub_configure=$ac_aux_dir/configure else { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: no configuration information is in $ac_dir" >&5 $as_echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2;} ac_sub_configure= fi # The recursion is here. if test -n "$ac_sub_configure"; then # Make the cache file name correct relative to the subdirectory. case $cache_file in [\\/]* | ?:[\\/]* ) ac_sub_cache_file=$cache_file ;; *) # Relative name. ac_sub_cache_file=$ac_top_build_prefix$cache_file ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: running $SHELL $ac_sub_configure $ac_sub_configure_args --cache-file=$ac_sub_cache_file --srcdir=$ac_srcdir" >&5 $as_echo "$as_me: running $SHELL $ac_sub_configure $ac_sub_configure_args --cache-file=$ac_sub_cache_file --srcdir=$ac_srcdir" >&6;} # The eval makes quoting arguments work. eval "\$SHELL \"\$ac_sub_configure\" $ac_sub_configure_args \ --cache-file=\"\$ac_sub_cache_file\" --srcdir=\"\$ac_srcdir\"" || as_fn_error $? "$ac_sub_configure failed for $ac_dir" "$LINENO" 5 fi cd "$ac_popdir" done fi if test -n "$ac_unrecognized_opts" && test "$enable_option_checking" != no; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: unrecognized options: $ac_unrecognized_opts" >&5 $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;} fi eztrace-1.1-2/configure.ac000066400000000000000000000637061265506773700154730ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. # # -*- Autoconf -*- # Process this file with autoconf to produce a configure script. AC_PREREQ([2.63]) AC_INIT([eztrace], [1.1-2], [eztrace-devel@lists.gforge.inria.fr]) AM_INIT_AUTOMAKE([1.10 tar-pax color-tests subdir-objects]) # Checks for programs. AC_PROG_CC AC_PROG_FC AC_PROG_CXX AC_LANG_CPLUSPLUS AC_PROG_INSTALL AC_PROG_MAKE_SET AC_PROG_LIBTOOL AM_PROG_CC_C_O AC_CONFIG_MACRO_DIR([m4]) F77=$(FC) FFLAGS=$(FCFLAGS) dnl Don't generate 'configure' if pkg.m4 is missing. m4_pattern_forbid([PKG_CHECK_MODULES]) AC_PATH_PROG([MPICC], [mpicc]) AC_PATH_PROG(PERL,perl) #AC_CHECK_PROG(PERL,perl,yes,missing -- the perl scripting language) # crappy hack: of the macros AC_PROG_{CC,CXX,F77,FC}, only the # first expanded one will check for object file extension etc, # and fail if that doesn't work. if test x$FC = x; then AC_MSG_ERROR(A Fortran compiler is required) fi cxx_enable=yes if test x$CXX = x; then cxx_enable=no fi # Correct install paths AS_IF([test x"$prefix" = x -o x"$prefix" = "xNONE"], [prefix="/usr/local"]) AS_IF([test x"$exec_prefix" = x -o x"$exec_prefix" = "xNONE"], [exec_prefix="\${prefix}"]) AS_IF([test "$docdir" = "\${datarootdir}/doc/\${PACKAGE_TARNAME}"],[docdir="\${datarootdir}/doc/eztrace"]) top_build_dir=`pwd` get_abs_dirname() { # $1 : relative filename cd $1 && \ pwd &&\ cd - > /dev/null } abs_srcdir=$(get_abs_dirname $srcdir) # Checks for libraries. AC_CHECK_LIB([dl], [dlsym]) AC_CHECK_LIB([m], [cos]) AC_CHECK_LIB([pthread], [pthread_create]) AC_CHECK_LIB([pthread], [pthread_spin_lock], have_full_pthread=yes, have_full_pthread=no) AC_CHECK_LIB([z], [deflate]) AC_CHECK_LIB([iberty], [cplus_demangle]) AC_CHECK_LIB([bfd], [bfd_demangle]) # Check the OS type os_type=`uname -s` if [ test "x$os_type" = "xLinux" ]; then # Linux AC_MSG_WARN([OS: Linux]) CFLAGS="$CFLAGS -DHAVE_LINUX -Wno-unused-parameter -Wno-unused-value" DYNLIB_EXT=".so" LD_PRELOAD_NAME="LD_PRELOAD" LD_LIBRARY_PATH_NAME="LD_LIBRARY_PATH" elif [ test "x$os_type" = "xDarwin" ]; then # Mac OS AC_MSG_WARN([OS: Mac OS]) CFLAGS="$CFLAGS -DHAVE_DARWIN" DYNLIB_EXT=".dylib" LD_PRELOAD_NAME="DYLD_INSERT_LIBRARIES" LD_LIBRARY_PATH_NAME="DYLD_LIBRARY_PATH" else # unknown OS, let's try Linux AC_MSG_WARN([unknown OS: falling back to Linux]) CFLAGS="$CFLAGS -DHAVE_LINUX" DYNLIB_EXT=".so" LD_PRELOAD_NAME="LD_PRELOAD" LD_LIBRARY_PATH_NAME="LD_LIBRARY_PATH" fi # Check the architecture type case "$host" in x86_64-*) dnl ---Test for x32 ABI in x86_64 AC_EGREP_CPP(x32_test, [#if defined(__x86_64__) && defined (__ILP32__) x32_test #endif ], SUBARCH='x32', SUBARCH='64') if test "$SUBARCH" = "64" ; then AC_MSG_WARN([ARCH: X86_64]) arch_str="X86_64" else AC_MSG_WARN([unsupported x86_64 architecture. Some features will be disabled]) fi ;; armv7|arm*-*gnueabihf) AC_MSG_WARN([ARCH: ARM]) arch_str="ARM" CFLAGS="$CFLAGS -marm" ;; *) AC_MSG_WARN([unknown architecture: falling back to x86_64]) ;; esac # Check for a library with a particular LDFLAGS # this LDFLAGS is not set in the 'final' LDFLAGS # This is usefull if only a small part of your program # needs this library # # example: #CHECK_LIB_LDFLAGS([gtg], # [setTraceType], # "$GTG_LDFLAGS", # , # AC_MSG_ERROR([cannot find libgtg])) AC_DEFUN([CHECK_LIB_LDFLAGS], [save_LDFLAGS="$LDFLAGS" save_LIBS="$LIBS" LDFLAGS="$LDFLAGS $3" AC_CHECK_LIB([$1], [$2], [$4], [$5]) LDFLAGS="$save_LDFLAGS" LIBS="$save_LIBS" ]) # Check for a library with a particular LDFLAGS # this LDFLAGS is not set in the 'final' LDFLAGS # This is usefull if only a small part of your program # needs this library # # example: #CHECK_LIB_TRYLINK("$GTG_LDFLAGS", # [#include "GTG.h"], # [gtg_container_t c;], # [enable_gtg=yes], # AC_MSG_ERROR([cannot find libgtg])) AC_DEFUN([CHECK_LIB_TRYLINK], [save_LDFLAGS="$LDFLAGS" save_LIBS="$LIBS" LDFLAGS="$LDFLAGS $1" AC_TRY_LINK([$2], [$3], [$4], [$5]) LDFLAGS="$save_LDFLAGS" LIBS="$save_LIBS" ]) # Check for a header with a particular CPPFLAGS # this CPPFLAGS is not set in the 'final' CPPFLAGS # This is usefull if only a small part of your program # needs this header # # example: # CHECK_HEADER_CPPFLAGS([GTGBasic1.h], # , # "$GTG_CPPFLAGS", # AC_MSG_ERROR([cannot find headers for gtg])) AC_DEFUN([CHECK_HEADER_CPPFLAGS], [save_CPPFLAGS="$CPPFLAGS" CPPFLAGS="$CPPFLAGS $3" AC_CHECK_HEADERS([$1], [$2], [$4], [$5]) CPPFLAGS="$save_CPPFLAGS" ]) # Checks for programs AC_CHECK_PROG(HAVE_ENV, [env], yes, no) if test x$HAVE_ENV = xno ; then AC_MSG_ERROR([Cannot find env]) fi # Checks for header files. # this is needed because demangle.h and string.h have confliting versions of the basename function AC_CHECK_DECLS([basename], [], [], [[#include ]]) AC_CHECK_HEADERS([fcntl.h limits.h malloc.h stdint.h stdlib.h string.h sys/time.h unistd.h sys/syscall.h]) have_demangle=yes AC_CHECK_HEADER([demangle.h], , have_demangle=no) AC_CHECK_LIB([iberty], [cplus_demangle], , have_demangle=no) AM_CONDITIONAL([HAVE_DEMANGLE], [test "x$have_demangle" = xyes]) AC_CHECK_LIB([bfd], [bfd_release]) # Checks for typedefs, structures, and compiler characteristics. AC_TYPE_SIZE_T AC_TYPE_UINT64_T # Checks for library functions. AC_FUNC_MALLOC AC_CHECK_FUNCS([atexit]) build_doc=no AC_ARG_WITH(doc, [AS_HELP_STRING([--with-doc], [Generate documentation])], [if test x$withval != xno ; then build_doc=yes fi], [ build_doc=no ]) if test "x$build_doc" = "xyes" ; then AC_MSG_RESULT(Documentation will be generated) else AC_MSG_RESULT(Documentation will not be generated) fi # pptrace stuff use_pptrace=yes AC_ARG_ENABLE([pptrace], AC_HELP_STRING([--enable-pptrace], [Enable pptrace])) if test "x$enable_pptrace" = xno; then AC_MSG_RESULT(PPTrace explicitly disabled) use_pptrace=no fi if test "x$use_pptrace" = xyes; then pptrace_lib_found=yes#no pptrace_binary_type=1 AC_CHECK_LIB(bfd, bfd_release, [pptrace_binary_type=1], AC_MSG_ERROR([Error! You need to have libbfd]) ) AC_CHECK_LIB([z], [deflate],[], AC_MSG_ERROR([Error! Missing dependancy for libbfd (libiberty)])) # check if the arch/OS is supported by pptrace if [ test "x$arch_str" = "xX86_64" ] || [ test "x$arch_str" = "xARM" ] ; then if [ test "x$os_type" = "xLinux" ]; then use_pptrace=yes else use_pptrace=no AC_MSG_WARN([The target OS is not supported by pptrace. The instrumentation will be limited to shared libraries]) fi else AC_MSG_WARN([The target architecture is not supported by pptrace. The instrumentation will be limited to shared libraries]) use_pptrace=no fi if test "x$use_pptrace" = xyes; then AC_MSG_RESULT(PPTrace enabled) else AC_MSG_RESULT(PPTrace cannot be installed) fi fi AC_CHECK_LIB([opcodes], disassembler, [ libopcode_found=yes AC_SUBST(HAVE_LIBOPCODE, 1) AC_MSG_RESULT(libopcode found.) ], [libopcode_found=no]) AM_CONDITIONAL([HAVE_LIBOPCODE], [test "$libopcode_found" = yes]) AM_CONDITIONAL([USE_PPTRACE], [test "$use_pptrace" = yes]) AC_SUBST(PPTRACE_BINARY_TYPE, 1) AC_CHECK_HEADER([sys/prctl.h], [ AC_CHECK_FUNC(prctl, [have_prctl_h=1], [have_prctl_h=0]) ], [have_prctl_h=0]) AC_SUBST(HAVE_PRCTL_H, [$have_prctl_h]) # -m32 & -m64 flags for tests AC_MSG_CHECKING([whether $CC supports -m32 and -m64]) _save_cflags="$CFLAGS" _save_ldflags="$LDFLAGS" CFLAGS="$CFLAGS -m32" LDFLAGS="$LDFLAGS -m32" AC_LINK_IFELSE([AC_LANG_SOURCE([#include int main(void) { printf("Hello, World!\n"); return 0;}])], [m32_flag=yes], [m32_flag=no]); CFLAGS="$_save_cflags -m64" LDFLAGS="$_save_ldflags -m64" AC_LINK_IFELSE([AC_LANG_SOURCE([#include int main(void) { printf("Hello, World!\n"); return 0;}])], [m64_flag=yes], [m64_flag=no]); CFLAGS="$_save_cflags" LDFLAGS="$_save_ldflags" if test "x$m64_flag" = "xyes"; then if test "x$m32_flag" = "xyes"; then available_target_bits="32 64" supported_mXX_flags="-m32 -m64" else available_target_bits="64" supported_mXX_flags="-m64" fi else if test "x$m32_flag" = "xyes"; then available_target_bits="32" supported_mXX_flags="-m32" else available_target_bits="" supported_mXX_flags="" fi fi AC_MSG_RESULT([supports $supported_mXX_flags]) AC_SUBST(TARGET_BITS, $available_target_bits) use_starpu=yes AC_ARG_WITH(starpu, [AS_HELP_STRING([--with-starpu[=]], [generate traces for StarPU])], [ if test x$withval != xno; then # use specified path starpudir=$withval AC_MSG_RESULT(starpu using $starpudir) AC_SUBST(STARPU_ROOT, $starpudir) PKG_CONFIG_PATH=${PKG_CONFIG_PATH}${PKG_CONFIG_PATH:+:}${starpudir}/lib/pkgconfig else use_starpu=no fi ], [use_starpu=no]) if test x$use_starpu = xyes ; then use_starpu=no for STARPU in starpu-1.1 starpu-1.3 do PKG_CHECK_MODULES([STARPU], [$STARPU], [starpu_found=yes], [starpu_found=no]) if test x$starpu_found = xyes then break; fi done STARPU_CPPFLAGS=$STARPU_CFLAGS STARPU_LDFLAGS=$STARPU_LIBS #check for starpu headers CHECK_HEADER_CPPFLAGS([starpu.h], [use_starpu=yes], "$STARPU_CPPFLAGS", AC_MSG_WARN([cannot find starpu.h])) if test x$use_starpu = xyes ; then CHECK_LIB_LDFLAGS($STARPU, [starpu_task_submit],"$STARPU_LDFLAGS", [use_starpu=yes] , [ AC_MSG_WARN([cannot find libstarpu]) use_starpu=no ]) AC_SUBST(STARPU_CPPFLAGS) AC_SUBST(STARPU_LDFLAGS) fi fi use_litl=yes use_extern_litl=no LITL_PRINT=${top_build_dir}/extlib/litl/utils/litl_print AC_ARG_WITH(litl, [AS_HELP_STRING([--with-litl[= or =]], [generate LiTL traces [ARG=yes]])], [ if test x$withval != xno; then use_litl=yes if test x$withval = xyes; then AC_MSG_RESULT(yes) else # use specified path use_extern_litl=yes litldir=$withval AC_MSG_RESULT(yes using $litldir) AC_SUBST(LITL_ROOT, $litldir) LITL_PRINT=$litldir/bin/litl_print fi else use_litl=no AC_MSG_ERROR("LiTL is required for eztrace") fi ]) # --> LiTL if test x$use_extern_litl = xyes; then # use an external installation of LiTL extern_litl_found=yes use_intern_litl=no use_extern_litl=yes TL_CPPFLAGS="${TL_CPPFLAGS} -I${litldir}/include" TL_LDFLAGS="${TL_LDFLAGS} -L${litldir}/lib -Wl,-rpath,${litldir}/lib" TL_LIB="-llitl" TL_EXT_CPPFLAGS="$TL_CPPFLAGS" TL_EXT_LDFLAGS="$TL_LDFLAGS" TL_EXT_LIB="$TL_LIB" else # use the LiTL version shipped with eztrace extern_litl_found=no use_intern_litl=yes use_extern_litl=no dnl configure litl from extlib litl_parent_dir=`pwd` litl_dir="extlib/litl" AC_MSG_NOTICE([configuring in litl_dir ($litl_parent_dir/$litl_dir)]) AS_IF([test "$srcdir" != "."], [ test -d "$litl_dir" || mkdir -p "$litl_dir" || AC_MSG_ERROR([cannot create $litl_dir]) ]) case $srcdir in .) litl_srcdir="$srcdir" ;; /*) litl_srcdir="$srcdir/$litl_dir" ;; *) litl_srcdir="../../$srcdir/$litl_dir" ;; esac litl_conf_cmd="$litl_srcdir/configure" litl_conf_args="$litl_conf_args --prefix=\"$prefix\" --exec-prefix=\"$exec_prefix\" --bindir=\"$bindir\" --libdir=\"$libdir\" --includedir=\"$includedir\" --docdir=\"$docdir/litl\" $TLFLAGS --cache-file=\"/dev/null\" --srcdir=\"$litl_srcdir\"" if test "x$build_doc" = "xyes" ; then litl_conf_args="$litl_conf_args --with-doc=\"$build_doc\"" fi AC_MSG_NOTICE([running $SHELL $litl_conf_cmd $litl_conf_args]) cd $litl_dir eval "$SHELL '$litl_conf_cmd' $litl_conf_args" AS_IF([test $? != "0"], [AC_MSG_ERROR([$litl_conf_cmd failed for $litl_dir])]) cd $litl_parent_dir AS_IF([test x"$TLLIB" = x], [TLLIB="-llitl"]) TL_CPPFLAGS="$TL_CPPFLAGS -I${abs_srcdir}/extlib/litl/src -I${top_build_dir}/extlib/litl/src" TL_LDFLAGS="${top_build_dir}/extlib/litl/src/liblitl.la" TL_LIB="" TL_EXT_CPPFLAGS="-I${prefix}/include/" TL_EXT_LDFLAGS="-L${prefix}/lib/" TL_EXT_LIB="-llitl" fi #TL_LIB="-llitl" if test x$extern_litl_found = xyes ; then CPPFLAGS="${CPPFLAGS} ${TL_CPPFLAGS}" LDFLAGS="${LDFLAGS} ${TL_LDFLAGS}" AC_CHECK_HEADER([litl_types.h],,AC_MSG_ERROR([cannot find headers for LiTL])) AC_CHECK_HEADER([litl_write.h],,AC_MSG_ERROR([cannot find headers for LiTL])) AC_CHECK_HEADER([litl_read.h],,AC_MSG_ERROR([cannot find headers for LiTL])) fi # <-- LiTL L_CPPFLAGS="${TL_CPPFLAGS} -DUSE_LITL -DRECORD_PACKED_EVENTS" L_EXT_CPPFLAGS="${TL_EXT_CPPFLAGS} -DUSE_LITL -DRECORD_PACKED_EVENTS" # by default tid recording is enabled LiTL TID_RECORDING_ENABLED=yes if test "x$TID_RECORDING_ENABLED" = xyes ; then CFLAGS="$CFLAGS -DTID_RECORDING_ENABLED" TL_CPPFLAGS="${TL_CPPFLAGS} -DTID_RECORDING_ENABLED" TL_EXT_CPPFLAGS="${TL_EXT_CPPFLAGS} -DTID_RECORDING_ENABLED" fi # check for openmp CHECK_HEADER_CPPFLAGS([omp.h], [openmp_found=yes], "-fopenmp", AC_MSG_WARN([cannot find omp.h])) use_papi=yes AC_ARG_WITH(papi, [AS_HELP_STRING([--with-papi[=]], [PAPI])], [ if test x$withval != xno; then use_papi=yes if test x$withval = xyes; then AC_MSG_RESULT(yes) use_papi_from_system=yes else # use specified path use_papi_from_system=no papidir=$withval AC_MSG_RESULT(yes using $papidir) AC_SUBST(PAPIDIR, $papidir) fi else use_papi=no AC_MSG_RESULT(no) fi ]) AC_SUBST(USE_PAPIDIR_FROM_USER,$use_papi_from_system) if test x$use_papi_from_system = xno; then PAPI_LIBDIR=$papidir/lib PAPI_CPPFLAGS="-I$papidir/include/" PAPI_LDFLAGS="-L${PAPI_LIBDIR} -Xlinker -rpath=${PAPI_LIBDIR}" elif test x$use_papi = xyes ; then if test -d "/usr/include/papi" ; then PAPI_CPPFLAGS="-I/usr/include/papi/" fi if test -d "/usr/lib/PAPI" ; then PAPI_LIBDIR=/usr/lib/papi PAPI_LDFLAGS="-L/usr/lib/papi -Xlinker -rpath=/usr/lib/papi" fi fi enable_papi=no if test x$use_papi = xyes ; then save_CPPFLAGS="$CPPFLAGS" CPPFLAGS="$CPPFLAGS $PAPI_CPPFLAGS" CHECK_LIB_TRYLINK([$PAPI_LDFLAGS -lpapi], [#include ], [PAPI_event_info_t plop;], [enable_papi=yes], AC_MSG_WARN([cannot find PAPI lib])) CPPFLAGS="$save_CPPFLAGS" if test x$enable_papi = xyes; then enable_papi=no CHECK_HEADER_CPPFLAGS([papi.h], [enable_papi=yes], "$PAPI_CPPFLAGS", AC_MSG_WARN([cannot find headers for PAPI])) fi if test x$enable_papi = xyes; then CFLAGS="$CFLAGS -DUSE_PAPI" fi fi # MPI stuff MPI_ROOT= MPI_INC= use_mpi=yes use_mpi3=no use_mpi_from_system=yes AC_ARG_WITH(mpi, [AS_HELP_STRING([--with-mpi[=]], [Use a specific MPI installation])], [ if test x$withval != xno; then if test x$withval = xyes; then AC_MSG_RESULT(yes) use_mpi_from_system=yes else # use specified path use_mpi_from_system=no mpidir=$withval AC_MSG_RESULT(Using MPI installation: $mpidir) MPI_ROOT=$mpidir AC_SUBST(MPI_ROOT, $mpidir) fi else # either --without-mpi or --with-mpi=no is set use_mpi=no fi ]) AC_ARG_WITH(mpi-include, [AS_HELP_STRING([--with-mpi-include[=]], [Use a specific MPI header])], [ if test x$withval != xno; then if test x$withval = xyes; then AC_MSG_RESULT(yes) use_mpi_from_system=yes else # use specified path use_mpi_from_system=no mpidir=$withval AC_MSG_RESULT(MPI include directory: $mpidir) MPI_INC=$mpidir AC_SUBST(MPI_INC, $mpidir) fi fi ]) if test x$MPI_INC != x; then # use the value supplied by --with-mpi-include CPPFLAGS="${CPPFLAGS} -I$MPI_INC/" FCFLAGS="${FCFLAGS} -I$MPI_INC/" elif test x$MPI_ROOT != x; then # use the value supplied by --with-mpi CPPFLAGS="${CPPFLAGS} -I$MPI_ROOT/include/ " FCFLAGS="${FCFLAGS} -I$MPI_ROOT/include/ " fi mpi_ldflags= AC_ARG_WITH(mpi-ldflags, [AS_HELP_STRING([--with-mpi-ldflags[=]], [Use a specific LDFLAGS when compiling MPI files])], [if test "x$withval" != "xno"; then # use specified path mpi_ldflags=$withval AC_MSG_RESULT(MPI LDFLAGS: $mpi_ldflags) AC_SUBST(MPI_LDFLAGS, mpi_ldflags) fi]) MPI_LDFLAGS="-lmpi" if test "x$mpi_ldflags" != "x"; then # use the value supplied by --with-mpi-include MPI_LDFLAGS="$mpi_ldflags" elif test x$MPI_ROOT != x; then # use the value supplied by --with-mpi MPI_LDFLAGS="-L$MPI_ROOT/lib -lmpi" fi if test $use_mpi = yes ; then AC_SUBST(USE_MPIDIR_FROM_USER,$use_mpi_from_system) # MPI header AC_CHECK_HEADER([mpi.h],[enable_mpi=yes],AC_MSG_WARN([cannot find headers for MPI])) if test $enable_mpi = yes ; then AC_CHECK_DECLS(MPI_Ibarrier, [use_mpi3=yes], [use_mpi3=no], [[#include ]]) fi else enable_mpi=no fi mpi_module_name=mpi AC_ARG_WITH(mpi-module-name, [AS_HELP_STRING([--with-mpi-module-name=], [Change the name of the MPI module])], [ if test x$withval != x; then mpi_module_name=$withval AC_MSG_RESULT([Changing the name of the MPI module to $mpi_module_name]) else # either --without-mpi or --with-mpi=no is set AC_MSG_RESULT([Please provide a name to the --with-mpi-module-name option]) fi ]) mpi_event_id=4 AC_ARG_WITH(mpi-event-id, [AS_HELP_STRING([--with-mpi-event-id=id>], [Change the ID of the MPI events])], [ if test x$withval != x; then mpi_event_id=$withval AC_MSG_RESULT([Changing the ID of MPI events $mpi_event_id]) else # either --without-mpi or --with-mpi=no is set AC_MSG_RESULT([Please provide an ID to the --with-mpi-event-id option]) fi ]) AC_SUBST(MPI_LDFLAGS, $MPI_LDFLAGS) AC_SUBST(MPI_MODULE_NAME, $mpi_module_name) AC_SUBST(MPI_EVENT_ID, $mpi_event_id) # GTG stuff use_extern_gtg=no AC_ARG_WITH(gtg, [AS_HELP_STRING([--with-gtg[=]], [path to libgtg])], [ if test x$withval != xno; then if test x$withval = xyes; then AC_MSG_RESULT(yes) else # use specified path use_extern_gtg=yes gtgdir=$withval AC_MSG_RESULT(yes using gtgdir) AC_SUBST(GTGDIR, $gtgdir) fi else AC_MSG_RESULT(no) AC_MSG_ERROR([Cannot find GTG]) fi ]) if test x$use_extern_gtg = xyes; then GTG_CPPFLAGS="${CPPFLAGS} -I$gtgdir/include/" GTG_LDFLAGS="${LDFLAGS} -L$gtgdir/lib/" GTG_DEPENDENCIES="" GTG_LIB="-lgtg" GTG_EXT_CPPFLAGS="${GTG_CPPFLAGS}" GTG_EXT_LDFLAGS="$GTGLDFLAGS" GTG_EXT_LIB="-lgtg" CHECK_LIB_LDFLAGS([gtg], [setTraceType],"$GTG_LDFLAGS", , AC_MSG_ERROR([cannot find libgtg])) CHECK_LIB_LDFLAGS([gtg], [gtg_record],"$GTG_LDFLAGS", GTG_OUT_OF_ORDER=1, GTG_OUT_OF_ORDER=0) CHECK_HEADER_CPPFLAGS([GTG.h],, "$GTG_CPPFLAGS", AC_MSG_ERROR([cannot find headers for gtg])) else GTG_OUT_OF_ORDER=1 dnl configure gtg from extlib gtg_parent_dir=`pwd` gtg_dir="extlib/gtg" AC_MSG_NOTICE([configuring in gtg_dir ($gtg_parent_dir/$gtg_dir)]) AS_IF([test "$srcdir" != "."], [ test -d "$gtg_dir" || mkdir -p "$gtg_dir" || AC_MSG_ERROR([cannot create $gtg_dir]) ]) case $srcdir in .) gtg_srcdir="$srcdir" ;; /*) gtg_srcdir="$srcdir/$gtg_dir" ;; *) gtg_srcdir="../../$srcdir/$gtg_dir" ;; esac gtg_conf_cmd="$gtg_srcdir/configure" gtg_conf_args="$gtg_conf_args --prefix=\"$prefix\" --exec-prefix=\"$exec_prefix\" --bindir=\"$bindir\" --libdir=\"$libdir\" --includedir=\"$includedir\" --docdir=\"$docdir/gtg\" $GTGFLAGS --cache-file=\"/dev/null\" --srcdir=\"$gtg_srcdir\" --with-mpi=no" if test "x$build_doc" = "xyes" ; then gtg_conf_args="$gtg_conf_args --with-doc=\"$build_doc\"" fi AC_MSG_NOTICE([running $SHELL $gtg_conf_cmd $gtg_conf_args]) cd $gtg_dir eval "$SHELL '$gtg_conf_cmd' $gtg_conf_args" AS_IF([test $? != "0"], [AC_MSG_ERROR([$gtg_conf_cmd failed for $gtg_dir])]) cd $gtg_parent_dir GTG_CPPFLAGS="$GTG_CPPFLAGS -I${abs_srcdir}/${gtg_dir}/inc -I${top_build_dir}/${gtg_dir}/inc" GTG_LDFLAGS="${top_build_dir}/${gtg_dir}/src/libgtg.la" GTG_DEPENDENCIES="$GTG_LDFLAGS" GTG_LIB="" GTG_EXT_CPPFLAGS="-I${prefix}/include" GTG_EXT_LDFLAGS="-L${prefix}/lib" GTG_EXT_LIB="-lgtg" fi if [ test "$GTG_OUT_OF_ORDER" = "1" ] ; then GTG_CPPFLAGS="${GTG_CPPFLAGS} -DGTG_OUT_OF_ORDER" GTG_EXT_CPPFLAGS="${GTG_EXT_CPPFLAGS} -DGTG_OUT_OF_ORDER" fi # Check for presence of pdfLaTeX AC_CHECK_PROG(PDFLATEX, pdflatex, pdflatex) if test -z "$PDFLATEX"; then AC_MSG_WARN([Unable to create PDF version of the user manual -- pdflatex is missing!]) fi AM_CONDITIONAL([HAVE_PDFLATEX], test -n "$PDFLATEX") # Check for presence of latexmk AC_CHECK_PROG(LATEXMK, latexmk, latexmk) if test -z "$LATEXMK"; then AC_MSG_WARN([Unable to create PDF version of the user manual -- latemk is missing!]) fi AM_CONDITIONAL([HAVE_LATEXMK], test -n "$LATEXMK") # CUDA stuff CUDA_ROOT=/usr/local/cuda use_cuda=yes use_cuda_from_system=yes AC_ARG_WITH(cuda, [AS_HELP_STRING([--with-cuda[=]], [Use a specific CUDA installation])], [ if test x$withval != xno; then if test x$withval = xyes; then AC_MSG_RESULT(yes) use_cuda_from_system=yes else # use specified path use_cuda_from_system=no cudadir=$withval AC_MSG_RESULT(yes using $cudadir) CUDA_ROOT=$cudadir AC_SUBST(CUDA_ROOT, $cudadir) fi else # either --without-cuda or --with-cuda=no is set use_cuda=no fi ]) enable_cuda=yes if test $use_cuda = yes ; then CUDA_INC=${CUDA_ROOT}/include CUDA_CFLAGS="-I${CUDA_INC}" CUDA_LIBS="-lcudart" CUDA_LDFLAGS="-L${CUDA_ROOT}/lib -Wl,-rpath -Wl,${CUDA_ROOT}/lib" if test x$CUPTI_ROOT = x ; then CUPTI_ROOT="${CUDA_ROOT}/extras/CUPTI" fi CUPTI_INC=${CUPTI_ROOT}/include CUPTI_CFLAGS="-I${CUPTI_INC}" CUPTI_LIBS="-lcupti" CUPTI_LDFLAGS="-L${CUPTI_ROOT}/lib -Wl,-rpath -Wl,${CUPTI_ROOT}/lib" # 64-bits systems CUDA_LDFLAGS="${CUDA_LDFLAGS} -L${CUDA_ROOT}/lib64 -Wl,-rpath -Wl,${CUDA_ROOT}/lib64" CUPTI_LDFLAGS="${CUPTI_LDFLAGS} -L${CUPTI_ROOT}/lib64 -Wl,-rpath -Wl,${CUPTI_ROOT}/lib64 ${CUDA_LDFLAGS}" NVCC="${CUDA_ROOT}/bin/nvcc" AC_SUBST(USE_CUDADIR_FROM_USER,$use_cuda_from_system) # CUDA compiler AC_MSG_CHECKING([for CUDA compiler in $CUDA_ROOT/bin]) if test -x "${NVCC}" ; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([nvcc not found]) enable_cuda=no fi fi if test $enable_cuda = yes ; then # CUDA header AC_MSG_CHECKING([for CUDA header in $CUDA_INC]) if test -f "${CUDA_INC}/cuda.h" ; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([cuda.h not found]) enable_cuda=no fi fi if test $enable_cuda = yes ; then AC_MSG_CHECKING([for CUPTI header in $CUPTI_INC]) if test -f "${CUPTI_INC}/cupti.h" ; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([cupti.h not found]) enable_cuda=no fi fi if test $enable_cuda = yes ; then CHECK_LIB_LDFLAGS([cudart], [cudaMalloc], "$CUDA_LDFLAGS", , AC_MSG_ERROR([cannot find libcudart])) CHECK_LIB_LDFLAGS([cupti], [cuptiSubscribe], "$CUPTI_LDFLAGS", , AC_MSG_ERROR([cannot find libcupti])) else use_cuda=no enable_cuda=no fi if test x$enable_cuda != xyes ; then CUDA_INC= CUDA_CFLAGS= CUDA_LDFLAGS= CUDA_LIBS= CUPTI_INC= CUPTI_CFLAGS= CUPTI_LDFLAGS= CUPTI_LIBS= NVCC= NVCCFLAGS= fi AC_SUBST(CUDA_CFLAGS) AC_SUBST(CUDA_LDFLAGS) AC_SUBST(CUDA_LIBS) AC_SUBST(CUPTI_CFLAGS) AC_SUBST(CUPTI_LDFLAGS) AC_SUBST(CUPTI_LIBS) AC_SUBST(NVCC) AC_SUBST(NVCCFLAGS) AC_ARG_ENABLE([gettid], AC_HELP_STRING([--enable-gettid], [Use syscall(SYS_gettid) to get the thread ID instead of pthread_self(). This however costs a system call for each trace entry])) if test "x$enable_gettid" = xyes; then AC_DEFINE([USE_GETTID], [1], [Use gettid]) fi AC_SUBST(libdir) AC_SUBST(exec_prefix) AC_SUBST(prefix) AC_SUBST(includedir) AC_SUBST(bindir) AC_SUBST(datadir) AC_SUBST(FCFLAGS) # cppflags for compiling eztrace AC_SUBST(TL_CPPFLAGS) AC_SUBST(TL_LDFLAGS) AC_SUBST(TL_LIB) # cppflags for compiling an application that uses eztrace AC_SUBST(TL_EXT_CPPFLAGS) AC_SUBST(TL_EXT_LDFLAGS) AC_SUBST(TL_EXT_LIB) # cppflags for compiling eztrace AC_SUBST(GTG_CPPFLAGS) AC_SUBST(GTG_LDFLAGS) AC_SUBST(GTG_LIB) AC_SUBST(GTG_DEPENDENCIES) # cppflags for compiling an application that uses eztrace AC_SUBST(GTG_EXT_CPPFLAGS) AC_SUBST(GTG_EXT_LDFLAGS) AC_SUBST(GTG_EXT_LIB) AC_SUBST(GTG_OUT_OF_ORDER) AM_CONDITIONAL([GTG_OUT_OF_ORDER], [test "$GTG_OUT_OF_ORDER" = "1"] ) AM_CONDITIONAL([OPENMP_FOUND], [test "x$openmp_found" = xyes]) AC_SUBST(LITL_PRINT) AC_SUBST(PAPI_CPPFLAGS) AC_SUBST(PAPI_LDFLAGS) AC_SUBST(PAPI_LIBDIR) PAPI_ENABLED="$enable_api" AC_SUBST(PAPI_ENABLED) AM_CONDITIONAL([USE_PAPI], [test "$enable_papi" = yes]) AC_SUBST(DYNLIB_EXT) AC_SUBST(LD_PRELOAD_NAME) AC_SUBST(LD_LIBRARY_PATH_NAME) AM_CONDITIONAL([USE_CUDA], [test "$enable_cuda" = yes]) AM_CONDITIONAL([USE_MPI], [test "$enable_mpi" = yes]) AM_CONDITIONAL([USE_MPI3], [test "$use_mpi3" = yes]) AM_CONDITIONAL([USE_PTHREAD], [test "$have_full_pthread" = yes]) AM_CONDITIONAL([USE_STARPU], [test "$use_starpu" = yes]) AM_CONDITIONAL([USE_LITL], [test "x$use_litl" = xyes]) AM_CONDITIONAL([AMEXTERNLITL], [test "x$use_extern_litl" = xyes]) AM_CONDITIONAL([AMEXTERNGTG], [test "x$use_extern_gtg" = xyes]) AM_CONDITIONAL([X86_64], [test "x$arch_str" = "xX86_64"]) AM_CONDITIONAL([ARM], [test "x$arch_str" = "xARM"]) AM_CONDITIONAL([WITHDOC], [test "$build_doc" = "yes"]) AC_CONFIG_SUBDIRS([extlib/opari2 extlib/litl]) AC_OUTPUT([Makefile eztrace.pc \ extlib/Makefile \ src/core/Makefile \ src/modules/omp/Makefile \ src/modules/mpi/Makefile \ src/modules/cuda/Makefile \ src/modules/pthread/Makefile \ src/modules/stdio/Makefile \ src/modules/memory/Makefile \ src/modules/papi/Makefile \ src/modules/starpu/Makefile \ src/core/eztrace_create_plugin \ src/core/eztrace_plugin_generator \ src/core/input/Makefile.template \ src/modules/omp/eztrace_cc \ test/mpi/Makefile \ test/openmp/Makefile \ src/core/eztrace.c \ src/core/eztrace.preload \ src/core/eztrace_config.h \ test/static/Makefile \ test/stdio/Makefile \ test/memory/Makefile \ test/pthread/Makefile \ test/automake/Makefile \ test/automake/testcommon.h \ test/pptrace/automatic/Makefile \ doc/Makefile\ src/modules/omp/pomp-lib-dummy/Makefile]) eztrace-1.1-2/depcomp000077500000000000000000000560161265506773700145560ustar00rootroot00000000000000#! /bin/sh # depcomp - compile a program generating dependencies as side-effects scriptversion=2013-05-30.07; # UTC # Copyright (C) 1999-2014 Free Software Foundation, Inc. # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2, or (at your option) # any later version. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # Originally written by Alexandre Oliva . case $1 in '') echo "$0: No command. Try '$0 --help' for more information." 1>&2 exit 1; ;; -h | --h*) cat <<\EOF Usage: depcomp [--help] [--version] PROGRAM [ARGS] Run PROGRAMS ARGS to compile a file, generating dependencies as side-effects. Environment variables: depmode Dependency tracking mode. source Source file read by 'PROGRAMS ARGS'. object Object file output by 'PROGRAMS ARGS'. DEPDIR directory where to store dependencies. depfile Dependency file to output. tmpdepfile Temporary file to use when outputting dependencies. libtool Whether libtool is used (yes/no). Report bugs to . EOF exit $? ;; -v | --v*) echo "depcomp $scriptversion" exit $? ;; esac # Get the directory component of the given path, and save it in the # global variables '$dir'. Note that this directory component will # be either empty or ending with a '/' character. This is deliberate. set_dir_from () { case $1 in */*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;; *) dir=;; esac } # Get the suffix-stripped basename of the given path, and save it the # global variable '$base'. set_base_from () { base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'` } # If no dependency file was actually created by the compiler invocation, # we still have to create a dummy depfile, to avoid errors with the # Makefile "include basename.Plo" scheme. make_dummy_depfile () { echo "#dummy" > "$depfile" } # Factor out some common post-processing of the generated depfile. # Requires the auxiliary global variable '$tmpdepfile' to be set. aix_post_process_depfile () { # If the compiler actually managed to produce a dependency file, # post-process it. if test -f "$tmpdepfile"; then # Each line is of the form 'foo.o: dependency.h'. # Do two passes, one to just change these to # $object: dependency.h # and one to simply output # dependency.h: # which is needed to avoid the deleted-header problem. { sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile" sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile" } > "$depfile" rm -f "$tmpdepfile" else make_dummy_depfile fi } # A tabulation character. tab=' ' # A newline character. nl=' ' # Character ranges might be problematic outside the C locale. # These definitions help. upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ lower=abcdefghijklmnopqrstuvwxyz digits=0123456789 alpha=${upper}${lower} if test -z "$depmode" || test -z "$source" || test -z "$object"; then echo "depcomp: Variables source, object and depmode must be set" 1>&2 exit 1 fi # Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. depfile=${depfile-`echo "$object" | sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} rm -f "$tmpdepfile" # Avoid interferences from the environment. gccflag= dashmflag= # Some modes work just like other modes, but use different flags. We # parameterize here, but still list the modes in the big case below, # to make depend.m4 easier to write. Note that we *cannot* use a case # here, because this file can only contain one case statement. if test "$depmode" = hp; then # HP compiler uses -M and no extra arg. gccflag=-M depmode=gcc fi if test "$depmode" = dashXmstdout; then # This is just like dashmstdout with a different argument. dashmflag=-xM depmode=dashmstdout fi cygpath_u="cygpath -u -f -" if test "$depmode" = msvcmsys; then # This is just like msvisualcpp but w/o cygpath translation. # Just convert the backslash-escaped backslashes to single forward # slashes to satisfy depend.m4 cygpath_u='sed s,\\\\,/,g' depmode=msvisualcpp fi if test "$depmode" = msvc7msys; then # This is just like msvc7 but w/o cygpath translation. # Just convert the backslash-escaped backslashes to single forward # slashes to satisfy depend.m4 cygpath_u='sed s,\\\\,/,g' depmode=msvc7 fi if test "$depmode" = xlc; then # IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information. gccflag=-qmakedep=gcc,-MF depmode=gcc fi case "$depmode" in gcc3) ## gcc 3 implements dependency tracking that does exactly what ## we want. Yay! Note: for some reason libtool 1.4 doesn't like ## it if -MD -MP comes after the -MF stuff. Hmm. ## Unfortunately, FreeBSD c89 acceptance of flags depends upon ## the command line argument order; so add the flags where they ## appear in depend2.am. Note that the slowdown incurred here ## affects only configure: in makefiles, %FASTDEP% shortcuts this. for arg do case $arg in -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; *) set fnord "$@" "$arg" ;; esac shift # fnord shift # $arg done "$@" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi mv "$tmpdepfile" "$depfile" ;; gcc) ## Note that this doesn't just cater to obsosete pre-3.x GCC compilers. ## but also to in-use compilers like IMB xlc/xlC and the HP C compiler. ## (see the conditional assignment to $gccflag above). ## There are various ways to get dependency output from gcc. Here's ## why we pick this rather obscure method: ## - Don't want to use -MD because we'd like the dependencies to end ## up in a subdir. Having to rename by hand is ugly. ## (We might end up doing this anyway to support other compilers.) ## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like ## -MM, not -M (despite what the docs say). Also, it might not be ## supported by the other compilers which use the 'gcc' depmode. ## - Using -M directly means running the compiler twice (even worse ## than renaming). if test -z "$gccflag"; then gccflag=-MD, fi "$@" -Wp,"$gccflag$tmpdepfile" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" echo "$object : \\" > "$depfile" # The second -e expression handles DOS-style file names with drive # letters. sed -e 's/^[^:]*: / /' \ -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" ## This next piece of magic avoids the "deleted header file" problem. ## The problem is that when a header file which appears in a .P file ## is deleted, the dependency causes make to die (because there is ## typically no way to rebuild the header). We avoid this by adding ## dummy dependencies for each header file. Too bad gcc doesn't do ## this for us directly. ## Some versions of gcc put a space before the ':'. On the theory ## that the space means something, we add a space to the output as ## well. hp depmode also adds that space, but also prefixes the VPATH ## to the object. Take care to not repeat it in the output. ## Some versions of the HPUX 10.20 sed can't process this invocation ## correctly. Breaking it into two sed invocations is a workaround. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; hp) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; sgi) if test "$libtool" = yes; then "$@" "-Wp,-MDupdate,$tmpdepfile" else "$@" -MDupdate "$tmpdepfile" fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files echo "$object : \\" > "$depfile" # Clip off the initial element (the dependent). Don't try to be # clever and replace this with sed code, as IRIX sed won't handle # lines with more than a fixed number of characters (4096 in # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; # the IRIX cc adds comments like '#:fec' to the end of the # dependency line. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \ | tr "$nl" ' ' >> "$depfile" echo >> "$depfile" # The second pass generates a dummy entry for each header file. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ >> "$depfile" else make_dummy_depfile fi rm -f "$tmpdepfile" ;; xlc) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; aix) # The C for AIX Compiler uses -M and outputs the dependencies # in a .u file. In older versions, this file always lives in the # current directory. Also, the AIX compiler puts '$object:' at the # start of each line; $object doesn't have directory information. # Version 6 uses the directory in both cases. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then tmpdepfile1=$dir$base.u tmpdepfile2=$base.u tmpdepfile3=$dir.libs/$base.u "$@" -Wc,-M else tmpdepfile1=$dir$base.u tmpdepfile2=$dir$base.u tmpdepfile3=$dir$base.u "$@" -M fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" do test -f "$tmpdepfile" && break done aix_post_process_depfile ;; tcc) # tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26 # FIXME: That version still under development at the moment of writing. # Make that this statement remains true also for stable, released # versions. # It will wrap lines (doesn't matter whether long or short) with a # trailing '\', as in: # # foo.o : \ # foo.c \ # foo.h \ # # It will put a trailing '\' even on the last line, and will use leading # spaces rather than leading tabs (at least since its commit 0394caf7 # "Emit spaces for -MD"). "$@" -MD -MF "$tmpdepfile" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" # Each non-empty line is of the form 'foo.o : \' or ' dep.h \'. # We have to change lines of the first kind to '$object: \'. sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile" # And for each line of the second kind, we have to emit a 'dep.h:' # dummy dependency, to avoid the deleted-header problem. sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile" rm -f "$tmpdepfile" ;; ## The order of this option in the case statement is important, since the ## shell code in configure will try each of these formats in the order ## listed in this file. A plain '-MD' option would be understood by many ## compilers, so we must ensure this comes after the gcc and icc options. pgcc) # Portland's C compiler understands '-MD'. # Will always output deps to 'file.d' where file is the root name of the # source file under compilation, even if file resides in a subdirectory. # The object file name does not affect the name of the '.d' file. # pgcc 10.2 will output # foo.o: sub/foo.c sub/foo.h # and will wrap long lines using '\' : # foo.o: sub/foo.c ... \ # sub/foo.h ... \ # ... set_dir_from "$object" # Use the source, not the object, to determine the base name, since # that's sadly what pgcc will do too. set_base_from "$source" tmpdepfile=$base.d # For projects that build the same source file twice into different object # files, the pgcc approach of using the *source* file root name can cause # problems in parallel builds. Use a locking strategy to avoid stomping on # the same $tmpdepfile. lockdir=$base.d-lock trap " echo '$0: caught signal, cleaning up...' >&2 rmdir '$lockdir' exit 1 " 1 2 13 15 numtries=100 i=$numtries while test $i -gt 0; do # mkdir is a portable test-and-set. if mkdir "$lockdir" 2>/dev/null; then # This process acquired the lock. "$@" -MD stat=$? # Release the lock. rmdir "$lockdir" break else # If the lock is being held by a different process, wait # until the winning process is done or we timeout. while test -d "$lockdir" && test $i -gt 0; do sleep 1 i=`expr $i - 1` done fi i=`expr $i - 1` done trap - 1 2 13 15 if test $i -le 0; then echo "$0: failed to acquire lock after $numtries attempts" >&2 echo "$0: check lockdir '$lockdir'" >&2 exit 1 fi if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" # Each line is of the form `foo.o: dependent.h', # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. # Do two passes, one to just change these to # `$object: dependent.h' and one to simply `dependent.h:'. sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process this invocation # correctly. Breaking it into two sed invocations is a workaround. sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; hp2) # The "hp" stanza above does not work with aCC (C++) and HP's ia64 # compilers, which have integrated preprocessors. The correct option # to use with these is +Maked; it writes dependencies to a file named # 'foo.d', which lands next to the object file, wherever that # happens to be. # Much of this is similar to the tru64 case; see comments there. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then tmpdepfile1=$dir$base.d tmpdepfile2=$dir.libs/$base.d "$@" -Wc,+Maked else tmpdepfile1=$dir$base.d tmpdepfile2=$dir$base.d "$@" +Maked fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" do test -f "$tmpdepfile" && break done if test -f "$tmpdepfile"; then sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile" # Add 'dependent.h:' lines. sed -ne '2,${ s/^ *// s/ \\*$// s/$/:/ p }' "$tmpdepfile" >> "$depfile" else make_dummy_depfile fi rm -f "$tmpdepfile" "$tmpdepfile2" ;; tru64) # The Tru64 compiler uses -MD to generate dependencies as a side # effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'. # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put # dependencies in 'foo.d' instead, so we check for that too. # Subdirectories are respected. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then # Libtool generates 2 separate objects for the 2 libraries. These # two compilations output dependencies in $dir.libs/$base.o.d and # in $dir$base.o.d. We have to check for both files, because # one of the two compilations can be disabled. We should prefer # $dir$base.o.d over $dir.libs/$base.o.d because the latter is # automatically cleaned when .libs/ is deleted, while ignoring # the former would cause a distcleancheck panic. tmpdepfile1=$dir$base.o.d # libtool 1.5 tmpdepfile2=$dir.libs/$base.o.d # Likewise. tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504 "$@" -Wc,-MD else tmpdepfile1=$dir$base.d tmpdepfile2=$dir$base.d tmpdepfile3=$dir$base.d "$@" -MD fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" do test -f "$tmpdepfile" && break done # Same post-processing that is required for AIX mode. aix_post_process_depfile ;; msvc7) if test "$libtool" = yes; then showIncludes=-Wc,-showIncludes else showIncludes=-showIncludes fi "$@" $showIncludes > "$tmpdepfile" stat=$? grep -v '^Note: including file: ' "$tmpdepfile" if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" echo "$object : \\" > "$depfile" # The first sed program below extracts the file names and escapes # backslashes for cygpath. The second sed program outputs the file # name when reading, but also accumulates all include files in the # hold buffer in order to output them again at the end. This only # works with sed implementations that can handle large buffers. sed < "$tmpdepfile" -n ' /^Note: including file: *\(.*\)/ { s//\1/ s/\\/\\\\/g p }' | $cygpath_u | sort -u | sed -n ' s/ /\\ /g s/\(.*\)/'"$tab"'\1 \\/p s/.\(.*\) \\/\1:/ H $ { s/.*/'"$tab"'/ G p }' >> "$depfile" echo >> "$depfile" # make sure the fragment doesn't end with a backslash rm -f "$tmpdepfile" ;; msvc7msys) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; #nosideeffect) # This comment above is used by automake to tell side-effect # dependency tracking mechanisms from slower ones. dashmstdout) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout, regardless of -o. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # Remove '-o $object'. IFS=" " for arg do case $arg in -o) shift ;; $object) shift ;; *) set fnord "$@" "$arg" shift # fnord shift # $arg ;; esac done test -z "$dashmflag" && dashmflag=-M # Require at least two characters before searching for ':' # in the target name. This is to cope with DOS-style filenames: # a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise. "$@" $dashmflag | sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile" rm -f "$depfile" cat < "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process this sed invocation # correctly. Breaking it into two sed invocations is a workaround. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; dashXmstdout) # This case only exists to satisfy depend.m4. It is never actually # run, as this mode is specially recognized in the preamble. exit 1 ;; makedepend) "$@" || exit $? # Remove any Libtool call if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # X makedepend shift cleared=no eat=no for arg do case $cleared in no) set ""; shift cleared=yes ;; esac if test $eat = yes; then eat=no continue fi case "$arg" in -D*|-I*) set fnord "$@" "$arg"; shift ;; # Strip any option that makedepend may not understand. Remove # the object too, otherwise makedepend will parse it as a source file. -arch) eat=yes ;; -*|$object) ;; *) set fnord "$@" "$arg"; shift ;; esac done obj_suffix=`echo "$object" | sed 's/^.*\././'` touch "$tmpdepfile" ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" rm -f "$depfile" # makedepend may prepend the VPATH from the source file name to the object. # No need to regex-escape $object, excess matching of '.' is harmless. sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process the last invocation # correctly. Breaking it into two sed invocations is a workaround. sed '1,2d' "$tmpdepfile" \ | tr ' ' "$nl" \ | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" "$tmpdepfile".bak ;; cpp) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # Remove '-o $object'. IFS=" " for arg do case $arg in -o) shift ;; $object) shift ;; *) set fnord "$@" "$arg" shift # fnord shift # $arg ;; esac done "$@" -E \ | sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ | sed '$ s: \\$::' > "$tmpdepfile" rm -f "$depfile" echo "$object : \\" > "$depfile" cat < "$tmpdepfile" >> "$depfile" sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; msvisualcpp) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi IFS=" " for arg do case "$arg" in -o) shift ;; $object) shift ;; "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") set fnord "$@" shift shift ;; *) set fnord "$@" "$arg" shift shift ;; esac done "$@" -E 2>/dev/null | sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile" rm -f "$depfile" echo "$object : \\" > "$depfile" sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile" echo "$tab" >> "$depfile" sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile" rm -f "$tmpdepfile" ;; msvcmsys) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; none) exec "$@" ;; *) echo "Unknown depmode $depmode" 1>&2 exit 1 ;; esac exit 0 # Local Variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC" # time-stamp-end: "; # UTC" # End: eztrace-1.1-2/doc/000077500000000000000000000000001265506773700137365ustar00rootroot00000000000000eztrace-1.1-2/doc/Makefile.am000066400000000000000000000017551265506773700160020ustar00rootroot00000000000000if HAVE_LATEXMK doc_DATA = user_manual.pdf docfiles = user_manual.pdf MANNAME = user_manual MANTEXSRC = $(MANNAME).tex MANAUX = $(MANNAME).aux MANPDF = $(MANNAME).pdf CLEANFILES = $(MANPDF) $(MANNAME).log $(MANNAME).idx $(MANNAME).out \ $(MANNAME).toc $(MANAUX) $(MANNAME).auxlock $(MANNAME).bbl \ $(MANNAME).blg $(MANNAME).fdb_latexmk $(MANNAME).fls header.aux $(MANPDF): $(srcdir)/$(MANTEXSRC) BIBINPUTS=$(top_srcdir)/doc latexmk -pdf -pdflatex="pdflatex -interaction=nonstopmode" -bibtex $< dist_doc_DATA = $(docfiles) endif check_PROGRAMS = EXTRA_DIST = $(top_srcdir)/doc/references.bib user_manual.pdf $(MANTEXSRC) \ $(top_srcdir)/doc/man/eztrace.1 \ $(top_srcdir)/doc/man/eztrace_avail.1 \ $(top_srcdir)/doc/man/eztrace_cc.1 \ $(top_srcdir)/doc/man/eztrace_convert.1 \ $(top_srcdir)/doc/man/eztrace_create_plugin.1 \ $(top_srcdir)/doc/man/eztrace_loaded.1 \ $(top_srcdir)/doc/man/eztrace.old.1 \ $(top_srcdir)/doc/man/eztrace_stats.1 eztrace-1.1-2/doc/Makefile.in000066400000000000000000000441521265506773700160110ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ check_PROGRAMS = subdir = doc ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__dist_doc_DATA_DIST) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__dist_doc_DATA_DIST = user_manual.pdf am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(docdir)" "$(DESTDIR)$(docdir)" DATA = $(dist_doc_DATA) $(doc_DATA) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ @HAVE_LATEXMK_TRUE@doc_DATA = user_manual.pdf @HAVE_LATEXMK_TRUE@docfiles = user_manual.pdf @HAVE_LATEXMK_TRUE@MANNAME = user_manual @HAVE_LATEXMK_TRUE@MANTEXSRC = $(MANNAME).tex @HAVE_LATEXMK_TRUE@MANAUX = $(MANNAME).aux @HAVE_LATEXMK_TRUE@MANPDF = $(MANNAME).pdf @HAVE_LATEXMK_TRUE@CLEANFILES = $(MANPDF) $(MANNAME).log $(MANNAME).idx $(MANNAME).out \ @HAVE_LATEXMK_TRUE@ $(MANNAME).toc $(MANAUX) $(MANNAME).auxlock $(MANNAME).bbl \ @HAVE_LATEXMK_TRUE@ $(MANNAME).blg $(MANNAME).fdb_latexmk $(MANNAME).fls header.aux @HAVE_LATEXMK_TRUE@dist_doc_DATA = $(docfiles) EXTRA_DIST = $(top_srcdir)/doc/references.bib user_manual.pdf $(MANTEXSRC) \ $(top_srcdir)/doc/man/eztrace.1 \ $(top_srcdir)/doc/man/eztrace_avail.1 \ $(top_srcdir)/doc/man/eztrace_cc.1 \ $(top_srcdir)/doc/man/eztrace_convert.1 \ $(top_srcdir)/doc/man/eztrace_create_plugin.1 \ $(top_srcdir)/doc/man/eztrace_loaded.1 \ $(top_srcdir)/doc/man/eztrace.old.1 \ $(top_srcdir)/doc/man/eztrace_stats.1 all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu doc/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu doc/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): clean-checkPROGRAMS: @list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-dist_docDATA: $(dist_doc_DATA) @$(NORMAL_INSTALL) @list='$(dist_doc_DATA)'; test -n "$(docdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(docdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(docdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(docdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(docdir)" || exit $$?; \ done uninstall-dist_docDATA: @$(NORMAL_UNINSTALL) @list='$(dist_doc_DATA)'; test -n "$(docdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(docdir)'; $(am__uninstall_files_from_dir) install-docDATA: $(doc_DATA) @$(NORMAL_INSTALL) @list='$(doc_DATA)'; test -n "$(docdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(docdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(docdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(docdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(docdir)" || exit $$?; \ done uninstall-docDATA: @$(NORMAL_UNINSTALL) @list='$(doc_DATA)'; test -n "$(docdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(docdir)'; $(am__uninstall_files_from_dir) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am $(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS) check: check-am all-am: Makefile $(DATA) installdirs: for dir in "$(DESTDIR)$(docdir)" "$(DESTDIR)$(docdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: -test -z "$(CLEANFILES)" || rm -f $(CLEANFILES) distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-checkPROGRAMS clean-generic clean-libtool \ mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dist_docDATA install-docDATA install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-dist_docDATA uninstall-docDATA .MAKE: check-am install-am install-strip .PHONY: all all-am check check-am clean clean-checkPROGRAMS \ clean-generic clean-libtool cscopelist-am ctags-am distclean \ distclean-generic distclean-libtool distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dist_docDATA install-docDATA \ install-dvi install-dvi-am install-exec install-exec-am \ install-html install-html-am install-info install-info-am \ install-man install-pdf install-pdf-am install-ps \ install-ps-am install-strip installcheck installcheck-am \ installdirs maintainer-clean maintainer-clean-generic \ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \ ps ps-am tags-am uninstall uninstall-am uninstall-dist_docDATA \ uninstall-docDATA .PRECIOUS: Makefile @HAVE_LATEXMK_TRUE@$(MANPDF): $(srcdir)/$(MANTEXSRC) @HAVE_LATEXMK_TRUE@ BIBINPUTS=$(top_srcdir)/doc latexmk -pdf -pdflatex="pdflatex -interaction=nonstopmode" -bibtex $< # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/doc/man/000077500000000000000000000000001265506773700145115ustar00rootroot00000000000000eztrace-1.1-2/doc/man/eztrace.1000066400000000000000000000021061265506773700162270ustar00rootroot00000000000000.\" Manpage for eztrace. .\" Contact eztrace-devel@lists.gforge.inria.fr to correct errors or typos. .TH man 1 "05 September 2013" "1.0" "eztrace man page" .SH NAME eztrace \- performance analysis tool .SH SYNOPSIS eztrace [OPTION] COMMAND_LINE .SH DESCRIPTION Run COMMAND_LINE and generate an execution trace. .SH OPTIONS .TP 5 -t [plugin1 plugin2 ... pluginN] Select a list of plugins .TP -o DIRECTORY Select the output DIRECTORY .TP -l DIRECTORY Add DIRECTORY to the list of directories in which eztrace search for plugins .TP -f Enable EZTRACE_FLUSH .TP -d Debug mode .TP -?, -h Display this help and exit .SH EXAMPLES $ eztrace -t "memory pthread" ./my_program param1 param2 $ mpirun -np 2 eztrace -t "mpi pthread" ./my_program param1 param2 .SH SEE ALSO eztrace_convert(1), eztrace_stats(1), eztrace.old(1), eztrace_cc(1), eztrace_avail(1), eztrace_loaded(1), eztrace_create_plugin(1) .SH REPORTING BUGS Report eztrace bugs to eztrace-devel@lists.gforge.inria.fr .br EZTrace home page: .SH AUTHOR Francois Trahay (francois.trahay@telecom-sduparis.eu) eztrace-1.1-2/doc/man/eztrace.old.1000066400000000000000000000025021265506773700170040ustar00rootroot00000000000000.\" Manpage for eztrace.old. .\" Contact eztrace-devel@lists.gforge.inria.fr to correct errors or typos. .TH man 1 "05 September 2013" "1.0" "eztrace.old man page" .SH NAME eztrace.old \- performance analysis tool .SH SYNOPSIS eztrace [OPTION] COMMAND_LINE .SH DESCRIPTION Run COMMAND_LINE and generate an execution trace. .SH OPTIONS .TP -d Run eztrace.old with gdb .TP -e Show environment .TP -p PadicoTM mode .TP -m MPI mode .TP 5 -t [plugin1 plugin2 ... pluginN] Select a list of plugins .TP -o DIRECTORY Select the output DIRECTORY .TP -l DIRECTORY Add DIRECTORY to the list of directories in which eztrace search for plugins .TP -f Enable EZTRACE_FLUSH .TP -? Display this help and exit .SH EXAMPLES $ eztrace.old -t "memory pthread" ./my_program param1 param2 For MPI programs: .br $ mpirun -np 2 `eztrace.old -m ./my_program` param1 param2 .SH SEE ALSO eztrace(1), eztrace_convert(1), eztrace_stats(1), eztrace_cc(1), eztrace_avail(1), eztrace_loaded(1), eztrace_create_plugin(1) .SH BUGS eztrace.old is a fallback launcher for eztrace. It relies on LD_PRELOAD for interception function calls. Thus, it only works for shared libraries. .SH REPORTING BUGS Report eztrace bugs to eztrace-devel@lists.gforge.inria.fr .br EZTrace home page: .SH AUTHOR Francois Trahay (francois.trahay@telecom-sduparis.eu) eztrace-1.1-2/doc/man/eztrace_avail.1000066400000000000000000000022511265506773700174040ustar00rootroot00000000000000.\" Manpage for eztrace_avail. .\" Contact eztrace-devel@lists.gforge.inria.fr to correct errors or typos. .TH man 1 "05 September 2013" "1.0" "eztrace_avail man page" .SH NAME eztrace_avail \- print the list of available EZTrace modules .SH SYNOPSIS eztrace_avail [OPTIONS] .SH DESCRIPTION Print the list of available EZTrace modules .SH OPTIONS .TP -v Select the verbose mode .TP -h Display this help and exit .SH EXAMPLES $ eztrace_avail .br 3 stdio Module for stdio functions (read, write, select, poll, etc.) .br 2 pthread Module for PThread synchronization functions (mutex, semaphore, spinlock, etc.) .br 6 papi Module for PAPI Performance counters .br 1 omp Module for OpenMP parallel regions .br 4 mpi Module for MPI functions .br 5 memory Module for memory functions (malloc, free, etc.) .SH SEE ALSO eztrace_convert(1), eztrace_stats(1), eztrace.old(1), eztrace_cc(1), eztrace_avail(1), eztrace_loaded(1), eztrace_create_plugin(1) .SH REPORTING BUGS Report eztrace bugs to eztrace-devel@lists.gforge.inria.fr .br EZTrace home page: .SH AUTHOR Francois Trahay (francois.trahay@telecom-sduparis.eu) eztrace-1.1-2/doc/man/eztrace_cc.1000066400000000000000000000013541265506773700167000ustar00rootroot00000000000000.\" Manpage for eztrace_cc. .\" Contact eztrace-devel@lists.gforge.inria.fr to correct errors or typos. .TH man 1 "05 September 2013" "1.0" "eztrace_cc man page" .SH NAME eztrace_cc \- Compile an OpenMP application for eztrace .SH SYNOPSIS eztrace_cc COMPILATION_COMMAND .SH DESCRIPTION Compile an OpenMP application for eztrace. .SH EXAMPLES $ eztrace_cc gcc -o openmp_program openmp_program.c -fopenm .SH SEE ALSO eztrace_convert(1), eztrace_stats(1), eztrace.old(1), eztrace_cc(1), eztrace_avail(1), eztrace_loaded(1), eztrace_create_plugin(1) .SH REPORTING BUGS Report eztrace bugs to eztrace-devel@lists.gforge.inria.fr .br EZTrace home page: .SH AUTHOR Francois Trahay (francois.trahay@telecom-sduparis.eu) eztrace-1.1-2/doc/man/eztrace_convert.1000066400000000000000000000023461265506773700177750ustar00rootroot00000000000000.\" Manpage for eztrace_convert. .\" Contact eztrace-devel@lists.gforge.inria.fr to correct errors or typos. .TH man 1 "05 September 2013" "1.0" "eztrace_convert man page" .SH NAME eztrace_convert \- create PAJE/OTF traces .SH SYNOPSIS eztrace_convert [OPTIONS] INPUT_FILES .SH DESCRIPTION Browse the INPUT_FILES generated by the eztrace command (or eztrace.old) and create PAJE or OTF trace files. .SH OPTIONS .TP -v Enable verbose mode. .TP -t TRACE_FORMAT Select the output trace format. Available trace formats are PAJE, OTF (default: PAJE). .TP -z Enable trace compression. .TP -o OUTPUT_FILENAME Save the output trace as OUTPUT_FILENAME (default: eztrace_output.trace). .TP -h Display this help and exit .SH EXAMPLES $ eztrace -t pthread ./application .br Starting EZTrace... done .br [...] .br Stopping EZTrace... saving trace /tmp/user_eztrace_log_rank_1 .br $ eztrace_convert /tmp/user_eztrace_log_rank_1 .SH SEE ALSO eztrace(1), eztrace_stats(1), eztrace.old(1), eztrace_cc(1), eztrace_avail(1), eztrace_loaded(1), eztrace_create_plugin(1) .SH REPORTING BUGS Report eztrace bugs to eztrace-devel@lists.gforge.inria.fr .br EZTrace home page: .SH AUTHOR Francois Trahay (francois.trahay@telecom-sduparis.eu) eztrace-1.1-2/doc/man/eztrace_create_plugin.1000066400000000000000000000047711265506773700211420ustar00rootroot00000000000000.\" Manpage for eztrace_create_plugin. .\" Contact eztrace-devel@lists.gforge.inria.fr to correct errors or typos. .TH man 1 "05 September 2013" "1.0" "eztrace_create_plugin man page" .SH NAME eztrace_create_plugin \- creates an EZTrace plugin .SH SYNOPSIS eztrace_create [OPTION] FILE .SH DESCRIPTION Generate an EZTrace plugin .SH OPTIONS .TP -I > Add specific include directories for the compilation of the generated code. .TP -o > Select the output directory. .TP -h --help Print a brief help message and exits. .SH EXAMPLES eztrace_create_plugin generates the source code of an EZTrace plugin described by a template file. The template file has to be structure as follows: --- foo.tpl .br BEGIN_MODULE .br NAME example_lib .br DESC "module for the example library" .br LANGUAGE C .br ID 99 .br int foo(int n) .br BEGIN .br EVENT("Do function foo") .br END .br void bar(int n) .br BEGIN .br RECORD_STATE("running function bar") .br END .br END_MODULE .br --- end of foo.tpl Passing foo.tpl to eztrace_create_plugin will result in a directory (default: output) that contains the source code of an EZTrace plugin that intercepts the foo and bar functions. $ eztrace_create_plugin foo.tpl .br New Module .br Module name : 'example_lib' .br Module description : '"module for the example library"' .br Language : 'C' .br Module id : '99' .br Function 'foo' done .br Function 'bar' done .br End of Module example_lib Once the generated source code is compiled, the resulting plugin can be used with eztrace or eztrace.old: $ cd output .br $ make .br $ export EZTRACE_LIBRARY_PATH=$PWD .br $ eztrace_avail .br 3 stdio Module for stdio functions (read, write, select, poll, etc.) .br 2 pthread Module for PThread synchronization functions (mutex, semaphore, spinlock, etc.) .br 6 papi Module for PAPI Performance counters .br 1 omp Module for OpenMP parallel regions .br 4 mpi Module for MPI functions .br 5 memory Module for memory functions (malloc, free, etc.) .br 153 example_lib module for the example library .br $ eztrace -t example_lib my_application .br [...] .SH SEE ALSO eztrace_convert(1), eztrace_stats(1), eztrace.old(1), eztrace_cc(1), eztrace_avail(1), eztrace_loaded(1), eztrace_create_plugin(1) .SH REPORTING BUGS Report eztrace bugs to eztrace-devel@lists.gforge.inria.fr .br EZTrace home page: .SH AUTHOR Francois Trahay (francois.trahay@telecom-sduparis.eu) eztrace-1.1-2/doc/man/eztrace_loaded.1000066400000000000000000000022541265506773700175430ustar00rootroot00000000000000.\" Manpage for eztrace_loaded. .\" Contact eztrace-devel@lists.gforge.inria.fr to correct errors or typos. .TH man 1 "05 September 2013" "1.0" "eztrace_loaded man page" .SH NAME eztrace_loaded \- print the list of selected EZTrace modules .SH SYNOPSIS eztrace_loaded [OPTIONS] .SH DESCRIPTION Print the list of selected EZTrace modules .SH OPTIONS .TP -v Select the verbose mode .TP -h Display this help and exit .SH EXAMPLES $ eztrace_loaded .br 3 stdio Module for stdio functions (read, write, select, poll, etc.) .br 2 pthread Module for PThread synchronization functions (mutex, semaphore, spinlock, etc.) .br 6 papi Module for PAPI Performance counters .br 1 omp Module for OpenMP parallel regions .br 4 mpi Module for MPI functions .br 5 memory Module for memory functions (malloc, free, etc.) .SH SEE ALSO eztrace_convert(1), eztrace_stats(1), eztrace.old(1), eztrace_cc(1), eztrace_avail(1), eztrace_loaded(1), eztrace_create_plugin(1) .SH REPORTING BUGS Report eztrace bugs to eztrace-devel@lists.gforge.inria.fr .br EZTrace home page: .SH AUTHOR Francois Trahay (francois.trahay@telecom-sduparis.eu) eztrace-1.1-2/doc/man/eztrace_stats.1000066400000000000000000000023661265506773700174550ustar00rootroot00000000000000.\" Manpage for eztrace_stats. .\" Contact eztrace-devel@lists.gforge.inria.fr to correct errors or typos. .TH man 1 "05 September 2013" "1.0" "eztrace_stats man page" .SH NAME eztrace_stats \- compute statistics from execution traces .SH SYNOPSIS eztrace_stats [OPTIONS] INPUT_FILES .SH DESCRIPTION Browse the INPUT_FILES generated by the eztrace command (or eztrace.old) and extract statistics. .SH OPTIONS .TP -o DIRECTORY Select the output directory .TP -v Enable verbose mode. .TP -h Display this help and exit .SH EXAMPLES $ eztrace_stats /tmp/user_eztrace_log_rank_1 .br [...] .br PThread: .br ------- .br CT_Process #0: .br semaphore 0x601300 was acquired 2 times. .br semaphore 0x601320 was acquired 10 times. .br mutex 0x6012c0 was acquired 20 times. total duration of critical_sections: 1000.065697 ms. .br semaphore 0x601340 was acquired 10 times. .br Total: 4 locks acquired 42 times .SH SEE ALSO eztrace(1), eztrace_convert(1), eztrace.old(1), eztrace_cc(1), eztrace_avail(1), eztrace_loaded(1), eztrace_create_plugin(1) .SH REPORTING BUGS Report eztrace bugs to eztrace-devel@lists.gforge.inria.fr .br EZTrace home page: .SH AUTHOR Francois Trahay (francois.trahay@telecom-sduparis.eu) eztrace-1.1-2/doc/references.bib000066400000000000000000000056611265506773700165450ustar00rootroot00000000000000 @article{Coulomb10periscope, title={An open-source tool-chain for performance analysis}, author={Kevin Coulomb and Augustin Degomme and Mathieu Faverge and Fran{\c c}ois Trahay}, journal={Tools for High Performance Computing 2011}, year={2012}, pages={37-48}, publisher = {Springer-Verlag}, address = {Berlin, Heidelberg} } @article{Buck00DynInst, author = {Buck, Bryan and Hollingsworth, Jeffrey K.}, title = {An {API} for Runtime Code Patching}, journal = {Int. J. High Perform. Comput. Appl.}, issue_date = {November 2000}, volume = {14}, number = {4}, month = nov, year = {2000}, pages = {317--329}, publisher = {Sage Publications, Inc.}, address = {Thousand Oaks, CA, USA}, } @article{Agullo09Plasma, title={{Numerical linear algebra on emerging architectures: The PLASMA and MAGMA projects}}, author={Agullo, E. and Demmel, J. and Dongarra, J. and Hadri, B. and Kurzak, J. and Langou, J. and Ltaief, H. and Luszczek, P. and Tomov, S.}, journal={Journal of Physics: Conference Series}, volume={180}, year={2009}, organization={IOP Publishing} } @inproceedings{Danjean05FxT, author = {Danjean, Vincent and Namyst, Raymond and Wacrenier, Pierre-Andr{\'e}}, title = {An efficient multi-level trace toolkit for multi-threaded applications}, booktitle = {Proceedings of the 11th international Euro-Par conference on Parallel Processing}, series = {Euro-Par'05}, year = {2005}, pages = {166--175}, publisher = {Springer-Verlag}, address = {Berlin, Heidelberg} } @inproceedings{TraRue11Ccgrid, title = { {EZT}race: a generic framework for performance analysis}, author = {{T}rahay, {F}ran{\c{c}}ois and {R}ue, {F}ran{\c{c}}ois and {F}averge, {M}athieu and {I}shikawa, {Y}utaka and {N}amyst, {R}aymond and {D}ongarra, {J}ack}, booktitle = {Proceedings of the {IEEE}/{ACM} {I}nternational {S}ymposium on {C}luster, {C}loud and {G}rid {C}omputing ({CCG}rid) }, address = {{N}ewport {B}each, {CA}, USA }, month = may, year = {2011} } @inproceedings{Aulagnon12EZTrace, title = {{Runtime function instrumentation with EZTrace}}, author = {Aulagnon, Charles and Martin-Guillerez, Damien and Rue, Fran{\c c}ois and Trahay, Fran{\c c}ois}, booktitle = {Proceedings of the {PROPER -- 5th Workshop on Productivity and Performance}}, address = {Rhodes, Greece}, year = {2012}, month = Aug, } @misc{vite, title = {{ViTE -- Visual Trace Explorer}}, author = {Kevin Coulomb and Mathieu Faverge and Johnny Jazeix and Olivier Lagrasse and Jule Marcoueille and Pascal Noisette and Arthur Redondy and Cle\'ment Vuchener }, note = {Available via the {WWW.} Cited 14 October 2012. \url{http://vite.gforge.inria.fr/index.php}} } @misc{gtg, title = {{GTG -- Generic Trace Generator}}, author = {Fran\c{c}ois Rue and Fran\c{c}ois Trahay and Johnny Jazeiz and Kevin Coulomb and Mathieu Faverge and Olivier Lagrasse}, note = {Available via the {WWW.} Cited 14 October 2012. \url{http://gtg.gforge.inria.fr/}} } eztrace-1.1-2/doc/user_manual.pdf000066400000000000000000006353171265506773700167630ustar00rootroot00000000000000%PDF-1.5 %ĐÔĹŘ 124 0 obj << /Length 254 /Filter /FlateDecode >> stream xÚ…=kĂ0†÷üŠe¨/ŇéËSCÝÔĄĄq•`šŘAv(ý÷•*o:ÝčyŢq8‡Ă†˙3ýfŰ ¤Đ6V€?ĄŐˇ˛45¨LţŢŘţŐWŤe±ëCőîŹŰ–8‹$´ĘL­ J"¨eŽtavU- g‡0†8ôéĐŽµ•ăÉr _•älŠźĺÍiŠY µEí$Ô$Љ5úiś—xż†1Ë0ž‹iw»]†ľ[†iś×JBˇT†r%c°q&5Óč¤*Ş—9ÄhŮs—t‚Ý»ËĘJ)Së_V × µ-·=&€lâw2a‚ĘB\,ůó·{żůS]* endstream endobj 163 0 obj << /Length 985 /Filter /FlateDecode >> stream xÚÝXËrÓ0Ý÷+Ľ”6şzř±b mĘ«CŔ‚ÇÂ8jëÁ±‹-ú÷\YŽť”´5C™®ä‘EçÜ{ŽîuÎęĐn|:;x4…ŘaÂŁśŮ™ú‹śç—Îlî|"“˛pYL´˛Cí~™˝x4ĺÜęÇ4nH/>ˇý ¸^Ě(y•ĄŞ¨•ëńHyfÇŁŹ37–¤JR|Á€Ĺ”pł¤Y˙–Ç]Ů5^/]DUËĚĹáÇmkQ&kuűáv­çE­“€GäťĘUşR%©IĹĆdg‘ß«ít ¤ËXbŐ´VmL‘ďýëŕ«BUÉ€çč§Jkŕf˙˝ŇWt˙{ßĐ6uDw"á’÷őÂ8Ă}ă™fL 9++űprúÜ~őäň2ĎҤ‹šdüßÄb;9€ÉERś÷ôE·ń׍ľl´}>Äs1ĹÜR]ˇöXřŹĚkD$ĽíBY]§Ć ĘZ{'eĄŐ˘cĽHň«:C¶C˙źF=ů Ŕ{‡8QŐů=I »öľ»ÔĹzźfąVŐkiâŰŮbaáOŐűG˝ň”Ią@­]{oŹ|§Ń4jťĄćüö_žjń(µ®Š,,*o®>S. 5·©zš7ĆF«Śď]Qß,ŮŢyyŻŘC‹Ľđ¤©uą¸F“l4Ś÷[ţňO÷­Ŕ°ÝIšŇ0&@Gĺ©čňô¨­;—YUCMeŔ|0ľšTYň5o­uÇ]ÁźqwÄSvč_Ą˙ٰÁ|•-2Ý—/4ŘÇĽĹĎţĽ’¶Ú¸ 0MŹiÍx¨t’ĺčÝF¸4>¶÷‘}ďł­Žś”•2hŘą‘hcŔď®qäZ4ý9ĂöóZnă"" nŐŁ\ďžfÇŰËpŘ÷”#¬Yö˙6­ś`Ś=oZS"|X”ŚrŞŔ:Ő´ő)ő˝Ác ™Ńů•5Ş'ő·övnoqŢ4Şî†´Âč Ô ·-Űd”ÍWS·"ő& ŘŤuuÄ;/Ůî!¨ÓÍ›łţ5ÔçB:ž|ař˛WćëßÍ~˝/Ú endstream endobj 169 0 obj << /Length 119 /Filter /FlateDecode >> stream xÚ3PHW0Ppç2€ŇN!\únĆĆ †z––† !i ††ćzF ć&z†Ćf !) ŃN™I9™ůéE‰šĆF•šşF¦ĆF–†ćš±!^păôÝ ÍPĚ27Ó3 éšé™C 3BŃ㵥 Ő endstream endobj 173 0 obj << /Length 1474 /Filter /FlateDecode >> stream xÚ}WKsŰ6ľçWhr 5cѤ(ľzKŹ›3~^ą€*TfČ$Ä•µdvtô/’Óx´«Ş(.ŇGŰqóȸŹ_LAmęĆööůAUÔ,ˇ˝ĺŠű#{vôH?QäÍW$ńE™Gź˝«ą3"ńÔ/°pđ¨#¬Ůٰb9fŽ´gK\j€ŰĽ„>dĆĐ9¨"SɡÓĺZŮ€aă˙ßÉ8}ÂnPŇÓ\Ěr\ˇ?¶f¤rCoöäK>Ň˝zčȇbqŞn&:ĚĐ…ĚŇy€€¤ôŁĆů7ŠľUŹC «´jT˘dy}ŕq–7Đg'GÍdU@Ůb÷ŰáxĺDî {ŤŁ-´Ôm$§`pőD˙Ą×ĂĺĂ­FéßĹ(‚žzţ¨“h‹ólďe––Ç`‰ó€Żý¸ź¶ýđžúR#ęŕť›9e¨D4ń¤ą3©.i9`µqăÇ÷YN+Š“J^d‡J&¦óʍÉFëËŁFˇ`ÎO†ďg•Ăž˙łó.?ü2†ź0ôŢĺÝU#łć+Ň9<ÂCĘ(Ţ…˛=ńËü˸JË".ŕĎm“ćIśdŁËž ˝żő?PŐŇ endstream endobj 5 0 obj << /Type /ObjStm /N 100 /First 812 /Length 1877 /Filter /FlateDecode >> stream xÚĹY]oŰĆ}ׯǶ@©ýšý‚ާAkÔ7v‹{křA‘›¨Lş•8˙ţžˇ(Q©mJh$p˛KrgöĚ™ł»CĘ‘˘HVQ"¶¤ EüŹ?H{ôĐŕŹE:z2=&6Ś zśČD2 YíȲŤ%ëáÚ“SŠŕČ‹.9ŹšXÂ(¶iä80ąH\"ϸcČ'# б§ŕq(D<fă1š"f÷Žbň#Ď”€S&†§D)b´A(:ÁZ'NĐ"Ä€ ´fŠJcިŃ"ĽčŔŽŁČh1>F´!bpÄ@¤-LÂP&áó$řsJśĂˇs2<:ŚŔ´č$3Ň Mł\)8e+á•V#lÍ2—PďW ůž•$BŕK‚jńˇ#c ¬Ă3Ň #Ë#XĹ$Ź`@ŻiF%´qHŕ#g^đ#‡>Éd1Ząü&źÚ´[­ü±!ťŽEn-@”dĚiäĐz–¸‘ď “bśMNâvH´ ™uF ‚Jg˝<‚XŮ‘F¶ťw-7ä‚đĎĐEŕ,ę@V%1l„Q¨€­0† Ůą…x!ĘŕŕDŁ@aiÉľjý@rĄáË›$l@ˇh¨Ä;¤äYÁ©Ft‚Ücűć {ń‚Ćç4~S]T4~EßLo'÷M^gú[úá‡Ń7š~)¦y9Ď©ú@Ż˙¸¨'ÓüŰgŤĚŇČĐŻóúc‘ÚÉĘ.­,˝-çÍd6›4EU>>ϧň ł+lčĐ»üŻEQçwyŮ̇LĚĘÄĐ›ĽiŠňćy\˝Ő Yféĺ˘]š­ÂqK#G?Uꍩč7×ýřüdn•kŁšVőr¶ŹĎD¶xżaąa ëó|&Ź`}˛(Ű1sÁ!ěÖ aj«;Ó»ľĘĽž,){ȧ Em8ŰqŮŢ‘üŃ‡Ş¦Ół·tt?+¦mηűs˝?GÇ·“ňF\6·9ýşhî ˝‚¦MUbzžˇłjŢ|ZŐM~GGĺdöy^lCaz¶ŃĄÓĽľůÜ ŔqRĚ ťť3nzfŃĄăęÁ‹őy&çM1ť°6–¤äő÷×ů‡˘ĚŻél¶@,Ű&·=˛_‰±Ě}Ľ7ŐÝÎNLďä ‘mułö±VŁ×ĺǢ®JQ7ý>©‹ÉűY>hË+[¦źËęS‰}î®hž“ájmwVĽVqQ"ţfRĚ&ă_č¬ Ź«:¤űeÝvéäáb«é ŔéĹ›!Pë±f ę´ş^<ÉŰ*~ż´ńtRcăŮłĎt4˙ŇůĎ"ź?·†»)ý*t°HŞ…äč¶Ş$ëĎZ}·Âů˛x?+Ş›zrűxq_JÝ čŤOŠćJĆżx1_|ľĎi|6ąÉGăăŞldaI $#GăwůĽZÔX©meŃŢ:ÍŻ‹ÉËę.np7Aę'ťĹt5‚§ZôĄ­n‡włlÎţß˙ý!eNQ” ŠÉđr1›]=?8,kÎTâ/@ĎŞúü^Rc—6g“y(©sńúˇy#K>§ŤĆ'“„ť“¶š +Rhašî5Ş‚îB !Ő^`ÚńY]MĎó†.1׫_ä ­á?ͨ·Źőúź0:>*Ë /ŰŇN Ie·l]×r×ú® ]»v—”tËVwmçĎuţ\çĎuţ\çĎuţ\çĎuţ¸óÇť?îüqçŹ;ÜůăÎwţ¸óÇKc´Ť{4>_ĽoÚë_ŠňĎŃř%Š€Ľn™ÓWăźĆoÇÇ—2˝ş®§H’ó)3R6rĘ4ęxBć^{|Ä}ař†+Ľý°. x}XĂp6‹Ţ Â0€ˇUfSęač”9ďaŘ=Â*SX.a#ŕ…b><‰âďµí~qD°xu[Á If]ÜÄň]±"ä’¶±űsśÉ›îن0Ă:uŕĂbTýrqNA0vw…hŮ.BÄ(Ć= ä©7Źý˘QŘETěŃh Ůđ.h Z›$o Q*3Ęď‚ć{Š Żú­ÍFźy» 9€€­wن~mŔţĄÂý"G¬2Öýgq2Çí¬Cč×Zź%ßosÖůL©´ šCpclćôkpîćňU íÁ`ăIZoQĚ€śÍň]w ‡ł}¦RyňĺwOç‘ËĽ#M|l9QďĆ쌜‘ş_Ô‡´ńŰ%·Ě™÷8p;h·ď‡ÍTű›Î•ţl48¤­ µďź Ľ'ÓďpĆxHf¸†ăCHgł|D^ăŔŮlôÖ˝Ť÷\),Áč¤2oz0:ĄĚ‡]°ěŮh`PˇßŮ4fmô–™ýËo¦ ˇ×+^Ĺłŕě ^ýţé°x!5}Ő„÷ič†éđ_JD>•řáS‰ühäą»h˛ň_÷u$=ţ:ľňëWűýа”NP8Ýú31h$ĂĺÜw_*¸MYÜíSŘW¦lßY Źżaý•_Ă._˙Ť§¶ä endstream endobj 183 0 obj << /Length 851 /Filter /FlateDecode >> stream xÚ}UMoÜ8 ˝çWř(±kYňöÖ Ýt˘sôĐ6e¬™j[†lOšţú’˘&ă=Q¤(ęéńŃ΢C”E˙ŢdÁ~ÜŢ|ř$Ş(ĎҲ̋h»Ź8ŻŇ:ŻŁ2oRÉ«hŰF?ŘÝQŤłvq" Éňřqű߇OĽ‰r™VuĹńX%˛Ik.éŔ×Sś7L»“ŃĎpJ6ĚîÉŢßĆuĹśÚéP§Śx–6Ys®ST4 ŐńŮ‚˛QĺěG~‹ Îę`ĺ#m‰|Ef¶q’×ĚvÁ=Ş™ň”éĎ™3Ů´Słâś°·Ě¶‡ŘNuÝ …ôo˝[fc„Ť8ąH‹‚`ÎĘĘR°˝ł=®rö`Çdç±·®Wľwîl?.—1ô3+˛‡ÍNuFgNőS'µ(Řç™Â-ܶ‚!]Ś‰Ě ‚EËź™ť‡ÉŔ†w*¤>yş4í0 ťžu{΀„ZźĚ´¨ÎüQ«»đ źČź–9’§®Âýf¶÷@®€¶Ź©ĎŕeÚ€ ߤ˝„ŐD‹€Zä¶z2‡Áˇ"úÉ´á¸"3™~ěB豪ó W‡çË­Łr ÝyśÉ5 j; ’‚m«ŠŠmŹ(L)*Đ…ęc‘żĘş_-™ÓťŃ!ĂS ±±[fA3„M×ââľÇÖBS+˙(yyÝŤ>ăë^ŽO,hDdt Ş{ůŁÉ9«îź8)82:ú¶ęˇ5ĂRáNŠäÚZŤSćő'xsi#:á”g0ďśüS ří°PO¦3sč’ß±ď2–ÉW[Ż4{gĄÁŐŐWŕB!HČű˛ůL‹Î<9ĺ@ŹČiÖ°Żçć#Ü/äĺ–2±™h7óŃiŐ˘Ú%ŚńEä^išžçB)Dť¬ ‚Ă‚ŔÁ/ŃŞ›,}"ž 9Ô2\s?! ‚KR _1#ŢÉw÷˰;ó$H hA[3~Â1ĺ•˙uzýoFĽ*Óţ\IŢ4iV°ňMŇýöć/ AúĂ endstream endobj 195 0 obj << /Length 1051 /Filter /FlateDecode >> stream xÚťVK“ś6ľďŻŕŹĐ8'ÇĺÝÚ”í¤*©dăf3dY4A0Îä×§EkŚń!9LŤZ´úńő×-Ń`ĐŕáŽú˙ďĘ»ř^d§DJže0–‘śçäIX”UđľÝ©ý űh%Ň$ѧňűřžOH–gĚŁÁ*)HÎ<đŘŮAµ­Óˇ:çKH$÷ęi‡Ş ¢c”†?éżĆ¦×/ş‹ ë}É€QRĐâä <‹ôä Â<4}5EčŽÜęÇ7Ţý^F9ČjŁ_y•ťFťÚ´­‰x~nş-nYSÓNÄłPőOtZWĐ> ×Ń Ôü÷|±pJ[WŻ]Üg&Č!jNRćĂfd®ň´J!}5:Ű`tcşíšť\Hş·Ńi)ľťˇŢ‡D|ŃÇÓ{WŐBĽR†źŔTőMçěQřđŁËĺŃ "l^öNjˇ(Ŕŕ@¦Â’h•0~PĎÂŕŽÚŃ)÷^:ş/fěOfqŃÜĐĂ”"XÁšýľźęrh*íqŻŽťzi6(´ÍşW}Łí”$ĄD9ů×(ˇ/ôh}ˇ6ŁĚË z¦ţďą©ö ’Hły)–Ëýľ)ߣ»ˇ®śő?hJáÇţOmď˙.aŽö8a%g; hxŐI9%ú˘ÉÝ0ě_Çqe>w­Q›XuP]§vdŰŤÄô۸׭VV۸~@!^ęOžD0~2» ä *I6Ż–XLéˇ|đµr)!Z_Ë'ă$+ň›|¶5® ô'đ˛Q¤îc Öźz3Řx;l—S ś »NÁÓŚça0űfĹ(wfbWšúyámŻUuDˇé6íXéę$á˙4–Äy,I(〟|ă °QÝɦ5¸şjŽŮ%$,öť·Ő5ĺÉWfłIć§Şp?›ô0`ŔŘp±lŠ}Vµ[$OŁď2°—[á7‡Ä”0đ†ĹV¸Ŕv„ mý& ‘uë÷=1Q¨ű©ÁŻĎ]]nbóęµmK.Bš32!…űŞsXăX˙38ëdâpÍQÎóm‰b,‘$•g˛Ţv“”$’Í;dąéߎ}ݧń=ř9©±Č­Ů»‹Ô l?e¦śĎw\Z~ꩉL‘ŁXÓzP]Ë5 ő~ţĺăFKcŰŔvʲpłÓ›gŔÁ8N» řňŤµ;hI»yY‚ N(.!&hB.=éű˘#ŢpŻ”zśŢÔřZ¶gŇ^ő3‹`sB+» u†ń‹׍O-ÄÄÍ…WříҰ ¸·Âü©ŕž" ş aRÎ$ńÚÁ ű%VKgTçý™®=žsőaŻÇ¦=…łÓ—'’ ¸˝aË$‘ŕpôs꬧3ťwĺÝżôI—! endstream endobj 208 0 obj << /Length 759 /Filter /FlateDecode >> stream xÚ­UŰRŰ0}ç+üŔPqŐq‹;ĺ`­˙E¦m€ü^CUľügĺ´Ëę­N€˛í=L,SčµYŔžô0úľ‡}ŕHj śeacŔgbŐ?ův>ĽNnĆ_'źżDËˉD|=ř †ď»r¶#y:ĐxY‰<+%Či*Â`=´ßEŕF1Ńp§ŽăLŰ/ă˛Ô[%o¨ŕ2v§ú4r×Ě0´Cźh†nUŇm2fyˇY-—¶Ł˘LĹlm8'ŕqÁ[’…©{ąČë4yŇ@–ě•§ŕjQpc’Š»"./_.>ÂQS śGQ-śŮŞęŹľG“ëń8ęâc‰+łjîŢ"â¦sËhĄ•­âĘ*NSžĽëBé ;ÄíŔśWóţńYtöş0ĄĂ×…ů°ýăOWŻ S:|¦¸ë-x^ĚD”´Ń$8¸č~ZŚÁş;oKI/5Š{Pí˘.«¶“4PŤüňf5Ť«V"ÓßęP„É®ąˇ`ĂVOdÓ´–O0á˝DĘ{ZĺĹş“BŹ@‚ĽÖAwĄHˇ/—ĘiB&Ľr5ŁóI4žH<đĽłá0€Ř'űĹ“íQú4ďU&´ÉĆěÇşQ8yrěéI¶–fÄ"+_$ŇÇPúßâR ˘O UUˇ‰/»B(ăŞîŕ®é©Y;1öFŢČo«ű%f<ý6ę´ÎşĐ2ÁŰŘC|Ď»fł/ÇF d.ˢ”®ě6#ůPb$itI]f˛żsgýĽüh endstream endobj 213 0 obj << /Length 1074 /Filter /FlateDecode >> stream xÚ˝VmŹś6ţ~żĺ“‘nlcWŞŞ4şkSéÔSşýĐ7E„őî˘FŔŢĺňë;Íľp$Q«¶_㱟yfć™a“h%ŃwWIx~»ľzy+tÄŞ—Ńz1¦iĆłHqCS¦Łő&úŤĽŢçí`»x%dJŇřŹő/o™‰xJu¦^K˘UjhĆRá{sCáBjČŕüóçŢúĹÍŻë8Ó¤Ë űŤă\ô/Źč1op+Ç@FܲGşLP™OwŠ® X ŮČ8q裟˛żĆez ¤Č ·Ăt҆*dçéaĘPˇřýAůßľz}ónü]J§VT3÷ĚĘÎ5#Kx{Ą$yWćď+ü»1>¨ą˘y%r[ ¨`Uöšq[żÓV‡]9&_ł ćcµ`÷}ĽÖ˝Ý`˘Rމ>QóŰySŘk˙ŠiYČ—T2îÉÉâ‡ÖuŕU2uĚČy‚ľ~ŃűÎćo®ÁÜ–/–Ҷ:GžÂ.CڧƉ3‰dc.E„†ŇcОbż_2¸›7ż{w˙Ćď•LÇJ0E Ě— FżŚ)C&* ‚ĹnÔ4Áě„:Áj¬r,>T]‘Ľ¬ ęHŐzÓ©„pţЇ‘|J‘‚y–gxrÂłµëžŕZgY~Ó‰OčŻţ®uŮvö3> stream xÚ­XmoŰ6ţŢ_áŹ2P1˘HŠÔPčKRt@Ѣđ0¬Ű(6m«“%A/IÓ_ż;%[‰ÜfŔľXÇwŢÝsĎ-v‹hńîY俯WĎ.®DşŕśĄJĹ‹ŐDÍLl:’Ś‹d±Ú,ţ @dń2ä+ ßá@‹tĽv˘1đ[f»!1kç®ÄµbI’ ‡á•.^ô­mpĺK°Çµ÷ÚuQí®DĚ3\2Š6YůĎő ü}9§Rł‡€ śůËLÂ0¤iaś˛8JŹQ(|ţÖđËsÔ±u¨áç÷$Ľ:˘ý‡aÓA¸Ł;`=ŰY»iIě*üB–m×ô[bXu4fÁHŮ;öÔá.€łS`z-´?FESD]ď˘"XEüÁ¸ÄE0nâ"ŘMP°ăÍ˝­Š˘Â­îr€RŚHŘwŔrDęÜ„á‚eMr W_“x>hç¦ôÝç/B˛Č¤ÓŁďö¶™ Á™źř-Ę.2wRÂt<"ĘĹ>8ŹŐÄA9šů€ŇŤómhĐń+| )°ŚĄťŁ,şJĄ*ř}oK>a X5%Q¶ĺ¦e¤©2,cPôÁaČ™§ źÝ59±‹ v'”]ÁOôçOÂ÷'Aó”5š~>Dc©Häă •>HßěłrçăTbpĐČ—‚ňcßŐ}Gň[Ďl8ĺţ ‰ó50že°±Ű¬/pU‡YδcâřCO›áđ-úÁú®Ľkií@ĺŘWú®˝ď(üFY1ë)YbÔ)wžjdĚc:踬¸¬ÚÓ™H6:bZOi– öčč(ít#÷$·¶óĄŠ8›‹8\K9\ Řďó«7—×ôűöţóś2iĘ䨱uav›7UyäD<óv©T5yvSXŁ8^pÉ„L<ŚľFŚ€Dbąz+Š‚OKŘĄj»đCŐts2ă«2+îŰĽťĂ%BE2-Ź;1îůÁ6»˙±p“@P°Çí䀥–ä¬ńsŔßUłq›”f`#ľá—ôó]éá«ňۦŹ>ĚUjąó&Ş‘Hâ"á Y7Ŕ&󞢒ŃáĐĂŞ±Ů†Ćođ÷$ź“čă«üűŔ„»jŰą¤„A˙˙Z^Ć·NSL6a5Ö…uöŐ2śBD‚˝¨ÎóŽS•ŘâAÎ90˘ć÷p\‰Ôé¦ňů Mł$óś/>“”\fĐe]ÖúHN%\ÂL/C$Łô±–ÔŢ_®Ô4§UĂ[ş?a/ř"ě«_F®ĹĽĹÓŕý–:ß­Ţů}ZęŔâĘF»ˇ¦ŻýaÂÇŐuµ}]; ›):°ô$ÂÁ§}1ýa”o¨s€ ĘDÓV{}ť@† ú°q1mŐZuΚÔM\ă§P0‚ŕô@ÁĂ~&JŽA‰×=şśÎÓ¤†Ś.Gň;ž4 ˇ™µŞ10fC LUtň”89ĐĂß(çPë ‹ĐŤÎĆŔó0÷ńćd~‘@uđ¨:ŹÇ7ňU^t¶92ííßhăĄî);fBi†bzó˘śxo›“×16ŕŰ;üŔ4÷p#Ăü#’M[ç||*ú3ę}Öú™C*Ą ťBĂN?ÔMéśĆZ»„÷Ă …Ó4…†Jó“Ç·–ÍÜ˙*Č·dő“ZUó.đúw˝<5ůŰLT   Ź2 ®Ýęłd@ş*ľa¤p¦)ićh;:”!sŐG3X8[}ś1š‰ÇşĽ=·'TˇÇ‚ž6ó5.Ô/ă$Ż`‚^q檡K'Dř0TgÎ1Ŕf|VŹÄ't ĽSô§ T6'{ŇýS‡*ŮŚé†}Ú†Îg¶4V•ř‡Žˇűśoý¦,3qź«ÍĆ?Ć\'đ~đ>çPă»f2çrőě_ČÍ^ endstream endobj 222 0 obj << /Length 1274 /Filter /FlateDecode >> stream xÚ•WmoŰ6ţŢ_áŹ21¤¨×`ŕdÎćaA ×°5…ˇJ´­U–TŠĘKýîH*¶%ë>$O÷ňÜ“Ý„N~yGízą~w~Í“ c$ o˛ŢÂ6"±O"ęĆĂÉ:ź|t|â>uóçŞ>4ť*ŞÝÔĺQŕ|P©*ZUdíôÓú·ókN% MjŁף$H¸Ńł¨Z%Ň|ęú~čÔSćlÍ6“"5*}?pRC<ąą!)™fÂo)÷Kq‡Čw§^ěÔťaĘŇʰ(Q–†4ĐÎßëiĚť^(«­Őúdé”@ř—qř‰ÁŰťs9÷śşÂ•9j/ AЬ–9˘Ôd´Ń^@đř4^@ć µ‹oZ`VŔ@ŔBç\šóşVČ*=ź6= ŕ,ëÝF¦Ő— ŐH!e27P8”™Ł‚'iv”ŽA: ·Ň !źĆ˘°\ď!?ůĹŘ·[ęŻýNůâ›ř’}±§Ů×®AËěE„&±áľY.Ţ4ęŽ}ô"că Ú6ÝADk­¨ÔX٬ćW^@Śö,-ËvÄdżś­V‹ůŞ—`ŻHôXČ ‡¸C ̱öi•—ĆőókĎ›0źp?Ôečú1a1ä—C¦’¨/C]„”:@ŽÝ\`-Túö…‘ł,»]QŮ25ĆŐ'‘?é!Ě–óĎFÉS=_u-TXPš´ÄŰw˘űÍ˙PTXg<Ž_ďuĹJL?ŹçľP{óˇ1&°°)?62éÂFÝ'„!bű¨Đ‚U ±4P˘d‡_°ĽE5ő"ô?aÝŽägŰU™*ę 1ůpĄĘěŽ(ŕpŹŠ ÁöĂťYe>‰‡ôĐ”Âę­YSłd]«t$ao|4ű˘íŮ@áÝ4€ľW”éç^KĎf!?ď'Ď<čŚäÇç„F1hĆj-Sµ|Ĭ × óŮPá{ťEźĆb Í©÷Ŕ§‰öi&+9f΋OZ2°´űş+sĂf»2PçŽ „ű˝Öśnΰę[™[CĘ"e!Ix4DzŤŞj„a´ ĽAŤś î†Ř ˝aŻĹ’ŃDŚő!t«ŮŐ|óűâr5[ý…˝w9[˙:[=,ˇJ­¤É˘,L5žúhYҦ‘u,vŕ¸D?4§ÝŇ€ş…haeß?TšZ*Ó_ćS¬ż3čÉŹ&‰ě˘)·ŢXUôŁ#˝‹9ś9ا|Ă…)dFeĘ đ×cś:7uŢa°?n1;ş«p»í°|űŞC z‹cćĚď%ŞS0čŃrä“Đž gQBś,{ÜuYÚ“PÁ¨™Ź {ví‡9R?JMÂŕQ<ě' őâ±Ęö˛®Šođ8@łUďR•ąŻ˘}ćéýWâᬟM‡´Ů×Rôg|ÎÉďv)ě]J1$"ô#đ/\‚i1[.¬sBőęŠ×s¬î*%äŘđcÖĽˇ=±Đ‹WäĽotç˝YÚä¤FŁ(ÍIâËd§Ă1rë|káĐoY¸Áˇ´8^˝¦/čő śŘřĚy¨ď@˙l8h¦SĹlj­SľÔ™MËVŠ7®č'-I콳5©OđníІt U;a_QĹç^ęe¦’x Řű?Šu·Ň‰ëeńž€9™BhŔÖÓ ‘'$ ÁÇ(&!ł-"Ě×ďţ0ÝGW endstream endobj 226 0 obj << /Length 2313 /Filter /FlateDecode >> stream xÚÝZmsŰ6ţî_ˇÉ—P7J_rźśŘÉĄ;=×íL›Ëh$‘¶™P¤J‘qÔ_űR¤L»‘ăúf.™ `±X,v‹‡vGW#wôćŔµőË‹^ëh$ĄŚQŁ‹Kh"Tá(p=!µ?şGOhˇĆ)•qŢ$yRÎŞ4żOt`śWőş*–Üţ)«ŻŇ|=ţxń㯥?’®ÜH"_w4Q®0‘fŽżŤCíőxâí,f96”sĹĽţUä ŹŻ-wÎň;aťŞ¬—I>VˇSq_um§^Öů˘J …ú7HĂ«)çf¬`CÓÄxşĆy;–NŽRŁR ăE,fQĆI {ÓĘ© ¬eGF최- zČ„\Ĺy’Ä}>‹2iąĚ¸ë?®ö2۵(XÂYšŞ_ pí±Ť@D‚BĄIĄč“|×u.®-»|¶Lx‘âŇĘqm;˛t^ÎĘMo?üă ¦T0Ҳđ0ąś-’FhăňHťWJ WF É«śťžu1dĆ:Đ -°”˙ěog˘‚HčHAC ŐlZ núĂűžý,űȱ ó2MěŢăd˝(S˘âVŠl”˘ĄěHáö—×Ë!O°ł·ÇX[ťÁď4¶¶š^n¸‡W’%ŔH\g X¤q•ăň@şfĘ2Y'ĺśMf„^”LrňűĹ8 >śĂ–” î©× IŠv‚öLüâىKg˝µÜ­sb¸đ0[ÄĆj•$O*śBž•$9ŹH×w·ć­wʵ‘¨«Vď~S^•EUĐz›/~‡aw‚Ŕ¦ÝŹ+¬·IÇá y´îą.PťU‡CAaëŐ áë˘Îl ČřĐ‹ĎV«–áe‘Ái“Ĺ“ŁHDľň):C u=źô%Ąĺ]ş¶áb*Dív˘ęLô%Ěk,ů:[®ŔÖŞUfUŤ˙Ë«7η7ÄÉĹÁ’ze{7 ?ŠF‹ĺÁ‡Źî(†Aśŕžáč†H—#mBáílôóÁżďYáîşť<32" Ţľ AÔah/'ŮlA–5Ě÷FĚw)ĚD“¦QÂËń$ ť*ßPů–Ę3*§TžRůžĘc*ˇňťťŰµÓ‡lqg+ßł!nźÝiŮl6Ś|PžRyK؆ŕjˇrѡ˘ŔůJĺŚvş¤öŠĘŚzfÚéI©=˙tŰ"•X{×SɱU–?SůŞ/«đŃáTVČúV'«)€lçŮçKĎ#ťBÔ˘2¦˛¦2Ł2y 󉺡s‰©Šeů”‹‘Ź1–˝¦ňiw.ŮÜ™»&s×t4šĚ]Óqč'J5˦TΩ,;r{ó=čďÚďŁşŞŤ^Ţ>®*áţ°ľ ‘8ŕ±;y@DNC.”÷ß[űČŚëvă‹Ůň^ËšCB+ż:%ó…줬ľ1ÚĘÍOB~ó•«WK®V\e\YĘ)W1WEŻm9rľôčs®Ş]mJx5ŮűŰE*­˛ł půIŐ[Ń (ąÄĂCýw-Îßçđ´iß'q'sžßŤďľ<َă”÷§lNî’«š;í™-šŁŁ*屢w¬ňö±zßr¬píłg;ĺ÷84žşďă–#T[rĎf—źr=çđ~)ŃŠZă Ýow+”Jæ2(F“¸řΚÚ)µ˙¤öíM÷±M­®o‚˝X·ÍâOHâ3’ţ¸ł«Sjżďô˙BíwÔţÖ¤u0ó÷Ľ@¸Ú/óŔśúŻ©=€6< }‘}žŮGPűöŔ<-N–AÄMI÷ ¶2ňž‰Ă6’ĚҦ’¬Wl=Dn=„¦ëľźYd(Í{ĐŤrŠşZŐ‰Ó2YTEąAKŚ'ž§śëuŰ…@H=č†Ę#UóËŮçdpcCİ1Ät=9ë‘f°K”t`­wФ“ß/ÎŹ^ťLß˝}y~tţúúOG˙ŚG`˝ŔëĆŁfhŔm¶Z•ĹŞL‡‘ŽV4j%đB ™ssh1«0®éoĄŹL-čô©‰Ó sÍIA”Š7}„lŢEÝ 2Ç\ôE¤ž[·(żöC $Bc–­ nĹI•”Ëq~ü‰YKj‰îP°4`q®ąČÚŐŞď Wu`eâč2o—  ¨‰ruŮ:ţJ×Öµˇ»»§Ř8YĄ‹ŞÁř%ŘłĹέż&•Ť@dČÉáC09ĺ†"Rţ˙““Ôŕ:}Lî)žPĺq>Ą°Ą°ľ¬8ł«:PŐ'ę) *JpŁď~Y‚˙×<9 <Ů’> stream xÚĹXYoŰF~ĎŻňDÍ˝x´čťČGa;‚-HšBX“´M€"q“_ß™ť%-Ę´ŰÄ@ú"-gŹ™ťoÎő&worüĆł˙‡Ë7űGĚź0ĎŤĽM–·&¤řjxŇeÂź,“ÉźÎň>ťţµü}˙H„Űk9s˝ĂIfQ“ÖÍţşLÚ<]ÝĄĹ”9iĄ›˛˘ť;\¸ç‘ě¶&Y•ưôëtĆ9sâ˛ňŔitVÔD©Ó/Sâą%ÄU¶iĚ,wš{Ý9I×e1CŽ“Sˇrá*§ş™ŇéLÜfĚů2UĘŃUV¶5âr˝ÖERÓ:Ť¬iM–ë›ÓP8•ŽIq˝ő9©Qř > wć®bvëgŹ;›v,É ;C:N ´‘٦­6Fô˛ŢÁŘÜ÷—]9ÄĐ8]Á:9üN®v7 |1×ýNŽů§ĺĺÁ»ůŠ~ß/ś^Ž!…nŔşM5‰śĆŮgOHD…ŁŠJî pÔ5اőÎ ú¸Ďb„÷ŢîŞ4®Ké ĎË»u•’ó÷(+2ýgOy7h=_é;Iou›7¤Î¬!bVʰ{—± »Ř~łŢŚÝ,{ě€űőE`fL‚;(ŔUBľ šłÓĂËËŹ ĄŐâ`y2ĄB÷~Z|DÔ±Śf"‚VlCź Ŕ4äĆl ˛lH „,ŇşŮJ®D“ëÎ ś-Ł%G†eą€cr{˛BŢŠ˛H˙‹îI‹¤zőzŻSx໑Ďë[ż‹Ú~őD@Q(;ę zőtŞčWÚÍĄNh´Ą,†•aĆË ´ń^"f%‚Ô‘çDĐČbosf#“2$!ż‡×ąŔáőŃŃür.puúi>î Ăç‘ ns}J§ÎľĄDÂë¦nZŘ!ŇŠČčH%ÇÁ1¬fÍ?±xˇ¬ťcQŘ×Ô/F­=ÚŃCE˛ { ŕđ™ůüđç:ÄŃŮőŐÉ3ˇü„€ú‚ď©^ÉLŽö¬-b2P%L<ܧĹŕŇhŘi´÷a€Ę#ś<ŚŚđ0tnŰÁ9޶@ńc¬¨SyĆMNöL©]ő'ĐQÚď—Ĺ ;}Ä㥠,v_S!Ď«Ş¬f`ČINU;Ă˙§6ľř°ş:=ľĄś­N.ŢźÍGkd&}—sőŘ+Ö¶g‘áNĘ—ˇ‚Ŕ~gl'ű[Rz±ç x)]<Íôhŕľ&˙‡`:ŃUň€rQ ŢqْѧU=«Ň\7]ˇţŁđ˝.g-§«wľë‹ĺüňjĽÍ®Çű‚:͡BFä¸ÂČ€ÝďÖ-‘ş›Ň%÷MxÁ9ë«8lkQzh-źť@‰É$`Î-¤Ĺ/Š´›JC÷4Ě:đ—şw&“@pů›dY5Łq^„.÷Ő3š¸UMüöÖP΄ÎîÚG«ĺ»s ˝K±9Z¬N/®ŢŽ6‰Ę E_ٍL:‹<ŐŘŰrBĽiĚ(č^Bd×–Ŕ€ŠRśÄB)u»±ÍqelçvôNý!ń(U›·‚Ŕ1¨Ą¦ş…/˘vµ9Ě9íĎĽ±)‡&čÂßá‡îř[ő Yk_!üíWź¬ ˇu¶6ŚňFél,Ŕ–mť÷X«îŮk Ě/B‚ĂŰ\$&"­,čß¶vŇŮTTŁCˇPcYe&MÔ°›/ę*mą é”y‘ëŃđx5/€$Ő@÷H%É.…lüÚµĹ0€ć˝wĘŤŢd+ýz‹1R‘đľ·™+쪾ŕÉő–XR»¶ ™»üKŕc!§ţü‘ď|qú$Ľů??Ľ«÷×ç`)‹Őůüęęŕx>â¤rĺăN>a‹ů>ßL˙¤]opd 5$‘“âÄf+:w`-kHß™j5 ±ŤâTEă—¦?zę{ô%w>˘ĺ—-Í;Ew;ŠËő¦5ϡf@ ¦đ®R"ĺÁ®­Ńę&‹ë‘ňŞ´ŹçeMSk% Ä]*ĺ™Ŕ§ÚËŘ`Í|ůćQ«; endstream endobj 256 0 obj << /Length 396 /Filter /FlateDecode >> stream xÚmRÉnÂ0˝ó>Ú1Ţâ„k+hi‹Z©9u9XÁ@D6eâďkgB['űÍĚ{ófl†vˇ‡ Ď»d2[ ¸˘Ri’-â<˘±QÄĺRŁd>±˘! 8g ?—‘KHá—¬Č:ÓeUŮ’ďäéWx¶”!âŚÎŮśŞšJ­P |Ł9~1]‘¸ľ W—ĘW[×RĚńâ#!±ŔŤ!§ÖĹ$ĂY ą´*ę,·@ǬŰCŢ@ 6M—Ą}nŔë·ŐČ/ęܶ$"Ć0´}JD„÷€Ě0ŁópIĂóŻ5 Í–Nmę c'׹3ňÜÖpž*=¨śëŞŽ^şj#g U§!ÚC°éK¸śĽłŞo™şÎłôěÓKÁ¤>UVÝŢ6Ó˙NC0j鎒 ޵źűţQŚŕ˝"rĚÂ|·QůÉ˝ŰfDíŐu{č[ŰBˇë ˇÖ#wýć•V·VwsíRřEçđÔŇ=ujéĹOqVS-9 BŃŤß”‹‹ŞE2ů(Ľâ endstream endobj 265 0 obj << /Length 1787 /Filter /FlateDecode >> stream xÚ…ŮŽŰ6đ=_áGµ©3}JłŇhQ¸(…V˘×Bu¤”ÄýúÎ%Żä(ɓșápî*ŘëF8\X§SS—ĹP÷jÇ_óez¦Sá/šĆŢaěJ¤˘Â ›şŰÍŽÄŚŕ¶Ňś…ŠPZßOh=ÓˇĄ'HâHkĘŢV¦sDˇň^ČůHÂRG(JĆ2Éţp…/¶b—‹r(śĹŠśě‰Ţ »¶·żiĄŮ] ‚»Ű— Š8®`ĎÇűđbűdŤb9ëiěɚτŢcH`\L:óniMâý‘„ÓŻ‘ÁWq )ŢÚzÎ…ş©maĎíůëĚ©°Ĺ`®hYVŠbÜ‚–+ňA–čBDm9fRM+ĺlß2ŚĺÉŐŇRä7Ě ĄĽ·SGÔvtĽV=iď&¬a>­V@ý ç•ÜByős|ă.™d8z$#Ź Á D·oUC:jcHňG€ł2#ćďÄtë…Ë " X´žł:šÇxb›BXJÚ¬%¨A>$ůŃR¸'Cf:"C" h‘bčUci„Ž$ˇx+mʦ¨zŕďÉöX.eŔ¤¸ŔźlŃţ´ÝĹpĽ"ç_ł‹¨¤TšĚ“Y§)g €/řY‰‚,ÖY6C=g(ž`Ąű†·îŘŹMĹL Ô„Ôék±­ąú~KÄş5»ŞÝزĎ2°PáţuĽtă”ř:Ó”úŽ—%,űöDę—“#Ú u)DZ+ŕ÷Ş<ő%W且˛&~=tĘŇ? ăMI-Ť‰‘çx42Š †Ţ˘Đ¸îaŐIń×q°lŠxú"9yÇ0’M÷Ě{*ş»ą°“.óŽţpâ–ł*˘ĆŰGĽçĚëS3>Ő9w•HQč"[P&d1y wÔ:ÉŘbĂ R™şbÎŰ©|ă‚2]DGPDĆ;đň˘âK¦ľ{‡FťŰ€<`łŚ3˝gŔĽÂd\˘e}—“¤ăL°č}™ëk7í©sfËź%PµĐ ů!㚇`w„n-0nµqĽ- ˇyś¬›^ňÎÖUe:¦ť&Áěj› üŰí?üy÷ŰďŻo׆·8ńuŞŕ ŃľBŐsďďŁ!7Mĺ@ËŔsŰ • oú:1ú*ÂÖÄHHMĐ‘ăĘ1HŘBťŻ*kúŹ˘\¤™§$EY& JÍ˛Ű Ľg0Äő`ÇVMľ‰EDËńđjjŚdâúNî]ęä^»Sxfésu9)͉W·§ĆLŇѰ‚@A’qżSećF sŕhśŐb'eŠŠYăMźłyEŇëÜÖAÎU@‡ÁĄřčľ Ęa,¦™nBëB†ěą8]Ç_'~–…SLý ţr?ů„özň"ąş®X–G..+ ‚%ŃK ˇTLĘůdópAř,+K¦€ŔwŠ9ŇAΕćrÄʡZw=ďÝąE5ź{j€iŕúfüfˇ[áťóV±"x´Ě˙”âC÷_öđ ˙>ůČ9+Ł=BLgl]®ň!\1ôr ˛}Ř?ĚŘbG[šN‘>ýň^ţ.mÂTĹ#đVę‡Jłřˇ^Ýí_üÚĚôU endstream endobj 273 0 obj << /Length 1813 /Filter /FlateDecode >> stream xÚŤXKsŰ6ľçWčHÍD ľÄŢÜÖÎ$SO=ŤN‰s€)HBË×”ç×w_ $[žÉ‰ŔXěóŰăŮnĎ>ľ‹ĺűűú݇•ĎTĽ,ăRÍÖŰ™RĹrĄWł"N—*ÉgëÍě[T»‡Á Îúĺüűú󇛤„}Ë2Ë4‰g ].u\ňćl©–jľPJgŃÍŹ5ź8żOÄˬLřÄÍ|•DÝ0_$q ¶ę†Ťkw8Í"ű8×EdŰą^EŁDĄ˘ëŻk<2Ęň®ÁÖ 3čZ¦Ť{"’ ( j‡TTçY,ç‹4I˘kSá{ćĐÝ|Ójç˝°} ’EÁ@#TA%Ë,Ą]ëÇáĐ śE4Ú śI28Gžqśżw¶µIlŢ67ÜÇIZËřŕŮ"°TY2ńSË_°—äxǤ˙đfkűK˛Ž{Ë*…»â"ňî§Ťč[uMoŞ‘— XÂó°;Qç=˛¶â±pp ěF÷­&÷1͵r“–µčšo»ˇ1ăeÁľHU Â1GvgJ×ÖĎ<"őpиÖ5¸íĐ0Á4ÝĎÉ™-]Ëwş®ýmľČĘŠF¬\cýhštLu™ö’XG äś$ äŁhŮqMökQÍ Żw=^fj^íÍ`;Úá—óKK~}\ü…üúó0Pôh­Ř:8čIÂÎŹ‹¦FŰ0Ő€PĎŢyŮł7UĐizż¸řYž<§ÖúxćÎάä/ŮŃ´hť,ÇA'١, Đ€kaź©$ú42©2Hfşm™rŠéŕşŃůŃUÂă>Ö™¬*”cĎ3sĽ µmw㞉$'˛f,*„…7;‹x¤‹RTÎ3tŻŠ…S0ĆtÂAŹ#u˛Y5Rôw!>#Ři¬–,.Fld&–”C†I’ĂH xäm8ňśé X\4zí~rpäĹ2qbúľ‰*E@Ŕ˝Aď<şn@đĎNđ­óUđŔ‘eŻůHĂŐ Çĺ€áČĄkß®BSŘÓ€  ąF$Ďň丄 .~tBX P¸ŕ÷ÁŁT#Ďś@ö°e0§µ¦¤ çčKŃÖ{G·ä‚ŹvhÜ(;?·(­ Zîaě ůaí•|y/ăxń$üt悔چ5Ç\O7”).„ÉŞ-ň$ehzŠ`łĺ}ç⡠+'ił;ôëŐç{¨ L1‰ßż×7ňJB„ańÉŤűî jČ ĎôÝB9ö°[\P'!ËÍ6„­oČf1˘¦ŠęĂŽú9ÜÄů#`ě`ăOňkśIóHĚ ‹î’?1`éµP¨V‚âő3¶wiä‡ÚŢ ¤aŰňwÚ±=´.{ˇwü=é÷Áká"Ę9ýÚyÇ@Ge!Ř tOëż.Y ^˛Ó“gA ŢyY/ą%ťz»2t^xö‡­a»žXNë€ädoAó÷o[]pŮ0s5V7"ÓPÝĐ“űȇŚ[^§;{Îŕ¤ČŇ6ĐMN˘±‘dxęí‹«O|Ł˘7Ę2E:¤ \BŢu@*y;‹K˘ Xň$ óSů‘,s ĆkB_×p˝•şpSŔÉ\ú‰‹rźĄW iĎͶt3D Ů‚ęp…|źyNŔ ö´őÄeOŤ†Ë6şáaĎÓű8‹oď>]ڇżůÁ`Ű[ŞžTőtt·ŢC˛yĎEť»ÖLÉôŠ7ě2µď¨ž^ 8G]l,ĆXK)´IłdĄ¸Ł¶ŢídY‘®Ż“«‚âŇ5hWuňĆçź@˘¶ľ/"+m–P «§=öĽřř]›‡仿®ľÜ^±çj×Z3˙ÁÝ52Ýáď‚ĘmsÉ‚ˇY%üţ¦ľs/ă|t׋‰ĺ‘ýŹ<[¦\#óŻë®Đ„\Ëë‘ĚEa4ýŘ™©"OAx:Ʊb Tz¶ëzýî=÷Ë endstream endobj 278 0 obj << /Length 1644 /Filter /FlateDecode >> stream xÚťXmŹŰ6 ţŢ_`_ V,ɲ¬ˇčpíÚâ ]‹Ă¶ĎQă;óKÓŰŻ)ĘIśúZěľś%Jb(>äCę˘ŮvÍŢ=‹ü÷ŐňŮâ­Ô3±$j¶ÜĚ8×,é,†Ĺ\Ď–ëŮ_Áë]včl3ĄŠdţ÷ň—Ĺ[nf"f:ŐŹEł06,ĺ1x;OuĐŘz[Í… şňÎĆ&¸iďqn×4ýĐ۶+ęŞE•'«Ŕ$9ă3‘qşSfL2 •dŇŇ˙]ťŕÉĺ ž2ˇ5,ąÍżďŔ ř=Üҧéý|?iđ@ă_ó«ŮáPy†v‘ŕXt;˝ůs9OeĐdą}Ž’8ČĘ’–şťĄÁˇ©ç!¨ÍmŰÚe<ŘÚ*DŃM\2ĄČ0Űdť%§âqçV™^^$N€‘żČ˘Ű/úÖ6U¶·/ç„9`8G®Ç]ĘÔE‡”¬‡ÜL6}•;>rŮ5€Ęş§•u´…g]®»Ă·$]EE;‰şoiŰeĺ”ßpVQI ń~÷$%Ü`đUÉxrâ<đöÇ›×oVßż_.ĘânŠŕăé"Ěú®SšŽl ýᑳŔ۬­§ÂRj¦˘tĚ&`4ÇM˘ŕvC·Ą»Ă{®kďHD­ő~D~ĺA[ý éD¤ \ěhçŢfŐ€ ę©÷¶ŰťHË›7欹#ÇpHÄÄb4\÷M1Ś [ˇ ÜŔś ŤŮŇ5 Úś•Î$ż7×:}U D¶ŃJŽělŽÜ“…m©hmęĆç첔Mĺ~ľÚ¶$ĄXʇ„4P­=\y]mŠ-‚1ÉfŠíuťřÓɨ%ă'‘Äč4—g\-˛=ĐW^ŕﻜăC}…ĺ˛h;9§Ă÷"ůZżą¦oߢŁ,M˛j¬j(ůÜ3ŇVŽSÖN$Ş^§Ą±ž’_;`S,,yÚ,±Ź%ÂFÜĐ÷ö’XÍ›ĆóĉíNĺЇw”4CÝ»z([ŮŻuę}Ľë˝ŢşrŤ<Ś2ú „LQ—KMp[Ńýź>1yRźhŃLĄÍPkaO ×)ąš?ť;çá®(bž#ď«ÉnÚDLĘSNaŕLu’ %żV_PűcŞˇáKÎüŰú$É‹ÍOYcX¤ŻjňżâšĹAî ŃOŹ»Â•ťMft ö_´ ¨Ěs¦bwŇĹ?ލůą<”­§ďťÂ“%Ť‡+üPTyŮŻ­7ß/ŽĚáťĂv/§\’$Ś‹‘·!ÍÉ ©S(Ő=IÜ3m¢T°řÜDź› Éň—0©ĹEĂŤqu9±ÎŇ—ß51”ąhÁęĹÁ|]ŇmŁuĹŻ§ÚŕňcüÖDŻé}ŰgĺsźDŚjđWÇ—-[ěV@EŰ9 ˛)€yÖl§_„\0«›?žĄB+xäÇ]Oa®[şČĐAsOGâLGßâڽʼnPé®éqÍa1ĽľĄ^ NżűůŐsî¨×Iŕ_Fbři˘HzôŚ) ܰDňY+f¤˙Ź·/o–Ďţ §LĐ endstream endobj 176 0 obj << /Type /ObjStm /N 100 /First 862 /Length 1818 /Filter /FlateDecode >> stream xÚŐYMo7˝ëWđŘ^¸äp†…QŔIę4@ ± ´5|PĺŤâĆŮ5¤u›ô×÷ÍÚNbKN¨HM.ő–|ś/gŁqĆ'oXŚĎ„nĆ_2xě3~ň©čőwgRÄxf“ pÎxô¦ä<ń?y>ă)á…‚ąŮEt0*Ŕů˘Kp2äX°D<č*lČ{`3Ú¨P ČEĚ‹)čŚxg(°G‡ĐÉAËA:I!bH”LÁÄqC‰0ŚU)Sšs›`HĹăgO&8Áä ĽčZ ¬ÁsF›éMďâµ Ną"č**‚-G´ ‹éBWÁ TSdPŤ:›2ĹžCS„Ą»†}„ĐŁaP™$‡VŠIl8čZ„Ŕ* 1Ě{˘ ‚¨Ş,‚‘v”)(Q™b/ś ZÂ✉&„QÎş`Ŕ4ĹŹ˛DGt¤€¸J—:Ş0Ý‚+:BF|Đ‘€NÖ6˘ F$ó„°y ~Ô:Ř2q†T;0,a<#1¨v0a…¬-lڰ3ÉŞ)Á|ÖF ]ŽČ/zŐ3¤˝Jöjň‰Ś(:EMFUňQÇśu$šä`+°Ë¤’†Ĺ&,,! #Ł ‚ĚCˇ'É&ă'µz@b‚ÝĂlRRs…ő¦„)(©Ô@á1©”<ŮŰ›4O̱Ǵμ0Íďü I6c",ht×]žźźL~üQÁ¦yÜź÷‹Ă‹é¬5áęťçÓahťąžâ§·ĂÓĂa:´ĆŹ“ć ďł·gšhĹĂďFÜ˝đ掅ÝëVjž/úŮa;cL˙äŔ4GíŰÁÜhŽŢ]´şîĽť€O7´Ý°„_Ž|&Í‹vŮ_.fírôüqč×öôlú¨kޤ%č&ł·ąś`µéSUÜßďş3Ź‘F)i¤ąjËU›ÝŘŢa4ľ7i/˙Ćç_κדćQż8măĘţ¤ůąyÖ<Ć–:Q®3lŇG¶°n!đr*"o%¨…˛…‰¶?ŠďĐ4OűŁŢ@cßÍΆÖî_žOç]ßyúéĎŁTň˝ o7”R´°Ď÷”2[G”@ăĹeëýăŮ|qvşC>ąŔËB%ZAĚ˙,ˇÇýĺy˙ć/ď.ÚĹŮrÖ_ěRH\ŕ)­Ř X’%8—`ŁK÷sú˙>fˇoy`Ľň@!«Ńîc\ţ6ݵȊ»–°Ą»ćk÷,îşő×íŐfőPżßmďÓ·ŻoçĐ3NÖâ¬zdCď‚ĂĐë‚áµ ŤÔěďíŤ+4űłá¬ďšĂć·Ďôď»ďď±Ŕ ŢY=´BLÇk¨Đ< ;+TOŕŐ0\üĐ4§ýżÝy?=µËé?Ó®›ľ˛óîŇö‹yłhĎŰé˛]6/_ÍtU2‹őČxŘ%«)N\ëoĚwţÜZ{Ö-Φö墹Xôcťe3ć[°dN68=µ„5 ±śô<†ľE6¦Ůţ7h4¶wé~9CĎ< áĹ:M+ ŮESëb|†g o”nďJ÷‚%›ŕNU`†jnXŽŮäĽu`©ŚäŢFäu`=瑪Wq‘°Čĺ+Á±XĘ•4(+wŔvR ›őTVŹ Ľ&Îos†ËwĎ˝+mp† śŽđÓä˘Úćď€ě ~P!ú•ĽYoŹŰ ŃoÍÜ:p¬ß8Ö]¶zĹüúÖŹ;+yy(-®ş‚ßÖü&®ŕÓ&Z\–‚Ö•:0kÂ+gfpLu`Ťč…}¨XďwkL5Vr˲ľÔdVL†Ü–&C~“ą ţŚÉ¬kúëc-qT§ňŤę*®ęŠ·Ő•l˘+ŮDWkŔ1[(T‚ÁŢĹ\ öŮf_ęŔ’q9§Ę JȰŻJâËÚ$s=Ifαě,Ő51®Ö goąT*…YG•Ň`˝;E®k"W ´’*7ç‹çJ±i)r®;«őĆŻJ´\ÂÍVÄůćAo‡7ď0ëUq«#~%âpŮ2âŰ âÜ_»z Jh—‚Ż ŰřEËý7‚‡ôŘŮJĽ«]6 č’WÄ»I@ůúW—[BÜľ†HqĄ†¨_Jľ@júťf¬FwÝúë–vYň¸˛čâPşŐďiaLNXů¨żżvüčröÚą'ďşgÝrŘ])[kúÁW«ő%Öz"T`Eź*e?™v·ÓÎÉÁۣݱa 6sąaĂŃ[ŐőgŮĚďÔúő›`˝źĆ ĘjkÁúíFrţęvź§ŐJEň[ş{Úí—<‘ŃŤą`Äö˝fA4~î¶1ęSŢÚé]y~>]ľ™Ţ5´I9eÝ·Ü‘"'©K&›$ÖCD’µŰbâmú8/Ú… ­ÖIRÜňÜM5u’˙FHSt endstream endobj 285 0 obj << /Length 1575 /Filter /FlateDecode >> stream xÚµXëoŰF ˙ŢżÂŘľČ@$ë¤ÓĂÁş˘Í’ŔŠľŚ Ű:ůlkŐkz$K˙ú‘Gʱ\ŐÝ‚őKÄă‘<ŹŹźăN¶wrýÄ=úľX>™]ůţD¸ÎÜť‹Ér3^čDQ8‰\é?ś,ד߭çÎôŹĺË˝ÚěJ„ťŘń˝¶ŚđË®i§¶ď{–ZŻ‘V»ÓhΊőBß‘ńĽ×ł×$sd[:ńÜëeĘŞMË‚¬·%żüm9Ť}«V‰nčBÝdSZ_˙ôâ|Ě ;đś8śOlá;śÓIúSK˘kđŤ,g–ßŻŞşÜÖ*§X«z+h›ŢŘ5l/pá Ďx“iŐ sRZEŮ2ŐîTŰSiCTł+»lMôÍÔöb‹…UUe©ćť˛ČŰé‚öJÂę¶,"+IşşéĹÓĚĽÄyŕaפŖ˘zćălf éŕEŃÄöc‡ÍĽýjţ żńÎľu7U1…»b8„´r¤ďi—ŮćąőX4 ŐoQĂDäŇ‚¶-›ĘDA'é×— 1×i­“¶¬ďńŞgČ‹¬]‰VîH QleÁ |8>ÚłŻ†«Äö<Č„ŕ…µOĚqőqĘ·…ĚVÄĚJ‚ň#qS.”÷p%®aAU;ňŰ>ŕ/&ĄŚ¬tß…K ~!׉HT­‰RôzeÇ;Ż+zÍâŐ(ÖD,Čd9VIŤ)Źü;ŚćKd±Ť–Źk4ňęÍb,É“27©Ői˘0Rßú!Ĺě*;pĘ”QŇuÁÍv´I ÇŹDŻ UřîůĹĺĘük4Qä„Á^Ü„lc6§e)6gd•âäÔ Ö]¦âÜOÍKĐbVS†Čém*Č*ŰĢ9w\Ź»Gäv–jˇYءZ/°pçľµÖŐeíÚĂYFlă  O"Ý4ţÍěśR›˝4‚5o™6Ż×lń3Ů÷ x \$ʤËČă·Ú¸ŕbĂt:ś%.Ďüö,żď˛Ŕ„|:#ę0]ąs dM»śŰínŻFű&§ŹÔG3tÓ¦„›Ńůu0Zü>őßUY·4–.áî‡ió4ŻŇ±SNę”yu¨óoŽůuh0Véw§kJúNP˘áH!Ńt.°ŚĽąÂdluˇkŐňŞ{˝Ľ"˘}ÄA1Ý”ĽmšR ú$˝…Ű´éT–~b…”ĹîRxç‘čţŚ^)Dý_ÚKřŘö˘,8¶`‚ăýdC#ČŞ5€‡†6q@ŕ÷zyMÄÓĄîę´50Ŕumeš4Đ&tý9)31>#×?xßçčűű9Ž$Eżq°Žç0DÁ ?) ę 8­kňĨîôޤ^o¦Ź˙gUΡ‘ú}ß­ĐşéaýţŔë[8p¬ËâŰČ=r=Ł9ű'_Ń_ď‹Ŕ7Ŕ)÷Ŕ— 2r–9RŠ!DZÂő_zŁ@/ ·@ńi‡§b†{y5űˇkt]¨\˙¸ęułr»2Q0ŚŕĐÁµ*>®\¶Ńć`ĺ‹6Ś(r&Ŕ{_†žq?lâÁřŔ c2:€­…€qłśÎ=«.;čő€†uAGĹd äžF¸I-0łC¬\DO2< ¸Ř@E$|[›˛3cMKņTѱ¨kZ›‰_śĚý«Ó á.ÔMY—&1WS¸–őUŢ§Ń ÄĆťR`ÇŔŃřa:#üÔE‚.âpFgĹđö¦Ű2~-yăs@Ý”9chčă™*ĂD´rcPÁc¸>hěGEhtOŃ!řw`Áĺ †¦&HČYk |VVąŢű†•ŁU~~Ü(AÓ !Mä°O~pEtşS˛/¦×ĹC™żŚ;Ń;9¶ÔŕMţEÄXj¤ŹÂ±kŰŞ9źÍ¶ĐP·‡שr6ő,Ś3{¶…¬®Véú)Ś3yňĘ6»˙Ü™ź@X‹wxĺ Z$xçŢS…ÎÎOŽ*íFČ!ţŕzÁio„ĆaďÍ{]SÔŁ- zźîg|ł¦uQ®µS@$ 2ꀀKěé‘řňQ^ě"q잌×ÝK~ß˙Ďŕ”ń(pBśîŕ™7ŹHQ„•Ëĺ“Ía' endstream endobj 291 0 obj << /Length 2098 /Filter /FlateDecode >> stream xÚŤXKSăşŢĎŻČî*UŘX˛üš]`20 0)Č…şw8 áGÇNÉ63đëO·$ĚÔŮÄRwëŮ_ÝJ0)&ÁääSŕľGËO‡_i6aÜOŇ„N–J?eé$ŁÉr5ůIŽÔ}©ęB‹ízĘ2ň<ýky¶›äđ+&™źĹ,Ć ‚‰…>í‡ţ¤ ¬'?˝'dîO˝0ddVteY`‡’3'ü"7›)%˛<°}+§äK]BkáÄGN|*VZí™~ďô‹x9‡IEUÔť“ź:ăóV(ůp€űśĐN’NhĹÉ5\€lÜoáBăŘÂ-ať^ 6ôMă·° Čü!ŞĽťß? C‡=6Š˝ăµĐ%lĆ ăŚĚşRU]áÔŕĎ/bŁdeUB·ŞňN:U–RËgňŃ Euň¤Vfš”\uҨSwç ±Ë,<´đ>ÄÚZ §žâ’ €©+µjwÉY@ş*o‚…ÓŚ¨Şi5Ě §ł_Ş][“ů˙—v/ąts~«FĽ `óYö®X7Öřă< Č‘ŘZ6á<<„Ä„KHżhŇW•VÂЇH^ň·ż]oÇ(/ }žě’Ó>*T;śG{°ŚGayŁ f{W„@._Dő·¦Ľa!ąčáçMm’ ŁäRŕ>7­±čÓh>-˝YµŇwPKZá­Ár®eĄŚ 8Ěič0MĹąęW˙”f˝®l•WJ¦ „2Ôú:ü{ě©ęŻ l"ĆëíZK±BGâ0)Ęl,ts}Tčpźô…Ž«vVÖsXě`q`J^řľ)věDĂ:•bM JłVBÁŚű1 †šwv1oom…fŐaጕ–Ńa„s-„Qšy déÄű{o¤Ę‘(É|[|eČ^róϧq;Č ú?AÔ×>Î~đČxC¨P·cÓ$rd{$5Ô#®s*ŐJ–}0Żu{äŰćőVĂ>ĄönQ0T,¤C}2Šúw‰3†”fKň˛öP ď,ާV7ŕ-1َ!ć§tĚŹrd~äŁ FŐ˝Ó÷ä˙.Ü%Žçżî¸;=÷…GÜňä ‡šÖ r¬ĘmÇ˝00”v:ŃÖÚ áË6ě‰~2쉍WöÄžcO[™Ůď=Őń{f|¨ňz(:ö,ÚÂŻĺ˘)öFI8 ü4K˙#˙˛Č>6ńk@‰ŤosŘó|~8›2Čč(Śń=Ňł.ËüëâëçÍ֬Ѩnăć«ě÷¸„^jÇ|ncĂ"´¬»•-@Ý* <Í­ąŢ^™ŠŻ•ăă­Vřd}ćD~d{ëĄüeďt=­Z§®]ĺz L\űż×37îBôe¤Ť;ęďýEGă ü,ČĚź|^ďÚŹ›€WÍ[É`Ě|ůéZE endstream endobj 296 0 obj << /Length 204 /Filter /FlateDecode >> stream xڕб Â0ŕ+ ‡Ř(z/ I• Eˇ*ŘAĐÉAśÔŃAQp(âŁőQ|„Ž^m‚E\$|KîÚý.Iňj’:Šzm}< ’Tś00µÍăĹ’”D1ĺŠdF§ăy‡"žŹČG1¦•OrŤÉ Ć<˛ŔşŘ€spůŞÁ"–˛GĄ…9¦Ť5ˇ4ĐŇĘłň’ťëQ3ÎܬŚxÇ:n¨™Ř«–~y~VýĺňCTáé(Ô™ŁŮüF++ĂI‚ |Ű A¨ endstream endobj 297 0 obj << /Length 194 /Filter /FlateDecode >> stream xÚ•Đ˝ Â0đ+…Côď4_( šV0 “8©Ł˘ŕСŹÖGé#ttp0!‰Š á·är˙$§T< N‚z’“’4”´xBĹÉ®‘ôĄÝSŤlMŠ#››}dzA—óő€,]NI Ëh#oQgĐ€–ŤÂ‰JŁrŔŞ˝Ű—ÜHţ˙đđîNÔN#¨ś80om[…ÓµŔ™xáŠ"mTé#lűG[âX»)ĽŽúiuŢe0Ű€3Ť+|RA endstream endobj 298 0 obj << /Length 136 /Filter /FlateDecode >> stream xÚ32Ő31S0P0SĐ54S02P°TH1ä*ä24 (™Be’sąś<ąôĂ Ťąô=€â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ĚŘ?đ˙ ˙ ?°o`0`(`H 0703°3đ1Č0X…B \®ž\\Ë—!Đ endstream endobj 299 0 obj << /Length 93 /Filter /FlateDecode >> stream xÚ32Ő31S0P°bCK •bČUČâÄ@tr.—“'—~¸‚%—ľđôU()*MĺŇw pV0äŇwQ6T0ĺňtQŕc°o¨oř u 6 \®ž\\TtÓ endstream endobj 300 0 obj << /Length 164 /Filter /FlateDecode >> stream xÚ31Ň31Q0P0TĐ52T05T03RH1ä*ä2±Š(XCĄ’sąś<ąôĂL,ąô=€â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ŔŘ€L1C)0ÉŔˇř „’PĘB@¨őB€|‹P“ŮđX5Ů€X °:Ő¬NÇcV§Ź† ˛ \®ž\\Á-› endstream endobj 301 0 obj << /Length 117 /Filter /FlateDecode >> stream xÚ32Ő31S0P°b#3c3…C®B.C ’HÎĺrňäŇW04ăŇ÷Šré{ú*”•¦ré;8+ré»(D*Äryş(0Ř0Ô1üg„ŔŚ | ö ő ˙!h€ —«'W %– â endstream endobj 302 0 obj << /Length 96 /Filter /FlateDecode >> stream xÚ3˛Ô37T0P0W04S0˛T02TH1ä*ä2 (B$’sąś<ąôĂŇ\ú ¦\úžľ %EĄ©\úNÎ @A…h ŽX.O…ú˙?€č?}ŕrőä äżIz endstream endobj 303 0 obj << /Length 94 /Filter /FlateDecode >> stream xÚ%‰»@@űóç ÜÝ»¶öHl!ˇR Ą‚đ÷„)¦ńšxOĂŚjéSŞăl±Á…7ę?¦y„ôtRS!±á±ź $o ZHÉÁŇŚ%ď—ëŞ ű˘ endstream endobj 304 0 obj << /Length 219 /Filter /FlateDecode >> stream xÚUĐ˝ŠÂ@ŕ]¶X"yp7Oŕ&BĽtţ€)­,ÄJ-…xś`—ĽŻäÜ+ä ÎŇBXł3wf>f¦Q6řbŠąËG)î38Aîf©kÝbw„q fŤůĚĽ›‚)řűs>€/'™â&Ăt ĺEňćŞPš‰>{Zâ; f,óOČž?B]}tě1LÂU|÷hµ‡Ľާ!´đ‰’€‚©­ő°L+ô^¤Ţ¨†Đ=‚™I ćÂTĚťB?…KkŮÝ Y +xir§ endstream endobj 305 0 obj << /Length 275 /Filter /FlateDecode >> stream xÚ…ĐÍJÄ0đéˇ}íĽ€öͲ Âş‚=îÉxRŹ‚ŠÂÄćŃú(y„{(Ť3itáG&Édfôęd^QAeEÇ-–¤Wt_ŞgĄ5G Z”áčîQmj•_“Ö*żŕ¸ĘëKz}y{PůćęŚxżĄ›’Š[Uo @<â9ufĆ8g׋:&í°çŁëh€¬FŽ÷OÂ^|I‡ĚňÓNî{ڧ‘?,ś''Oěi%ÉÉőŤ‘”_ůŕMŔü ŕ–?ŘKŻŔÓ´ L Áz˘@;uŮúž3Áĺ2<ŰŚ+ăŮ¦Ś ŐJfWÄ-Ć˝<Ď%5ľŢß’“É uöP›:ŻŐN}°m» endstream endobj 306 0 obj << /Length 245 /Filter /FlateDecode >> stream xÚ]ĐÁJ„PĆńO\gă Dsź « ×ZÄÓąjŐ"ZUË`Š‚Cúhó(>‚KĂŘů®Žf‚ţ¸ žűż.;™ĎMbśŢŮ©qgć%•wq™®.ůáůM–ąŘă2±7úVl~k>?ľ^Ĺ.ď®L*veS“> stream xÚmŃ˝JÄ@đ˙±ĹÂŢyÍ— pppž` A+ ±RK EÁBČ>Z:_#oŕ–)BÖ™˝ŤwáGf6󱩧ł2Ę :)¨:ŁňśžrójĘ’ŁUyL=ľumŇ;*K“^qܤő5˝ż}<›t}sAüľˇűś˛So€qĬĽ=fĽď–›9fîđůĹ©Ëh€¤FŽ÷PC@s€>ítü©“óh¤GŤ[†€ ´Rd‡ÔúĂJÉ " h"ö|š÷<zŘŽŮtÄí! Í#ݲsi‘DÚ0$§'x,.$cq/őcÁ÷˘ż­,±Ňág J z·ß\ÖćÖü­U endstream endobj 308 0 obj << /Length 208 /Filter /FlateDecode >> stream xÚÍб Â0ŕ”…[úŢV´…ZÁ ‚N⤎ŠÎíŁů(}„ŽJĎK‹ŃŔ@Č—„űá.‰Çé#śňfĚR<Ĺp…$ĺ{d®ćăxLÜa’‚\ń+HµĆűíq™mĚqct•Łđ‰tHTý€´#>EP3žßs‹Ň raJ !úŇ!L˝Ńv(]p†gŃt.8Ă·Đ­ ŹxYÔ4}k]FhaZ7ĄC|¦˘Ý©üŰxŢS)¨őşŢ‰ZX*Ř ¬Sšd endstream endobj 309 0 obj << /Length 155 /Filter /FlateDecode >> stream xÚµÎ?AAđ•Wl2Ť#ŘdKÉó$¶P)D…RA¨9šŁ8‚ňběóĆóË|3ÍüĐz´8*ăqqďŕ!ćlK,ŹÝęfŤ!‚™ç+´ŔËůzS/§čŔ4¸qh·TQűŇy”~1}áÉ „3îĚMP u|žđf*ˇe´đŹz”7"ęČ…`–`_ÂâSt endstream endobj 310 0 obj << /Length 199 /Filter /FlateDecode >> stream xÚuϱ Â0€á”…[úz/ imŠu*Ô vtr'uŞč\ÍGé#těPŚÉE#.ßp—?"Ć 0ÁÁăă1îC8j ÚŃfw„¬ľF!€ĎŐx±ŔËůzž-§Ďqb°…"GĆ<)›o™×)Ű~ôŚŤ­o¬műĆ»mjĽŮVFf+ɇ­cělÝźđŻüöOľ2ĄđęĄÎ—”üVgvdMi5…”L?X:úpâęc=_˙Чn3°‚'äŻVO endstream endobj 311 0 obj << /Length 300 /Filter /FlateDecode >> stream xÚ]Đ?JÄ@đ¦"{¸3'0 ®› ë ¦ÖĘB¬ÔR˘°U’›x ËÜŔ#8ĺÁřŢäźIńżoŠóE«ÓŐZŠ&>Sç‘z Ĺ‹( Ďb›˙VEká_á«đ“kőöúţ$üíţB…Âß©»P÷"Ů)ŕÍ·é´$› Ł•NşšH’ňA?%®“A^ ŕ|‘6¤ď^ěŁ@Ĺ(.§: \= )ʛɠâĽWš‘ŞQY;ŕXývrĘšTfŔŠ©Š;Łč¬ČŔť‰Ł<Ö+fT ‡QR«‰÷Ş8ä‚vĘ™– Y±eKÍa¦ hd'ÚŇţI~¶:t'mi «ą ËŮŞ ť ń#‰JkšRBŢÔVËAn+q™ńéĄ™Ę endstream endobj 312 0 obj << /Length 266 /Filter /FlateDecode >> stream xÚmбN„@ŕ!$Óđ;/ ŔHlÜä<)L´˛0VjyĹ팷ŹĆŁđ”äpţ9L0@ľe†ef§./ëZr)6r±]VWňVđ«RŁąÔĹśzÝó¶áěIŞ’ł;ŤsÖÜËçÇ×;gۇŃ÷ť<’żpł"ŠO„ËO-“±.”4Đ7RD×Ę‘S4áEúYÚRŇzcéf‚ŇcĹ=¶T‰‡h\KΕ˙Hg:Ăd@ĹŻq č¸_eÂŃ\·‚o˙Śă Ó™“ÍŚšEc†¶Ľ@[ĆѵWđK›‡·†YŤ6'ť ĚPÇť˘ŐѶ’·‘›plЬ>ß6üČżmyä endstream endobj 313 0 obj << /Length 208 /Filter /FlateDecode >> stream xÚeÎ;Â0 ĐTĽôő H«*0V* Ń &ÄŚ ŰŁő(=BGÔ`‡O1$ĎN;f2Î2LĐĐš¤h¦xLá†ó„Sg(JĐ[4ô’NA—+Ľ]ď'ĐĹz†)č9îRLöPÎQŤ¬µĺ°jĄ˘Nĺ-ŃrÄ„T˙žD#ɉ~ –T?Bެ”„frOMPŐ¨sĐČ`ŕ;¤vôî)G˙/¤O7şrŤť$ňi%±O#É}jIĺŁ$ÖŁw{đĆÚç?°(a/5˙sR endstream endobj 314 0 obj << /Length 261 /Filter /FlateDecode >> stream xÚMĐAJĹ0Đ)]fa/đˇsm+¶"ďěBĐ• qőuéBQp×­Gɲü iś™hMIyM:™ĚdhOúsj錎Oič'Ďľa?đbKýEúłĹíÍő67ĽŚÍxKďź/ŘlﮨĂfGʵO8îĘceID``g&@ňY”â›ń95łü3çŘ•’#­Ë™śśĄđ “fW<@Ô ‚€EżÇs>‰(Rµ §’:$ÓV.Á»ąbăAű*3ÂJęËü´€ î«ĘsěJ´ŻÚ›?&ˇJI_B”´›)J—rí&| eŕýüDŻX‡×#ŢădŚ? endstream endobj 315 0 obj << /Length 255 /Filter /FlateDecode >> stream xÚeбJÄ@ŕ?¤Lqy1óš;ÉĺÄŔy‚)­,ÄJ--í‚ÉŁíŁäR®\g& wÚ|°ó'ěü[”‡ĺ1Ďąä#^Ľ<áÇ˝P±’ˇŚSňđLëšň[.V”_ĘňúŠß^ßź(__źłś7|·ŕů=ŐPą…aHÂ(fîăTĆČ AęŹÄ#{Ä˝š8=N¦ÝŻ™Ř#Ă_+ŃíÚAďžtjÖ›Ł4HĂ`~AWÓQ‚~,¨‚·@Ek˙ĄflF[bŰłî[ŞúĎ µ~”ö“-´˝(˝ŰN[¶NŁĎA/ńŁĽ†V—í­‹łťč˘¦ú?Fj¤ endstream endobj 316 0 obj << /Length 214 /Filter /FlateDecode >> stream xÚUϱjĂ@ `ZîB­'¨ă«S0ŇâˇĐNB§¤c )-tłÍŹâGđč!řz˛3HôńKh{~\.hN™ í)'—Ó)Ă+ş,ä9Çqs<ă¦Äô\†é>Ś1-_éçű÷ ÓÍŰ …é–áćË-ĎŐޱwzđ´¶L“Ô 73nb¤. fV÷ c†éF ÓI, —m%‰¦‘¬5µ¤Ň€Ä+I¤ąIbM/1šNb5Ó'ë1UŢó…Wŕ®Äwüݦpt endstream endobj 317 0 obj << /Length 293 /Filter /FlateDecode >> stream xÚeѱJÄ@ŕ [¶H^ °óšäđ.ąęŕ<Á‚WY•Z QěnßĚ ;źŔb!eŠpëÜn6âÚ}üĂ ?L=;^ž`e…G3$Î+Ľ+ů#Ż”8_ŽŁŰľnx~…Ő‚çç”óĽąŔç§—{žŻ/O±äůŻK,nxłAcúÔ¦µ:¨sŇń`§íő+ ŃŕÝEz’ňbż’^±ÓŽ^‰“ńŠHY ö&ˇ& ^T'¦{m „¤G©Q™PTjsŞIŇ‹ŞÔNę„Jś´W¤„Ę1)T(ˇÚ@ I{˝;e$ĺő!­ęIŻ >ÁŞť¤A|Yí˝Ŕ(ߡ$>€čĽR'úoŞ')«áʤU?‰öRD ~Öđ-˙:‰­T endstream endobj 318 0 obj << /Length 212 /Filter /FlateDecode >> stream xÚMÎ?ŠÂ@đoH1đš\@Č»€NbjŁŕş°)´˛+µ´P´ $`‘No°g‰7ń)S„dgFA›ď/ę÷˘}q7`ťÂo:PhŠ>‡Ăggł§iLjÉaDęG—IĹż|:žw¤¦ó/HÍx°ż¦xĆ@@6/ďcGÇÄP‰Âŕ”¨!×R^!Ş'“ĚâTH3=™âŤ,ŃšĹć×R;÷â…gąX˛Kž%Hs$h%Ƣuőg·+> stream xÚ]Îż ‚PđOîśĹGđĽ@]˙ éb`955DS5ˇöfö&>‚ă$»)5üÎđ}śĂńü‘Ë6+X8!CŠľˇ %jˇ•P¦f•˘¶J`Rôň˘Űţjµ×źć—­ůZzę FB”!Ě‚žĄ_©şC4KhEoçM> endstream endobj 320 0 obj << /Length 237 /Filter /FlateDecode >> stream xÚUαN„@ŕŮPLĂ#0/  ĽćHÎ3‘ÂD+ cĄ–íH ± Ó7đY0ľŹ@IAX˙ÝcClľbvćß?;9Î2Id#G©dą¬Oĺ!ĺg^ĺ&˛Ţ^îźxW˛ľ‘UÎúcÖ奼ľĽ=˛Ţ]ťIĘz/·©$w\î…ÔĚGď ~=ŃBç‰Oá \N nk˘m`Ş`Â\MčđŐdłG :5"ěŔ€šŐ»>fĆâ®g˘ä|w3±ăÇňŢŚT8Ú¦˘şĄŠLH[e"4űü 8 żĐ6IőÔź—|ͬÁkŢ endstream endobj 321 0 obj << /Length 193 /Filter /FlateDecode >> stream xÚmÎ=‚@ŕ!$ŻáĽ čňS $Љ&ZY+µ´Đh˛…‘ĺfx“=%-l,ľf&™LŹCö9áQŔQÂŃ„ť)LLčs›ý‰¦‰ ‡ ‰…‰IKľ^nGÓŐŚ9oöwTä ”€Ý×pź< ŃAZ-¤Ý@:ŇÔh˝M¦,ĂŃ™ňTYő(űÖPĂ zăőG÷ăßŘ IaévíÁU.R8Uk®čĎÍ ZÓ˘ B endstream endobj 322 0 obj << /Length 216 /Filter /FlateDecode >> stream xڕб Â@ Đ!‹? 4? ×Zµ¤­`A'qRGEˇC©~Z?ĹO¨[©&‡á\îA.ärI»ŰęôĐÄf›–¶Ý>n,Říҵ‰NŻĚ­w0 A.ĐvAN(2śâńpÚ‚ÎFh piˇą‚0@!D-%ŚŚđ\"ů¸ĹŤ¨Ţr"Ë®R\uęŠTÇP\(z>SaĽˇŘ§#|ˇsf’ĚC§˘ČuŞŠLçŻ1>|Sţ¶Á$^IÁk,b&â…rźńŐs\ ăćđ;ř]Ş endstream endobj 323 0 obj << /Length 236 /Filter /FlateDecode >> stream xÚEÎżJ1đY¶L“2/ Ů¸{şŔy‚[Z]!VzĄ…˘ ({űh_$ʰą"¬Î,»ÚüŠI曯^źťSE ťş5Žę=:|ĆzÉÓŠÍôôđ„›íŽę%Ú+žŁmŻéőĺmŹvssAí–îU÷Řn @đ‰ÉëE2 ĘȨ čž1˝JŕAE8čA‡b„räČßg|ŻFĆí‰Ă„äĚ dľ]Ą 2÷ŃG€d÷Ć3úKę–‚ú'Îč‘'BÇĄ„žx`:!s\ÁIź˛`~zNx /[ĽĹ_¨TdW endstream endobj 324 0 obj << /Length 229 /Filter /FlateDecode >> stream xÚUϱJÄ@Đ7¤^“ň~@găfa„ĹuSne!Vj)¬˘`•̧ĺS"ţ@Ę-ÂĆűFaťć0Üa.wŞłÓŞ’™,䤜NžJ~ĺąCřü÷ćń…W5Ű;™;¶×ŮÖ7ňţöńĚvu{)%۵ܗ2{ŕz-” DfJ ŁHźGş„"|„ZĄŃÖ¦ÁçŃÔ Ă›)ä€ň`ötfTvhĚ"Ă?|@‘×QZť×č¨VШó@0ă1ŘE–ŤÎă×¶-eý¶ŇŻnOć;`ëDŽhI|Uó†´éd" endstream endobj 325 0 obj << /Length 187 /Filter /FlateDecode >> stream xÚ…Í1 Â@ĐR,Lá^@Üą€nڦ˘‚)­,ÄJ-m5âĹâMö)Sq79€3ŻřĚ?ŠĂ<ć~ČQÂq̇.ě6µźý‰ŇŚô†Ł€ôžIgKľ]ďGŇéjĘ!éoCv”Í^a JH˸ěçř;%ü˘‡ŽB·‘Xś[O”ë ÔŽgUđ[ĄkM•4FF~ŚúęŐxçĘĎ•€ÓěBTđ hžŃš~; 9ő endstream endobj 326 0 obj << /Length 248 /Filter /FlateDecode >> stream xÚUαJÄ@ŕY¶Xâňr™ĐM.ŢA\8O0… •…X©Ą ˘íeĺ _ë|“XŮFlR,‰3…mľâ˙/Ę˝e4§Ýśög4/é6ÇG,r|đ{ąąÇe…ö’ŠÚSŽŃVgôüôr‡vy~L9Ú]ĺ”]cµ"Đ-€"ŔŚ4ÉČ6"ńn"ja ‰g\Ă´ ôę˝… ßĂ}abZvLŁşRČ´WÝ€î¸Wq‘ţćĎz=Ač…ćłă=AF­…Zp2ŹÇ¤>}Ýţ±áÄmĽ§˙1ľfxÔ‘0ťSč!9„¦TxRáţé^ń endstream endobj 327 0 obj << /Length 172 /Filter /FlateDecode >> stream xÚ}Ě1 Â@…á‹ŔćbćşŮ…č ‚#BĐĘB¬ÔRPQH!šŁĺ(9‚eŠÝٵľęđ”(E!Ť¨/I )ŇtxA©M )»eÂ8E±!©Q,LF‘.év˝QÄ«I m%…;Lżđ>?9›:Ŕ^ÖÓj¬šµśŠµť7óś’ůNÁ‚˙÷Ö=¨»Öj •‘Av†G ąĘç)®ń ®E‡ endstream endobj 328 0 obj << /Length 266 /Filter /FlateDecode >> stream xÚUĎAJÄ0ŕ?dQČÂ^`0ą€v:B[ˇLaÁ.]ąWęR¨˘ĐU'GËQ2x€‹É˘t|MUĆŐG^Â˙żdůéyŞć*W'©Ęçę,WO©xŮ‚†t,¦›Ç±ŞEr§˛…H®h,’úZ˝ż}<‹dusˇR‘¬Ő==z­Ĺ€Č!ň|ŻeŹŁ2ŽL»Äń˛ä[+1“-˙2R•c;“–íë¶2l ›IÓTšőAp©ÝfŇvŕî@tc[Ą§Ö čŮ˙ư`ć)ôĎaTzÄCY?›ôŁ´‰/C ÷EĺîPÚĚ5ˇ„Ű&„së~´ˇ„oŤ eźôs*ÁP%Äe-nĹ7ă7x` endstream endobj 329 0 obj << /Length 225 /Filter /FlateDecode >> stream xÚUϱjÂPŕ?ÜáÂâ 9/Pc0$Bjˇ;u(ťÚŽ…V2HĽŕ‹ĺQî#dtíąÉ`]ľáżç˙áĆÉ8ÉxÂ)?DĎxšňgDżGNxšő/ß4/)|ĺ8˘đYb Ëo7»/ çëKşä7éĽSądĎâ蓺řů@7=ćĘbTŞEV´žÓŠUŃ?âI4ť›öŕ´őMÔĐâÚç;žŘ@ę˝AŻęmQŤSuj#Síęő}7µ÷ÝČ~Ô9ěĚÜ`^ą©ŔBË× č©¤ú’tUž endstream endobj 330 0 obj << /Length 190 /Filter /FlateDecode >> stream xÚ=Îż ‚PđO„łÜGđĽ@]˙Aµ(AAM ŃTŤ Em˘B/foâ#ÜŃA´«BĂßóťŔ›;Ľâ™ËÇţ‚Ż.=Č÷tč°żś6—;Ĺ)É#űÉ­ŽI¦;~=ß7’ń~Í.É„O.;gJ Ŕě+Ż‚Ť92´Č =™ ˇĄY5"ˇŮŐ$*GE1Ŕ_ßkĐMŚAŰŽĚfb)­n!ę ˘Ęa—!"„şt¨5ľ}€6)č•GĎ endstream endobj 331 0 obj << /Length 238 /Filter /FlateDecode >> stream xÚ]ĎżNĂ0đ/Ęé!÷Ňš?"R)čÄ€ZF¤‚@ę€j?šyó=D ç¤$¶ôî|§Ďjr˘źĘ=.ĎYMxzÁ«’ŢH•]őlşo-_iVSńČŞ¤âNęTÔ÷üńţůBĹěᆥ:ç'z¦zÎČLfÜU¸ň›/ŕ2¸k`Ł­¸Ö&[~‡ÜŔő6bňÓůÝ‘T~4óĐ{ŹÚÎťh{“FRýD“öJÎĘČ*+oŁFt:‡^˶ńCŘĆf\8ŘŚ&‡†Ńôи%F–Ó¶öźt[Ó‚~JlÓ endstream endobj 332 0 obj << /Length 182 /Filter /FlateDecode >> stream xÚUÍ1 Â0ŕ_:˙`/PěMC”v(j3:9“: U:ÍŃz”ˇŁIÄ!Ë7Ľď‰é8âQL#NN"¦#Ç ˇĂDňkgĚ%˛- l©cdrE·ëý„,_ω#+h§‡ö( ňŻż ß0¬R‚GéC:k3•dŤ¦V™Ş4PÖ`  {@ű1Ľ˙€ˇgy9x–Ρoi|KăZ”Cf1Ź.$nđ ń˙> stream xÚ=ͱjÂ`ŕ2î’7hî čźäÇ6] fěÔˇtŇŽ…*:H|±é(V;Qű¬›X¶’¤\FjÓŰeý%E)ćM“TĚ‚k1ĺRvűO1Ĺjޱ™ľÇ}H9S Ü ÁąB†4řĹ7Z4^ë7^óŻć¬üđ;r<×˙ťŽĚȇ0Č)¤ ĘčŹz§»!ËB–e,; eáŁ__ß=FĘĽ”Wą|/Hd endstream endobj 334 0 obj << /Length 178 /Filter /FlateDecode >> stream xÚ]Ě1 Â@Đ )Óě„Ět“MBÄ…Á-­,ÄJ-+łGËQr„”Bt ńóŞ˙á«|Ť(˘śú1%Š2EűϨR.#Ę’ď˛;baP®IĄ(ç\Ł4 ş^n”ĹrJ1Ę’61E[4%o!¨Aü™u4§x@ŐuŚ/řňŘÓńYë¬qDówßűk;Ôp×pŇĐjh´WOü: ¬đm 83¸Â7ġB endstream endobj 335 0 obj << /Length 216 /Filter /FlateDecode >> stream xÚ5É1JÄ@†áo"đ;ÉMB˘™……uS,he!Vj)¬˘°•›xĄ9ĘaĘ)Bp’ŤÍSĽoÓ\^]sÉ-_TÜ´\·üZŃŐëK®őůĽĽÓ¶Łâ‘ë5w1SŃíůëóűŤŠíý WTěř©âň™ş##„M~!ÝJő‰Ë&Ň ­zĺt9FěaĆôąőąu‘Ţť"řYa€áĚ b&ÄőĎ9ă1¬ÄM¤‘J·°‘^-}´đ‰?źʰ9:o,”U ŰŽč;˘VF endstream endobj 336 0 obj << /Length 205 /Filter /FlateDecode >> stream xÚUÍ1jĂ@Đ/¶L!]ŔXsxµ^¶¬"W.B*'ĄÁ v+éh:ĘaKĆxl%4ţ†oÝlÎ9üdxaŘüa苬•2gëĆËţ@ËšôŽ­%˝‘štý§ďó'éĺë3Ň+~3śżS˝b$PT§h»$&wĘ;.CŐą Yw¬ţĐ ˇA ß †ż ¸HD†‘)Ô€ TřC‰8Ŕ!ö#Ç˙ř_˘^P=”WťĽÉDC)´ö­kÚŇ V˛Aš endstream endobj 337 0 obj << /Length 243 /Filter /FlateDecode >> stream xÚUĐżJÄ@đ/lÂĽ€¸óšÄäHŠóSge!Vj)DŃN.>Z:_ca;S„ŕ·Q9m~ łóŹ)ł“âT3­ô8Ż´,´¨ô>—')Śfş(ľîeÝHz­ĹBŇ Ć%m.őĺůőAŇőöLsI7z“kv+ÍFáQÁ¸‹Ř–Ú"qő Ißîé`{ż}w3ÁŐ ˘™á›fŔĆ˙aBě™»=ŃĚđ3ă ÓŤK·žM;tźÄ~®č±='sź.ěC˱ä |G ew´†UuĚ‚%s‘LáárŢČ•|–ob3 endstream endobj 338 0 obj << /Length 230 /Filter /FlateDecode >> stream xÚ]бJAŕ?l±0Í>ÂÎ čŢ%w'6 Ä^!he!Vjiˇhw_leáĘ+Bôż\&Ěň±ĚÂěĚÓó˘ĐL/őlŞEĄe©/ąĽË¬b2Óňb|y~“e-áAg•„¦%Ô·úůńő*aywĄą„•>ćš=I˝RŔôü–4žt®…I6ÂFáZ“ŕ€Ăt#ÍŔćŔ¤?ŔjvOG,I#¬“Ü1>ÂÇ-í k`Ť#ľŘްő ™ěčyßńŻ˝Dř}Ă‘çŰĂqç ž†÷ŕ~`[ uą®ĺ^ţš#g endstream endobj 339 0 obj << /Length 176 /Filter /FlateDecode >> stream xÚmÎ1 Â@Đ iô™¸ILŔTÁ-­,ÄJ-mMŽ–x…ÁŇB\'î6ć˙ćO“„BĘŘ(Ł4Ą]„'Ś»v±;¶,4ŞĹŞ·¨ôś.çëU±P„ޤuDáuI0vŽěŕ±ó[€>Ë™iÁ7 äw40`ÔV.ŔŞś›óv^–'žVOȬh/|5V ţĚW5cjSŤKü.[HG endstream endobj 340 0 obj << /Length 277 /Filter /FlateDecode >> stream xÚ-ʱJÄ@„gI±°…yąü/ Iî/Ĺaŕ<Á‚V"¨ĄE!Ĺá­řbkĺkě#l™â¸Ü˙G‹ýŠfvţbzZ”ŃśN¦TśQYŇSn^ͬb1Łrţç<ľecŇ;šU&˝b٤Í5˝ż}<›tysAąIWtźSö`šQě›ŘA;(yD– CőŽ‹5ŁjŐ]ĆhAŕG´ŃNůuÔ+7 śîŐŹÓA}Ů8¨o{ő‹Ä©=j‡5˙‹-?Č n˙_Ą˝Lłs'ć¨;†ŚĹąč‡›ăt†ˇ-"s—=⌝HfÁ…¨{.Üî]=đ1#衇WC€Çŕ `.skR@eÝ endstream endobj 341 0 obj << /Length 242 /Filter /FlateDecode >> stream xÚeĎÁjÂ@ŕÉ!0—Ľ@ŃyvM…˘`ĚA°'ŇSŰcˇ-<úby”ÜzMo9„lgĚÁJö[]fçŹ7qĚ!ßňő€ă”“„ź#z§a*Ĺ“´»yzĄiFvÍĂ”ěBĘdł%~l_ČNW÷‘ťń&âđ‘˛ĂFđsÔđ+ż‚ď\©äśĐ*µR˝+ş˙p§Ś.Ů)ogŽÂŹ6řţ*ÖT˙jČ)”h` ěarAÖá’ö?ćDžrěđ8xuG+iN‘ iJ!Pú…’ŁÂÂAm€˝‘|cy‹ľÎHníĐ<ŁúÔĐZ endstream endobj 345 0 obj << /Length 208 /Filter /FlateDecode >> stream xÚŤŹ; Â@†˙°``s!sMÂUŔBĐĘB¬ÔRPŃNbŽ–Łě,Să¬Xhgńóíü3łş×F˛ćNÔgłđ.˘ikCŽăĎÓö@Ł”‚ë‚™x Ň9_Î×=ŁĹĹNx-ˇ Ą†ŞżÎ‘)ă”8ŞJ×8•W¨7~®ŞÄ§Ľ–LxţIöÉX ‘ähř9Z~¦W í dďQöÜÜBîÜů‹ť&iHž‘¦/lm˝üĄ–ľÚ€¦)-éŇHN˛ endstream endobj 346 0 obj << /Length 221 /Filter /FlateDecode >> stream xÚUϱJÄ@ŕYpa ÓZ7/ {IŚ(ČEÎ;0… •…X©Ą ˘Ý‘ËŁĺQöRn!9˙ŢÂ×Ěěţ3›źź^¦:×LORÍ -Îô5•OÉ3çZcçĺ]–•řGÍ3ń·,‹ŻîôűëçMüňţFSń+}bĐłT+Ž\QM=`Čţ.If °`kCtŤý3Ü›íŘOZm°ťé\01iůt3(N‹í¨ä¤˛˙g7ť~Ü`O=ŮNcË–ąŽ3\‹Cpl:\ rĂÚîÓ u%ňoGĘ endstream endobj 347 0 obj << /Length 189 /Filter /FlateDecode >> stream xÚťŹ1 Â@E°Lˇ70sÝě ’@°ÜBĐĘB„€ZZ( 9ZŽ’#XZ:IV›t«ţ 3ďOĚŘÄrÄ#˛‰xjř¨éBşN%7nt8SjImYǤ–’“˛+ľ]ď'RézΚTĆ;ÍážlĆ@TđJô ř@ đhxÁ«jzeŤ/¨ š]aöĺŮáýÝ;żíÇÎAdDÉ/ťak+ÚÎ?i¶Ą”T“‚RSĘ"§…Ą }G«@ endstream endobj 348 0 obj << /Length 188 /Filter /FlateDecode >> stream xÚťŹ1 Â@Eż¤L/ :ĐÍ®A"EŚŕ‚VbĄ–‚Š‚…EŽ–ŁäÁÍ$±ĐNxŐĚgćýˇ1‡qß„l">hş.§!Ǧ^íO”XRÖcR 7'e—|»Ţʤ’ŐŚ5©”·šĂŮ”s Î@ t€h~//iąÝKxO`L®Đ“tIVăçßxĹ?üŢůĽ¨>ö‡©(=C±uÚ•ż/ń@ŞĹRÓr•iniMoEËBs endstream endobj 349 0 obj << /Length 104 /Filter /FlateDecode >> stream xÚ32Ö30W0P0WĐ52T02R03RH1ä*ä24Š(XCĄ’sąś<ąôĂ M¸ô=€â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ˙˙ü˙ó‡a0C ą\=ąą¶ h endstream endobj 350 0 obj << /Length 102 /Filter /FlateDecode >> stream xÚÍŽ;@PŐggÜwAí“x…„J!*” Âî%>‰EČt3ÍŘ00 •ľUjĚŘrR¬Đ豆iřĄqAć 5‚Tʇ¸šűv̬ɩ‚˝Ň pŻó:˝_ó˘thq_ţh endstream endobj 351 0 obj << /Length 130 /Filter /FlateDecode >> stream xÚ-ɱ Â0…á gđ 2ś'0ą-Ą™k3:9 TGAEçćŃňfÚ˘|Ű˙—ŐŇ7ôlXUÔŔ:đ˘x@='eý;ý m„;P=ÜfĚpqË×ó}…kw+*\ÇŁŇź;Zä“Fy2d›ĺĎd“L*R!s™ÉB¬ąËY°ŽŘă ,P#Ś endstream endobj 352 0 obj << /Length 131 /Filter /FlateDecode >> stream xÚ-É1 Â@EŃ?^á ¦xĐ™‰‰mŚŕ‚V"ŃRPŃ:ł´Ů™&Nwoľ\ř’ž%红V\ó¦xA=y1žö:Ŕť¨n×w¸°ççý˝ĂŐ‡ ®áYé/ ­tň‹˝4č’M22ÉDłÉT&2+•<ĺ*ŘńBŰ#´ endstream endobj 353 0 obj << /Length 94 /Filter /FlateDecode >> stream xÚ32Ö30W0PaCsK…C®B.K Ďȉ&çr9yré‡+Xré{€O_…’˘ŇT.}§gC.}…hCX.O†z†˙ 0XĎ ĂŔĺęÉČ[\w endstream endobj 354 0 obj << /Length 101 /Filter /FlateDecode >> stream xÚ32Ö30W0PaCsc3…C®B.K ×ĉ'çr9yré‡+Xré{ąô=}JŠJSąôťś ąô]˘  bą<]dęţ7Ŕ`= 1S—«'W fp"¸ endstream endobj 355 0 obj << /Length 94 /Filter /FlateDecode >> stream xÚMÉ=@PEáţ®â®ŔĽ™x¨ý$^!ˇR Ą‚°{ ŤäTß±4J2:*5ˇĹ4ĺ¬Ř`ö˘Ł˙Ć´"žfšűą@ň¶ BJJ7"”Ľď몀Đi ‹ endstream endobj 356 0 obj << /Length 90 /Filter /FlateDecode >> stream xÚ31Ô35R0B#C##c…C®B.C D"9—ËÉ“K?\ÁÄKßCÁKßÓWˇ¤¨4•Kß)ŔY(č˘ ÔËĺé˘đ $—«'W R endstream endobj 357 0 obj << /Length 119 /Filter /FlateDecode >> stream xÚ31Ô35R0P0´P01T06Q05QH1ä*ä24ŠĹŤˇRÉą\Nž\úá †¦\ú@q.}O_…’˘ŇT.}§gC.}…hCX.O ††Ś˙˙±˙á˙ ŔľˇŽáÆ.WO®@.Ϭ{ endstream endobj 358 0 obj << /Length 175 /Filter /FlateDecode >> stream xÚ3±Đ31Q0P0bScSK…C®B.SßÄ1’sąś<ąôĂL ąô=€˘\úžľ %EĄ©\úNÎ @Q…h ĘX.Oţ ę˙ł˙g``üÁ~żůűĆ˙üäŘ˙É?`°gŕ˙¤ęŕÔ őN}`o`üÁŔţ¤›™ÚÔřFŃ¢˘˙0°˙˙˙˙? Q\®ž\\ŕ  endstream endobj 359 0 obj << /Length 208 /Filter /FlateDecode >> stream xÚĺѱŠÂ@ŕ?¤Xf!ó·FHÄJđ"BĐĘâ¸J--îĐÖ|1}_aaËÁu=ÎŇÎeżŮýg›Mű]îp,+íqŇçeL?”&Ňwš¶ąX¬i“™sšË)™|›ßíŠĚpúÉ1™Śż$ůMyĆ€v¤Š3|-{Pé˝ÓeÓ!,¨„GpPghÁşFdPCWTíÓ-”k¦ˇCđj( ­g¸f"{ż!ÂŞý—Â[ďŹŢ—˙AŁśftŕůËC endstream endobj 360 0 obj << /Length 235 /Filter /FlateDecode >> stream xÚmĐÁj1ŕ é^=;OĐd-‘ő$¨…îAhO=”‚ĐöX¨ŇބͣíŁř{ô°N"¸Q6>fB&?™Nî'izŕmf4Őô™ăŤáZűŇ||ă˘DőJĆ zâ.ŞrMż»ż/T‹ç%ĺ¨Vô–“~ÇrEP@X×ěű8ő \˛˛IU{ó»ůÁ3ĚbĆYăĄ1Ezôč$ć'i=SË©†LÂB„p6Pu Ž–8ç:R†Ł ˛Ž÷›[4ß9޲áéí…ĂŽ&ÎČ&üZÚú'­ăXÎť®ÁÇ_đ%°mĽ endstream endobj 361 0 obj << /Length 209 /Filter /FlateDecode >> stream xÚ•±‚0†Ź0Üâ#pO`Amd3ALd0ŃÉÁ8©ŁFgúh< ŹŔČ@¨…«Ú´_®íÝýýe4ŤfĐÜ,ą ą¤k”µÓ„íĹĺŽqŠâH2@±5§(Ň˝žďŠxż¦EB§‚3¦ i3 €5C8ZA–›Ŕ/:LĘ^ŐÁ­űpšôXpžŰôkÚF¶­±bIF°Ü2ŐéqžËUśNĐC¨™E>Ş_…ń÷c‹đ+v·dŻóŻĺínÔâ&Ĺ~VźP endstream endobj 362 0 obj << /Length 260 /Filter /FlateDecode >> stream xڭѱJÄ@ŕ? LaZ áć4‰ÜŞ[-ś'BĐĘB¬ÔRPŃÖĚ›ř*ľ‰yË+Äuv˛g!–Bŕ#“ÍĚîżÎďúnŮńÎ;ÇÎóMG4÷Zlyż›ľ\ßѢ§ć‚çžš-SÓźňÓăó-5‹ł#Ö÷%_vÜ^Qżd RPDZT†¸R´öR ĘOÔµ ţ@ů*Ť(ŢAWEÁ],řR‚şIµRę5ú7P­Ń&?”2oĆ(~#FLŘŕgČü5=dF#ďzv˘L;mf–Ä&,—mXJ[°Ěa Ţ#ĺ }Rş:%e-vÁvS˝•Ô=U:îéśľšes– endstream endobj 363 0 obj << /Length 194 /Filter /FlateDecode >> stream xÚ33Ö31V0PaS Ss…C®B.S ßÄI$çr9yré‡+špé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţÁőBýc``üßD@.ý0Ĺ˙L1˙SŚŔĂ?UŹBŮ7@¨`JJ=SüPęŠýę (<öˇ9ĹńPŻ@=ómrüC%hACž  !@ y`> stream xÚuб Â0Đ  ·ôĽ/0­ µ‚ťDŞŁ˘łý4?Ĺ/iLsqŤđ’»INÍĆŞ ś&vŞ)©9ť Ľ˘‹ĺý¶O4¬4Ę©ĺĘFQę5ÝoŹ3Ęjł ­ioK¨k2ýč DŇŔ€§dFLƤ1’(­C8^Q€„ÉĆDđąďɰ|pĂ1ĆŰ˝Ó.ţ"bř˙yŇ€Ś)™gëşk¸×żŕRă?Uź’~ endstream endobj 365 0 obj << /Length 166 /Filter /FlateDecode >> stream xÚ35Ń3R0P0bSCSs…C®B.s ßÄI$çr9yré‡+sé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţŔd’ńü†˙ Ś`’ᬓ6`R‰äÁAňI68ÉŘ€L2`%™‘Hv0)"˙˙G'!âP5Čş‰ A€J$ă˙ `G@%ą\=ąąM˙x× endstream endobj 366 0 obj << /Length 254 /Filter /FlateDecode >> stream xڭѱJÄ@ŕ?l&ŹyM"&`µpž` A+ ±:--­7`ákMgé+ä ĽňŠăÖŮÍ& XšćKf’Íěż]{Üt\ó)ťp×p{Ć =SŠu¨ÄÎć‰V=U·ÜvT]j™ŞţŠ__Ţ©Z]źł>Żů®áúžú5đ(ü6S¬ßü`ŤŔ쑊-Ě— oŐ¶¸áÖëĄd‡ľŻ IľSňý03a‘™LlB".€żŃ!1ÍúOx˝&ÂpcÄJÂ&ĆHů‹¸Ł…¸Ű…„ťrI)ĄĚÜ” _ň,v0źšőů{lŘtéT–‰é˘§úî”Ű endstream endobj 367 0 obj << /Length 125 /Filter /FlateDecode >> stream xÚ33Ň3˛P0P0bSKSs…C®B.SS ßÄI$çr9yré‡+šré{Eąô=}JŠJSąôťś ąô]˘  bą<]ţ˙˙Ďř˙˙?TŠńó bü78) Ŕ¤Żs‘)hčb y.WO®@.!»Ą7 endstream endobj 368 0 obj << /Length 106 /Filter /FlateDecode >> stream xÚ3˛Ôł´T0P0aKSs…C®B.#3 ßÄI$çr9yré‡+™qé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţ˙˙†€ˇľačcWüĹĺęÉČ3v\‚ endstream endobj 369 0 obj << /Length 165 /Filter /FlateDecode >> stream xÚ31Ň33W0P0VĐ5R0¶T05WH1ä*ä26 (ZBd’sąś<ąôĂŚMąô=€Â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ö˙˙?@"ä˙000°˙â„=¨o˙`#ř?0üoő ü ä0X0Č`a°o`ŕŠ2°7Ăń˙ qő \®ž\\źÎ`¬ endstream endobj 370 0 obj << /Length 243 /Filter /FlateDecode >> stream xÚ]ŃÍJĂ@đYr̡ľ@ ű&A[sjsěÉxj= QôjöŃň(y„=HÇíĚ˙Đ”eöDzĚĚ~,Ż/•/üUŚeé7~_ňG‹8"ÇŤÝ;ŻÎźăšóť›G˙őůýĆůúéΗśoüKé‹Wn6^DČĹ8×I ęF"!˘:+2oa[8®7“`¦dÎ`+ŘÂÁÔôhLM‹fp &byiguf0«­~5Őżjźţ©RrŔyd* îŐőSkÜ_ ź¨ NÔÇ÷9LŐxoéá ˙ádÔ˙™‹„sůľá-˙5Š•P endstream endobj 371 0 obj << /Length 140 /Filter /FlateDecode >> stream xÚ35ÔłT0P0bKSs…C®B.S ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś ąô]˘  bą<]ţ˙˙˙€™dü€ţ3 eR/i& 0Č ň‚d“Ě`’LĘ?`üßŔđ˙Á@!ą\=ąąAfl÷ endstream endobj 372 0 obj << /Length 244 /Filter /FlateDecode >> stream xÚuŃ?kÂPđ{<0p˛ Ţ'đ%ś˙€ ur(Ávt°ÔŮ€«ę•]ÝĚGČč|˝¨X#yîřÝ=8. [~›< 8˘€:˝ű¸Ä°ËµW”ĹÇ|ýŐ”Â.Ş1wQĹĎôőąú@ŐŹjHŻ>yoÉŕçŁ1 Ă˝¸ 8hFăx‡]Ę*ń›1ć•řá8§ľyşŘTBź¤,a Pł —Ŕ“M ő2Ü< ś fepŇ\$ŔIÂÖ5+zŰG4÷V¸Y5D NZ@fWđí¤'c´ÔŇÇýoĘŔQŚü¦Â! endstream endobj 373 0 obj << /Length 243 /Filter /FlateDecode >> stream xÚUĐżJÄ@đ/.0…űfźŔMNÖ?ŤóSge!VjiˇhkRů\AKÁTÖ©$EŘuwöŠM1üřf`Šď`ą·<’…ÜwŁŹĄ>”w%=’Ö.>úĂí­jRWRkRçnKŞľĎO/÷¤V›SY’ZËëR7TŻĄµ@fŤµm óŔ¦‡íĽĹĎ0 ŕ{dľ¦ĂĽŰÎ=ő4]LŐ3ůȦ€aŇ@b·´liş@ĎT|`Ä“MLjbËŔľĹ4źLő“˙1ÂÄdtFŔśW$®Gś á*Ă.|×Ř™±ťŐtI˙6D†c endstream endobj 374 0 obj << /Length 239 /Filter /FlateDecode >> stream xÚ­‘±‚0†Ď8ÜÂ#ô^@D'ÔDťŚ“::htŤGáxWÚśmš~éÝßöú_LÂyŇxJsNgoô(ň»ĚéŠIŠîžÂÝ5‡ŃM7ô¸?/č&Űń~IźĽ#¦K¶ CµĄ ÔĽ*x1F%¨Ŕ)dBśĂč ń‘Š…¬ŞA«Ńź8çEĹjGîU…Ň(ßNkĽűČ4Ş,— ~ĐjÔ…}Á<ŰCż2[|Žţfa?­-ČŤÖžĆ3ë ń“­oŚ×śČľ}°]Ń=ÂUŠ;ü”K‰É endstream endobj 375 0 obj << /Length 167 /Filter /FlateDecode >> stream xÚ35Ó35T0P0bS#Ss…C®B.K ßÄI$çr9yré‡+Xré{Eąô=}JŠJSąôťś ąô]˘ĆÄryş(ü‚ ę„úĎŔŔřż,ĘŔ ˙LńSĚ? Ô0Ĺř™adŞT Y;ŞŃPű ¶CÝuP7ČŮ˙ŔÔ ™….ĵ—«'W ŽK€ż endstream endobj 376 0 obj << /Length 221 /Filter /FlateDecode >> stream xÚ•Ń˝ Â0đ–‚ě#x/ i*Uś ~€ťÄIťíŁů(}„ŽJăŮK Í"&…äHr˙t˘F*ÄÇ8 q˘0šâYÁ Č€f4ăĘé óäžę ×´ 2ŮŕăţĽ€śo¨@.ń 08B˛D­uĺĐ uf,HW§‚ ôĄlüfëç¬(şzĄeő§Ö~űüćަŹŘô§ą_Qš@™ńÍëő6Ň+L®6źńeĺlóZąš˙«›v,XżŐKéP~ď‡ŢEÔşeŻÖ©úN=â’ą«vđ™<›Â endstream endobj 377 0 obj << /Length 256 /Filter /FlateDecode >> stream xÚUϱNÄ0 ŕżĘ)Kˇ~h{=îÄB¤ăč€Ó @°!ZŢĚŹ‰čF%PŤsw ˛|Jě8¶ç‹Ăަ’ćt0ŁůŚŽŽé®rŹ®^j°¤EµËÜ>¸U㊠ŐKWśkŘÍ=?˝Ü»buyJz_ÓuEĺŤkÖ?€ĆŚ!ňÎf°l#>Ů3ZÎ;@Î'€ç7Ŕîx ďÉ&Ś&Č–Nm9R0—!ˇG/aEďFD+E$˝Ńڵ˛MX‰ż„^É>a‡-úĆü‘M˙čű=¦×:upÇ´–¤-µiŢ}őčGŚA§Š^{s¦ywÖ¸+÷=ź†# endstream endobj 378 0 obj << /Length 150 /Filter /FlateDecode >> stream xÚ3µÔł4W0P0bSsJ1ä*ä2ńÁ" Fr.—“'—~¸‚©1—ľP”KßÓWˇ¤¨4•Kß)ŔYÁKßE!ÚPÁ –ËÓEÁţ?<@Ł0˙g`ÇŔřŹůA büP˘>€©T*L`Ą€)‹`J+ŦF ĹţżHĘ‚Ťârőä äWÎr° endstream endobj 379 0 obj << /Length 191 /Filter /FlateDecode >> stream xÚĺĐ= Â@ŕŃÖBČ\@7‰¬ĆJđL!he!Vj)¨h«9šGÉ,SëlĹ3X,ßňfâu˘VsŔmnFlzlşĽ é@ĆH¸¤¬w4HH/Ř҉I'S>Ď[ŇŮCŇ#^†¬(±µĘ>ńl \3X~ZPCAůŹ©J'BEH?4€ţ—şôuâ7{©-'żROrď%ËxşVÝ™‹Ă·ąCŮ ď qBszŘxaş endstream endobj 380 0 obj << /Length 240 /Filter /FlateDecode >> stream xÚmĐ1jĂ0Ćńg1> stream xÚuŃ1KÄ0ŕW „ăşv8ČűÚôÎbť ç vtrá@ť˙…?'â)Îť¤Cąř’ŁâMHřH^ÂK^Yě/Pá÷ćX.°8ÄŰ\> stream xÚÍαJAŕYČÁL›"y÷.p1©bŻL•BAS¦P´Î=’ŹpʞŹ2EČ8»n@ô,†ofg٧“ËÉŚK®´¦×WüRŃ+ŐsťË8ĆĹó– ą5×sr·zJ®ąă÷·Ź ąĹý5Wä–ü 7©Y˛Č đ~k%…öŇvěT˛Z^{ÓcÝŮł ÷ĂâôU«oŤ˛CŐ0Ë–*¤ĹSTB¶‹ú`ζŃńŢ&‡í%‹ăE¶ź´§QŇČ0›b4č3ľÝe}÷żÍ˙ô"Ý_馡}Čl® endstream endobj 383 0 obj << /Length 232 /Filter /FlateDecode >> stream xÚUĐ1JÄ@Ćń/¤Ľ&GŘw“@B,ÄuSZY ¨Ą ˘`—-GŮ#liv|ß‹ÜŔü`fČź™iĘ“¶ÖRu«M«Ď•ĽK]ŮĽä”OŻ˛î¤¸Óş’âĘVĄč®őóăëEŠőÍ…ÚęFďí—é6˘}8rB˛G‘š˛ ç g@ţăîp ¬vřÂoűŃđDšD,ZŚN€Çŕ±E‹Ń- ®Ĺ-FIâ2vpŽeDZdřÓbt¤˝k±Ůt`ĚÜÓÔel6óXĆË"÷ó­üdÁí=yŮ<"ú»ýW.;ą•_µštó endstream endobj 384 0 obj << /Length 204 /Filter /FlateDecode >> stream xÚmĚ; Â@ŕ . ´Vf. ›Ť´1ŕL!he!Vjiˇ(X›Łĺ({„”Á8룗ĺř‡ůÝéĹQ—Úš’ş}Úi<"ĎČĹ÷f{ŔQ†jĹ{T3ŽQes:ź.{TŁĹ4Ş ­5EĚ&ˇ€ş6äüĄ…°%/_x÷/PAP02gřýÁ0Ҧ–yp&îî¬dBw›:Ś+0đÁüâ}¨ATľyóMŢ6Ó˘5lö–˘.Ë5˛Ŕi†K|¤řTŁ endstream endobj 385 0 obj << /Length 198 /Filter /FlateDecode >> stream xÚ31Ó34V0P0RĐ5T01V0µPH1ä*ä21PASKLr.—“'—~¸‚‰—ľPKßÓWˇ¤¨4•Kß)ŔYÁKßE!ÚPÁ –ËÓEůĂT‚D0Sť$ę00|`ÇŔüąAľů;˙ć ě˙ĺ00ţ* ŕÄ?8Q"ęI&ęPMĘřbŰ˝`Ëßśq ä ă ň ĚŤęţ˙:]ţ—«'W ČckA endstream endobj 386 0 obj << /Length 182 /Filter /FlateDecode >> stream xÚŤÎA ‚`ŕ'?( ‘ś ”ýüşĚ A­ZD«jXÔ.ĚŁyŹŕŇ…Tcu€ßć Ź7f: 5ŹŮđPł™° ř éL¦ %ż—ý‰â”ü MţBbňÓ%_/·#ůńjĆ’&Ľ•ÎŽŇ„ˇZŔ{ČUe5ČTŤĆ©¬Ö-Ő‡W¨6ęŔj@-ĐÉĹóOůŻÓ‰;*`{ú^‰ž[bŕTd7“ý w§”§ÍSZÓ»= endstream endobj 387 0 obj << /Length 198 /Filter /FlateDecode >> stream xÚ31Ó34V0P0VĐ5T01Q0µPH1ä*ä21PASKLr.—“'—~¸‚‰—ľPKßÓWˇ¤¨4•Kß)ŔYÁKßE!ÚPÁ –ËÓE˙ó‚ÁţT‚zó !˙HÔ±÷`řÁřţó†ú쀶¤ „|P±=i«‡u âÉDŞ)öph‘<„ÚkrF=ČAď?0ţ`<˙ꎆ˝˙?ü?ţ˙ ě@‡sązrroXhI endstream endobj 388 0 obj << /Length 189 /Filter /FlateDecode >> stream xÚ]Î1 Â@Đ\B/ 8ĐM˛(ÚЦ´˛+µT´“čŃr”!ĺbI qáÁ23ü;čŤö9änŔ¶ĎvČű€ÎdC)úlGUgw¤IBfÍ6$3—2™dÁ×Ëí@f˛śr@&ćŤm)‰Úť¸·2Ď©\^ˇsϵ2¸Î÷ŻHĹřQ‰RńţQÖOţř—Ö5ÉQŃJrµěhč MťŁíÂá„TĺrŹLĽ@ł„Vô˝Ł@ endstream endobj 389 0 obj << /Length 141 /Filter /FlateDecode >> stream xÚ32Ő36W0P0bcSK…C®B.# ĚI$çr9yré‡+Ypé{Eąô=}JŠJSąôťś ąô]˘*cą<]ę˙70đ|Ŕ ßţ€Áž˙C˙`ĆĚ00Š˙˙˙Çäč§3˙a`¨˙˙Žą\=ąą˘&[ endstream endobj 390 0 obj << /Length 237 /Filter /FlateDecode >> stream xÚŤŹżJ1Ćż00…ń v^@ł9ďäŠĂ…ó·´˛+µT´[¸}´> stream xÚ31Ó34V0P0bS …C®B.C ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś€˘. Ń@-±\ž. Ě€ŕ?É&™iN‚ěaţ`˙D~°’Č700nŕ?ŔŔüťDţ“ŘŔČä‡$Ů€‚ë˙˙˙˙7 “\®ž\\y endstream endobj 392 0 obj << /Length 122 /Filter /FlateDecode >> stream xÚ32Ö30W0P0aCS3…C®B.C ßÄI$çr9yré‡+Zpé{Eąô=}JŠJSąôťś ąô]˘  bą<]ř0Č@A@ 8~Ŕüá? ±q©ŽŘ0ü˙‚¸\=ąą(CE` endstream endobj 393 0 obj << /Length 150 /Filter /FlateDecode >> stream xÚ32Ő36W0PĐ5QĐ54W0´P05SH1ä*ä22 (Ăä’sąś<ąôĂŚ ąô=€\úžľ %EĄ©\úNÎ @Q…h ®X.OĆ ěř   P?`üÁđ†Ř€¸ôE6Ś?ęügüđź‚üc?PĂ~Ŕ†ź˙ó.WO®@.˙§Wő endstream endobj 394 0 obj << /Length 196 /Filter /FlateDecode >> stream xÚµÍ1 Â@Đ•ir3'pŤ.#BĐĘB¬ÔRPQ°ÍŃrʱ0EČ:? ędŮł3ó7čuÂ.{Śô¸ňʧăH‰ĆrCqJzĆGz$ݤÓ1öÇ5éx2`źtÂsź˝Ą […RĘüâë?´LőŤşćÝ3Ř‚ćrÁĘkm‚¨„;xÔÂ3ęH†Kv¤Ř@%Żâ.ęýoÔ nn—**ŚÉŤů@Ă”¦ôDr endstream endobj 395 0 obj << /Length 108 /Filter /FlateDecode >> stream xÚ32Ö30W0P0aCS …C®B.C ßÄI$çr9yré‡+Zpé{Eąô=}JŠJSąôťś ąô]˘  bą<]?0ü‡!ţ ̱˙`ř˙˙qązrrĆ‚Q. endstream endobj 396 0 obj << /Length 177 /Filter /FlateDecode >> stream xÚ3łÔ3R0Pa3scs…C®B.3 ßÄI$çr9yré‡+™pé{Eąô=}JŠJSąôťś ąô]˘  bą<]?đ`Ŕđ˙ý†ú@ú=ă:†˙Č77Ř3đnŕ?Î ßŔüť˙ţÇŔD˙a`˙ÁŔN˙``˙€ŤţŔŔţ`Đ O€â˙˙˙˙7˙˙ŹNsązrr#ß endstream endobj 397 0 obj << /Length 147 /Filter /FlateDecode >> stream xÚ31Ó34V0P0bcs…C®B.C ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś€˘. Ń@-±\ž. Ěř?00ü˙`˙D~°’Č70đnŕ?ŔŔüťDţ“ŘŔČä‡$Ů0˝ń˙˙Á˙˙I.WO®@.‡e% endstream endobj 398 0 obj << /Length 188 /Filter /FlateDecode >> stream xÚŤŽ1‚@Eżˇ ™†#0Đe6 &na˘•…±RK Ťv9Gá”Tâd)H¬ĚN^fţîţů‘žĚ¦đ”ÇšŁ€Ă9ź5Ý(ŚE”qŃßś®”R{cRk‘I™ ?îĎ ©l»dM*çćŕH&g8^W‰S­śQdHŕVđá•Rľ ň!J*¨- Ŕi~ nNű/†oońkg»Íîő$AéÖHĺŠ> éáwlzZÚŃIKÚ endstream endobj 399 0 obj << /Length 196 /Filter /FlateDecode >> stream xڝα Â@ ŕH†Bˇy˝ž­uj;:9“::(şÚ>ZĄŹp"ŘŠç]qĐQ |CB’?Šű2ä€Ü“1G!‡#ŢI:R°«ařm”d$V$f¶O"›óůtŮ“H–$R^K6”ĄŚĘŻŔ¨\ąUW0÷Â/Ľş%>Á«°T¨5*č´4hy~“˙Ě÷ö˛Ąý¦Ýß> stream xÚ36Ň35R0PacCcs…C®B.# ßÄI$çr9yré‡+Ypé{Eąô=}JŠJSąôťś ąô]˘  bą<]ŘČ3üPŕ˙ĂÇţ?n˙Ŕ˙śýó3 ~Äo0˙ah`ţÁŔ€‚?PłÍü˙˙sązrrjŮF„ endstream endobj 401 0 obj << /Length 195 /Filter /FlateDecode >> stream xÚ=αJÄ@ŕ¶XfßŔĚ x{›`TńSwŐ‡•Z * WîŁíŁÄĘ6`“"8Î%GŠŹ™ů˙fŠ|q~ĆK.ř4pˇó‚˝R^j¨çĺÔ<> stream xÚ36Ň3˛T0P0TĐ5T0˛P05TH1ä*ä22 (Ad’sąś<ąôÌ̸ô=€Â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž.  Ř W á Ś@Ě Äě@,˙˙?Ă(f„ĘQ „ţ0‚pC sC3=;˙?°f.WO®@.uH– endstream endobj 403 0 obj << /Length 153 /Filter /FlateDecode >> stream xÚ31Ó34V0P0RĐ5T01Q06WH1ä*ä21 ([@d’sąś<ąôĂL ąô=€Â\úžľ %EĄ©\úNÎ @Q…h žX.Oć ěţ`üŹJň`Ŕ‘p’şŤBţ`°ŔŔđˇüÆç˙왏Iů˙í@’ůĐ.WO®@.1c endstream endobj 404 0 obj << /Length 183 /Filter /FlateDecode >> stream xÚU̱ ‚PĆń#‘k[çęŞWJ'Á rjj ¨Ć†˘¶űh>ŠŹ`›Ph—ş—jů ˙ľ@ Bź\ň©ďQŕ“ŇÎĂ#ŠHE—ÄčłldČ—$"äS•‘g3:ź.{äÉ|Lň”VąkĚRj×_ś śŇ.Á.X ,g0i)ŕ <ˇĄ©ˇp¶&†®A†=éjś|c(v‘kŘ]ţb=ŔĐ(ÔżáúO¨ÁI† |FŁ?ę endstream endobj 405 0 obj << /Length 233 /Filter /FlateDecode >> stream xÚUÎ=KĂPĹńs Xxłv(ćůzËíËb ­`A' ÖQ|A7©‘|±€Đ~ŤLťďx‡`Ľ7UÓN?8gů«áá°Ď!ńAÄjŔÝĎ"z$Ąěr·ż~nîh”ĽdĄHžÚ™drĆĎO/·$GçcŽHNř*âđš’ WUPń÷6ľAß´4ćđŠ5ą§q ‘ţ" bxŘ%âtÇqżÁ_ů®cůGŲh;˛š÷L€ Ëtč5Â<ţfúOk…2·|âµÁ+ń–ZlECÝdŃ ±ď(°çÂŃIBôĄY_™ endstream endobj 406 0 obj << /Length 210 /Filter /FlateDecode >> stream xÚMν Â@ đ)(ˇ«Đ> stream xÚUÎÁjÂ@ŕYi® Î čn˛Ző$¨sÚSE¨GÁ˝‰ćŃöQ|„x ‰ł˛Iéĺ;üĂüü=ÝF¤(˘N8 ^DúŤÖ!ţ qިŻÝiµĹIŚň‹ôĺśs”ń‚öż‡ ĘÉÇ”B”3úI-1žQY¦ăâŹŕAćgŕ//7śŽ4gËZŽvŞ*Ě 0‰ĂżŠ+ă]S‡¸CEÉ@QsüϰFŐě,IŤqSn/Ľ'¶’gCţbź^m‘mjg`ç1řă'>ÚźKř endstream endobj 408 0 obj << /Length 183 /Filter /FlateDecode >> stream xÚ%Î1 Â@„á‘@„‡$|'0‰+AA˘‚)­,D¨Ą ˘ťŹćQ<‚eŠ`śŤĹ_ěě·°&î# µÇL_M¬‡H.běÚŁ˝Řź$I%ب‰$Xp• ]ęíz?J¬¦Ęu¦[>ŮI:ÓIU•uO§Ă)Fh~đß!;Łó:cňĚŰዬQÖ‘‚ôź˙)H˙ĺpIëH]R·YŔ#őH[¤mé(ś˛âl2Oe-?uŕC endstream endobj 409 0 obj << /Length 188 /Filter /FlateDecode >> stream xÚµ1 Â@EH!L“#d. ›ÍşŤBŚ` A+ ±RK EÁBb޶GÉR¦R×l´6Ż˙ţPtĚ+îǬƬ5$ťIi;ŚXŹÜf˘$#±aĄI,ěD¶äëĺv$‘¬f,I¤Ľ•í(K~ |[äjż„W˘‚opGĎŕ ŔÄ!´—S‹˘E¦ /‹ňčzů´ĚOľ6x+Ó¸YŰ~ĺŐÎÜuĐ´ńí…ć­éÂŐ`ú endstream endobj 410 0 obj << /Length 121 /Filter /FlateDecode >> stream xÚ31Ô35R0P0bc3SS…C®B.# ßÄI$çr9yré‡+Ypé{Eąô=}JŠJSąôťś ąô]˘  bą<]0001;Ëń˙ ˙aX*6T°ý†ú˙˙?Ŕ0—«'W ľťNÚ endstream endobj 411 0 obj << /Length 228 /Filter /FlateDecode >> stream xÚmαJÄ@ĆńoŮ"0M^ป'p÷WóSZY ¨Ą ˘`eňh>JáĘ+ŽŚóé5‚E~°;˙Y˛¬Źšc­té_^iÓčC-/’łź+9¸’u'éZs–tî·’ş }{}”´ľ<ŐZŇFoj­nĄŰ(Ę-€~‚Ů€8¶#J^ÎQě0CÜc…0áůîČDĚ_úźžÓÁďř:ßsöNüaçü™r$_΂[-> łŔ,°, %‡s„'älĎ"łČĚńĄ™aAZŇ›M°żČY'Wň Tźc| endstream endobj 412 0 obj << /Length 235 /Filter /FlateDecode >> stream xÚuĐ1NÄ0ЉRXšß`3', ZiY$R AE¨€ ´ŘGóQr„”[¬0Ľ„‰"OĘŚóÇ“ăîČ/Ą•^—Ňź‰÷ňŘń+÷ĹVüÉľóđĚëÝ­ôžÝ%Ęě†+yűxb·ľ>—ŽÝFî:iďyŘ™-­2Č9QµµŐ EëPőE6‚f¤LÍôV»&‘ĆŕđĚÔb&e6‚€§Ńf“őŐŽó‘ňY (yâ/ifU ý°Ĺ_ cBüÔ¨M>Ő‹ý‚¸ź™°yĄ˙€‚޵¸2_ |ĂßÇ›jh endstream endobj 413 0 obj << /Length 188 /Filter /FlateDecode >> stream xڕν Â@ đ+ At-('đ®¶µťkotrˇP?ÁQđĹ_ÄÇč čý‹­łů‘äIŕőĂ+FŠĂ!Ż=Ú“™ş,ń‘o)Ń$ěG$'¦KROůt8oH&ł{$S^z¬V¤SBĢ⊠ŘŔ©ičA«äf°1ë€h‚.p;»Áö`ŻZ  \2đoóŠß›˙Ây™ł54Ö4§ňý`ö endstream endobj 414 0 obj << /Length 226 /Filter /FlateDecode >> stream xÚ•ĎżjAđďnaÜ Î ˝s=b!j W¦J!‚`R ěnÍGąG°´8ÜĚśEH:›_1;ödĎyźSpŻĎnČyÎźíÉ9)¦śżÜ_6[šd?Ř9˛oR&[Ěůđ}ü";YL9#;ăeĆ銊ÇŔŚÇćҺ„ĐpQ*Ĺ+j .+xsş7á”xÄ•‘Íç–Üđ‘\ }µrÓţ† ”żř´•R ţ/:tK­¬uéîNTc¨'ŰĽ‰ŤÄ'ňˇjěiT”2®DĄ×‚Ţé+XŃ endstream endobj 415 0 obj << /Length 243 /Filter /FlateDecode >> stream xÚmŹ˝JÄ@…OŘ"p›ĽÁÎ}ťdłÚXW0… •… j)¨hëäŃň(ó)S„ĎD…m>†{çüÜuuěVZj­G+­ĎÔ9}ŞäMjÇa©îägóř"›VěťÖNěÇbŰkýx˙|»ąąĐJěVď+-¤Ý*Đô@ ŹP„sŽşř‚&ľłľ[ D>#E@˘Ç†rIő~2ű> stream xڕα Â@ ŕHÁB}ŃĽ€Ţ]ő¤“…Ş`A'uŞ(¸ŮGóQî|šTZčŕŕ‘ű†?$w#3°i˛ÔhdČŽéhđ‚CË!Çá·s8cś ÚĐТZpŚ*YŇíz?ˇŠWS2¨f´5¤wĚHźPQžç®ÎëY’ 4aĐ:B@Ă ¸Ç8 ‚—1ľěn -ˇSQĽüRá-8­đ d“_Ń®Ó+ČJ˘_<˙!’Żtůâ<Á5~lúQ- endstream endobj 417 0 obj << /Length 265 /Filter /FlateDecode >> stream xÚMŹÁJĂ@EoĹŔ[8ĐĽĐ$ŤA„ŇB­`B]ąWęŇ…˘ĐEÁů´ů” ;#Ç›*ÖÍyóî{wćÎquÔLµÔZ§ZźjÓč}%OR7KmN~&wʞlĄ¸Öş‘₲íĄľ<ż>H±\źi%ĹJo*-oĄ])L OÄ[ Ŕ`;d1ëa¶°3X`LpŔM6{ä{xÖSĎś°Hpžî|tOĄ0Ł1lą6Ě ůi4ČţÓ,ěŔe3zŤźÓáw™ťgRŇô¦SĹß@v伕+ů˙cĺ endstream endobj 418 0 obj << /Length 237 /Filter /FlateDecode >> stream xÚuĎ1NÄ0бRDšĆ@ň\ślÖBT––E"T ¶¤AKr®â›ě!eŠ3ł šgiŹ˙_×'aE5tĽ˘ćŚB Çź± 2¬(śÎ_žpÓ˘żĄ& ż”1úöŠ^_Ţvč7×çTŁßŇ]MŐ=¶[‚b—….'0SÉ2*(ŮŚ`&p ŢÁőBě!Ît çĽŕŇđ_čÝ_čRĄc§Ř™%Éž 6{6Cń!I¬c“Ä)A×ô?€Ö«ĚÁ“ôXZ1IÁŘËN+éOVë”ůŔäqY‰-Ţŕú m9 endstream endobj 423 0 obj << /Length 178 /Filter /FlateDecode >> stream xÚuŽ1 Â@Eż¤¦Éś čîFc“@Ś` A+ ±RK E;‘=ZŽâ,S:ٵ^5÷ż?ŚŃ5Íý„Ł ŹŢ:‘IĺŞ9Ž~ŃîHEEjÍ&%5—;©jÁ—óő@ŞXNŮ*ycXo©*EXŁW#·řot şO„—Ř–-pwÜ/Góźú—ţW†_Źď”rQHt"u;@fČÉKłŠVôÇ/9- endstream endobj 424 0 obj << /Length 173 /Filter /FlateDecode >> stream xÚuŽ1 Â@EżX¦ń™ čîFÓb·´˛Vj)¨hk<ÚĹ#XZq˛‹ĄđŞů3óţ8%SÖśń0ă$ĺIĆ{Cg2ą 5§IHvG*-© ›śÔBƤ쒯—ŰTąš±!UqmXoÉV|Zŕ4@á;DOD/ôßčµ>»{ O,<:×ý!¤a3\Ĺż?ágŰ)D$:‘ŠZ 4ľŚhĄÍ-­é ¦ 6« endstream endobj 425 0 obj << /Length 102 /Filter /FlateDecode >> stream xÚ36Ő32W0P0QĐ5W06TĐ5TH1ä*ä22 (A$’sąś<ąôÌ̸ô=€„§ŻBIQi*—ľS€ł‚!—ľ‹B´ˇ‚A,—§‹Bý˙˙ ˙˙˙?€ŚAb\®ž\\&” endstream endobj 426 0 obj << /Length 157 /Filter /FlateDecode >> stream xÚ36Ő32W0P0Q0S06T06UH1ä*ä22Š(Y‚%’sąś<ąôÌ̸ô=€˘\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. r `,Ąˇ¸@ŽąˇFŽżáźśüúyő ő˙˙7Č˙˙ÇŔţ˙ă˙ ő `ĉäAę@ęAú@ú‘ÍC6źËŐ“+ ňç2· endstream endobj 427 0 obj << /Length 120 /Filter /FlateDecode >> stream xÚ36Ő32W0P04RеT02Q°TH1ä*ä24 …- 2Éą\Nž\úá ††\ú@q.}O_…’˘ŇT.}§g ¨‹B4PS,—§‹‚<}Cýúh˙@ţ;ň?PßđźáÆ.WO®@.]Ä#Ú endstream endobj 428 0 obj << /Length 108 /Filter /FlateDecode >> stream xÚ36Ő32W0P0W02R0˛P01RH1ä*ä22PA#¨Lr.—“'—~8P€KßLzú*”•¦ré;8+ré»(D*Äryş(T0>řĂüá;ąřQ ó 2`8ŔĺęÉČqv6 endstream endobj 429 0 obj << /Length 158 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bcc#…C®B.crAÉą\Nž\úá Ć\ú@Q.}O_…’˘ŇT.}§gC.}…hCX.Oţ `,˙Ű|ŔÄ5?¸˘‚áG fü`‡‚™?Ř30?‡ŕ˙˙Áý˙˙8>ŔßŔÁ,®˙`˙ă˙ű?0 âsązrr'¸Ră endstream endobj 430 0 obj << /Length 161 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bc#C…C®B.#K ßÄI$çr9yré‡+Yré{Eąô=}JŠJSąôťś€|…hCX.O…˙˙?0ü˙˙˙pŕoŕŔßŔÄĚř±`83TŤü~ > f๷±šńż ‰ĂĚä´„@ÝtÓ.WO®@.K”eL endstream endobj 431 0 obj << /Length 190 /Filter /FlateDecode >> stream xÚŤŽ=Â0 …]uäĄGŔ€´iÝ"•"Ń &ÄŚ ŘPéŃz”!#H…ŕđł#ëüě÷ět8P#Š)Ą~B©˘LŃ6ÁŞśĹ˛ô3Ů챨P.Iĺ(§,٬ft:žw(‹ů”%­Š×X•‘1 ďÜĂÎŮť¶WŻotZ ˇ˝B`ë/Ó€çöż]öAÍ^źáó´‡ó{­GľkDÇťs ˙ŕžš"8©p/ł.S‚ endstream endobj 432 0 obj << /Length 160 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bc#C…C®B.crAÉą\Nž\úá Ć\ú@Q.}O_…’˘ŇT.}§g ßE!¨2–ËÓEˇţ˙†˙˙˙ń? ţĎP˙˙ýţy fÁĚřAř2ţÄ5Db$} s@ć1C1Čţ {AöÜqĎű¸\=ąą XS endstream endobj 433 0 obj << /Length 131 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bcC…C®B.cC ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś€|…h –X.O…˙˙˙âČż.b¶âţ˙#ËŐ3 c ¶Ă†ö˙Cø\=ąąM«\( endstream endobj 434 0 obj << /Length 188 /Filter /FlateDecode >> stream xÚuα Â@ ŕĂA–>ÂĺôÚ^űP+x “8©Ł˘[±}´óMň âr`ˇöZč&áË@ţčŮ4žSH1M"Ňš’N^Q‡ä+ŃýćxÁĚ Ú‘Q­Ú1*ł¦űíqF•mˇĘiQx@“Č—…ňĂĐ4> stream xÚ36Ő32W0P0bcC…C®B.#c ĚI$çr9yré‡+sé{Eąô=}JŠJSąôťś€|…hCX.O…˙˙˙!#†Ú!4»¸\=ąąí >| endstream endobj 436 0 obj << /Length 113 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bccC…C®B.crAÉą\Nž\úá Ć\ú@Q.}O_…’˘ŇT.}§g ßE!ÚPÁ –ËÓEˇţĂ˙˙ âł 9®Á…ë˙˙˙ó ů?¸\=ąąf*Há endstream endobj 437 0 obj << /Length 144 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bcC…C®B.c# ßÄI$çr9yré‡+qé{Eąô=}JŠJSąôťś€|…h ĘX.O…˙ Ś˙Ář3Ë=`Ż€ăür| 2r66,cQ!'WÁ|Ěţ™@0AŚěćrőä ä ZM endstream endobj 438 0 obj << /Length 165 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bccC…C®B.crAÉą\Nž\úá Ć\ú@Q.}O_…’˘ŇT.}§g ßE!ÚPÁ –ËÓEˇţ€üŹ˙ě˙üÁőäđ0ă ¶€b(–b9(ćb~$ĚŢŚŔ̇„C0†âb(®bk0®`ŕ˙y(ćňů¸\=ąą{Sq endstream endobj 439 0 obj << /Length 150 /Filter /FlateDecode >> stream xÚ36Ő32W0P0QĐ5T06T01RH1ä*ä22 …Ť!2Éą\Nž\úá Ff\ú@a.}O_…’˘ŇT.}§gC.}…hCX.Oć˙ř˙˙a˙˙ŹÁţ˙0®o¨o¨co¨aŕă? ü~0°ÓĚa] {AöĂÜrČ} wrązrrÖW]U endstream endobj 440 0 obj << /Length 187 /Filter /FlateDecode >> stream xÚ}Ě1Â0 PŁ•Ľôř¦iĹTŠD$02€`N6F®Ôp8BÇ!NŐ–'Ůßţ*'ŠIŇH’Ę(•txFĄÜ2¦4é’ý óņ”B±pkĺ’®—ŰEľš‘DQĐVRĽĂ˛ m+k¦e,€f"ŁŤcX9"&|;‚_řÔßůţő--óéGŁ™©Żg˘˙Ü™‡éy]G/c›ĐzŔ6]\?@8/qŤ_…] endstream endobj 441 0 obj << /Length 204 /Filter /FlateDecode >> stream xÚMÎ1jĂ@ĐoT¦Ń4HVZÉŘÝ‚ă@Tâ*EH•¤4ŘÁncA.¶GäJçBhň­4. †ĎTó[żĐB+˝)µňZ{}/e/~ɰкú߼meŐ{Vż÷ŔX\ó¨‡ĎㇸŐÓť–âÖúRjń*ÍZaßmb?15‹9:EB#ň8 ›ś'éd@ŇľčDˇr2ë‘Ú€™Ť— ĺ9PÖ)%ýĹłţ|…}“‘7Ć[ëB4ţA0vý˛s:Č}#ů2b endstream endobj 442 0 obj << /Length 144 /Filter /FlateDecode >> stream xÚ36Ő32W0P0TĐ5T06Q01TH1ä*ä26 (Ad’sąś<ąôĂŚŤ¸ô=€Â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ˙Č˙GÇü ŚhŽ01űćě ř˙XäŹýĆ˙˙ţ˙g`¨˙ÇŔ ˙ý—«'W îm[{ endstream endobj 443 0 obj << /Length 158 /Filter /FlateDecode >> stream xÚ36Ő32W0P0TĐ5T06Q01TH1ä*ä26 (Ad’sąś<ąôĂŚŤ¸ô=€Â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. őř˙ý˙Ŕ˙†A|ţĆ Ě~€ů2Fĺńţ•ĚđCž×ءb»–«@Ĺň?ř? 0ű0ćrőä ä‰ëJ endstream endobj 444 0 obj << /Length 168 /Filter /FlateDecode >> stream xÚ-Ě˝ Â0đá–>Bî LŰPÄ)P+AĐÉAśÔŃAŃ9çÓů>‚c‡óR~p˙;ŰΚ9Vhł›žk¸­ĄŻr›§+tĚm f-S0~Źűó¦Ű.Q¦=ääľÇ “*ůŁ4ĘqI9báH+MjT ¦ 3•B‹đ-)Č.ţ #-µ¦ü%Ľ$Ăs’|šň;©°ň°‚tI¨ endstream endobj 445 0 obj << /Length 171 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bccC…C®B.cßÄ1’sąś<ąôĂŚ ąô=€˘\úžľ %EĄ©\úNÎ @ľ‹B4Pe,—§‹Â˙†˙P1;>|đűń˙ ě÷˙`˙˙˙`˙Ç˙ýóöŚŘ0@đ†:(¶Ă‚ë€jęŔę>€0PH˙?ţ`ó@ćŢ˙ßŔ~ţ?só.WO®@.eTú endstream endobj 446 0 obj << /Length 162 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bcC#K…C®B.#ßÄ1’sąś<ąôĂŚLąô=€˘\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. öţ˙a`ţ˙źůXţA=}C=C=C˙âX0L®Ž¨‡¨SľÁţ€|ü‡z°yě˙˙ÍŞř´Ëţ—«'W ű7 endstream endobj 447 0 obj << /Length 172 /Filter /FlateDecode >> stream xÚuŚ-Â0Ç»L<ł#은®ërÉ $ H,ťăZĎqŤ9Žbiy]0$ ~â˙©GĂ|ŚćŚ.°P¸Sp­XgA†`{€Ę€\ˇV gě‚4s<ź.{Őb‚¬k\ód¦F!|ĂĐ7˙ŘEţA±Râ=ĄÖSŮ”dEJW‘ôtÜ Ľ~Đőyň馼+yo©lű?ÇżŽ˙]äďNŘŘÁÔŔŢ”L[ endstream endobj 448 0 obj << /Length 170 /Filter /FlateDecode >> stream xÚ]ڱ Â0E_éxK?!ď LÓ"Ĺ)P+AĐÉAśÔŃAѵͧĺSň ŽŠĎDśÎpďąÜz>«*©NhŞtÖxĂoW¦Ä銭Eµ§ŞAµŽ-*»ˇÇýyAŐn—¤QutĐTŃvĆđ9O ˇ`vň58ă¤7PřD"Dů?ŔôهĚăD0A9J˙|üuż†¸’peq‡ť.L° endstream endobj 449 0 obj << /Length 143 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bcC…C®B.° ’HÎĺrňäŇW02çŇ÷Šré{ú*”•¦ré;8+ů. ц ±\ž. ő Ś˙0°˙ŔŔÄň@lů0ر`°c`@Ćő˙˙7ü˙˙˙ řčj(Áö˙˙ě€cźËŐ“+ üĺ@„ endstream endobj 450 0 obj << /Length 144 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bcC…C®B.c# ßÄI$çr9yré‡+qé{Eąô=}JŠJSąôťś€|…h ĘX.O…˙ ˙ bv|řŕöă˙Řď˙o`˙˙˙˙ăŔţýűćěđŇń˙ň˙˙˙łGÂň˙ą\=ąą<¦[ˇ endstream endobj 451 0 obj << /Length 119 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bcC#…C®B.# ßÄI$çr9yré‡+™pé{Eąô=}JŠJSąôťś ąô]˘  bą<],ţˇ" ¨˙Ăđ˙ŐŐŘ‘‰ę˙˙ű@6—«'W wŚ2„ endstream endobj 452 0 obj << /Length 144 /Filter /FlateDecode >> stream xÚ36Ő32W0P0VĐ54U02U01RH1ä*ä22Š(šCĄ’sąś<ąôĂŚ ąô=€â\úžľ %EĄ©\úNÎ @Q…h ¦X.O† Ě?PP0˙˙Ŕţ˙1˙Şˇ büaÁřنůĂ? âđ˙?¨˙Ď`˙Ź˙—«'W \ęOé endstream endobj 453 0 obj << /Length 112 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bc#C…C®B.° ’HÎĺrňäŇW02çŇ÷Šré{ú*”•¦ré;8+ů. ц ±\ž. ő˙ţ˙Gŕz f8\˙˙˙˙˙˙?€aźËŐ“+ Ϩ0m endstream endobj 454 0 obj << /Length 148 /Filter /FlateDecode >> stream xÚ36Ő32W0PĐ5Ćf F– )†\…\@¦ą`™ä\.'O.ýp .} 0—ľ§ŻBIQi*—ľS€ł‚!—ľ‹B4Pe,—§‹Bť<ă†˙őÇ˙0ü˙˙ţř˙ʎH2đ?ü'ĎŔđ8đ‡źżáŚ`ř@˘ţń?ű˙?˙·˙€ Ŕb\®ž\\ăcMa endstream endobj 455 0 obj << /Length 137 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bc#K…C®B.c# ßÄI$çr9yré‡+qé{Eąô=}JŠJSąôťś ąô]˘*cą<]ţ7ţařü?Ă˙ű˙ţ˙˙„Ů˙ń?`˙Áţ€ýóöHřéř˙?ů˙˙˙Ů#aů˙\®ž\\ňśR_ endstream endobj 456 0 obj << /Length 165 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bcC#K…C®B.#3 ßÄI$çr9yré‡+™qé{Eąô=}JŠJSąôťś ąô]˘  bą<]ě˙?``ţ˙ý˙ţ˙äüc°o¨g°cg¨co¨aŕořĂŔŕ;V ’a:z{ ˇ ýň˙Í™ 2dČ>.WO®@.‘€=D endstream endobj 457 0 obj << /Length 178 /Filter /FlateDecode >> stream xÚ36Ő32W0P0TĐ54U06V0˛TH1ä*ä26Š(@Ą’sąś<ąôĂŚ ąô=€â\úžľ %EĄ©\úNÎ @Q…h ¦X.O…˙Ťţ˙Ďđ˙ţ˙˙˙˙ÄŘ˙ń˙`˙Áüýăö |€ˇŠí°ŕ: š:°ş ÔŇ˙Ź˙;Č< ąě÷˙7°ź˙ĎŔ~řP=Qř˙?LĚĺęÉČ–Ę^s endstream endobj 458 0 obj << /Length 142 /Filter /FlateDecode >> stream xÚŤĚ; AĐŽ+ń }ç‡éş‚‘(+ŤGó(Á°ÁaŰ1”âŐ FC?fËľý„÷'Ë5ĄÖÇî&¬9XyąÂÄwç˦YNŮÁ´Ľql·-§çࡒDEłľ4'ŐL*ĹýJz#R"ę?ňůOŞsÚŐŽYÄ o"ĺG endstream endobj 459 0 obj << /Length 160 /Filter /FlateDecode >> stream xÚ‹1 Â@D*á7ą€7ŮÄĆ@Śŕ‚VbĄ–BmMâá> stream xÚ36Ő32W0P0bc 2WH1ä*䋹 ‰ä\.'O.ýp#s.} (—ľ§ŻBIQi*—ľS€ł‚!—ľ‹B´ˇ‚A,—§‹CĂܸţ˙˙†˙˙˙€aźzěńĂćpü‡ů0ü“?´„ě˙10đ˙a``˙ŔŔĺęÉČB•J( endstream endobj 461 0 obj << /Length 127 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bc#K…C®B.c# ßÄI$çr9yré‡+qé{Eąô=}JŠJSąôťś ąô]˘*cą<]ţ7Ôř ţ2f?ŔL!fbţěě°˙˙˙źŠţţĎ`đ?—«'W nNŕ endstream endobj 462 0 obj << /Length 155 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bcc#K…C®B.crAÉą\Nž\úá Ć\ú@Q.}O_…’˘ŇT.}§gC.}…hCX.O…˙ě˙ cţöě Px€żů??g`| Áě>Ř@đŹ†Š ®ůÁŔ`ó‚íXţó```o`ŕrőä ä®; endstream endobj 463 0 obj << /Length 170 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bcc#K…C®B.crAÉą\Nž\úá Ć\ú@Q.}O_…’˘ŇT.}§gC.}…hCX.O…úőţ˙@@źůă†5 ?j>00Ř?``bţ@ÜŔŔŔŢaÄlب¦˘‚áC X/ă9ćň őěA¦ţaźËŐ“+ uŐFó endstream endobj 464 0 obj << /Length 183 /Filter /FlateDecode >> stream xÚ]ĚÁ ‚@ŕ‘Âň t^ vu•DÁ ÚCP§Ń©:}4ĹGđčA¨]-Šľ~Ś˝ qňhä$yS:¸xAÁI—ďżOű&نG¶P{drI·ëý,YÍČE–ŇÖ%ľC™ŇłŽŰfa–JץĄQiµ đŃ„Ů[}ŮgĄ*VŐ3µňGŃł4čD@®bóŕŃŞ©5±ŠqŞţç×řşOD) endstream endobj 465 0 obj << /Length 167 /Filter /FlateDecode >> stream xÚMŚ1 Â@EżX¦É2'p“ ˘©b·´˛+µT´ ÄŁĺ(9–Së›o†?Źůůt˘gś˛äšuÁ§Śnvú»˝8^¨´¤v!“ZőÓ®ůqžI•›g¤*ŢgśČVlĽwŤ÷2¤Fěj$] ÓÎŃĽŚŢŔX€Čq$-`‚j|ţ:\cI:i!áS|čú--mé 9Mâ endstream endobj 466 0 obj << /Length 131 /Filter /FlateDecode >> stream xÚ36Ő32W0P0bc#…C®B.#c ĚI$çr9yré‡+sé{Eąô=}JŠJSąôťś ąô]˘  bą<]$ljŔčăć? ěę˙0ü‡ †šŠQý˙?ő˙˙ÁĐ.WO®@. ;6Ö endstream endobj 467 0 obj << /Length 209 /Filter /FlateDecode >> stream xÚMαJAŕ?\qaš}„ť0{·1ÝBŚŕ‚VbĄ–жą_lÁąGH“âĽqbRČđ5˙ŔüÓś/âWÜđYÍMäeäçšŢ(®,¬xŮ7OŻ´n)Üs\Q¸¶B{Ăďź/Ö·—\SŘđCÍŐ#µFĘ€ ÝŁÔ N~čúdÓÁç-\žPăÉĹü7žlQ'ťI9‰W»'ĄţHˇ;~ ćĹ»sä˛7©÷}‡ĆÔOH_FGxűËé`żőM]µtGżźN^- endstream endobj 471 0 obj << /Length 114 /Filter /FlateDecode >> stream xÚ36Đ31Q0P0b#Scc…C®B.C ßÄI$çr9yré‡+Zpé{Eąô=}JŠJSąôťś ąô]˘  bą<]00>``Ŕđ˙ĂO0›ZůĂ˙˙€ËŐ“+ °V4q endstream endobj 472 0 obj << /Length 171 /Filter /FlateDecode >> stream xÚɱ Â0ŕ+ ?…®Dţ'0iZĐM¨ ftrˇ Ž‚Š‚CÁ>ZĄŹĐ1C 6ÂwĂÝĺrZ,ŮGÍ8Ďů’Ń”şôŐ畚ĕ"±VzËŻçűJ˘Ü-9#±âcĆňDzĹEäšqŇʰ«‚ľ‚10öŻţ –°đŚô;„-˘ 0ćŔč´qŘÄ#¤1Ň陯3ÎőZkÚÓg‚6T endstream endobj 473 0 obj << /Length 170 /Filter /FlateDecode >> stream xÚ-Ë1 Â0ĆńŻt{˝€”wMŇtč”B­`A'utP:ĎÖŁô3j‚Âoxü?ž–Ë> stream xÚMŚ1 Â@D˙'`ࣽ…Â?»›ÝB+!Fp A«b!j)¨čr4o2ŢŔÄ$X8Ľ)fĆŰIjŐ7ΦꞜÜ$k;ŰĆv8^$ŹbJÍ‚UÓŠ‰k}Üźg1ůfˇNLˇ;§v/±P"w$ ´cf :€Ţ ¸BR!eô}Ć1dXĆ•FÝé÷óOňˇyÝ Ë([ů=í9÷ endstream endobj 475 0 obj << /Length 166 /Filter /FlateDecode >> stream xÚUÉ˝ Â0@á wr,(Í}Í/č\ě čä ‚ Ž‚ŠB‡}´>J!c&cPá›Î1rl-I˛4R¤'d ťŢPë%ű=Ç –Š-iŤb™2ŠjEŹűóŚ˘\ĎHˇÓN‘Üc5§>Č‚yŹŹ-ÁŔC˙RL«× ™ËÁçęŹ&‘ĐÔĐ„źÚC8€ż27e®ČÚ, €‹ 7řÔë21 endstream endobj 476 0 obj << /Length 171 /Filter /FlateDecode >> stream xÚ=̱ ‚PĹń# ·¸6Čí{ş^u¸ĂťĚ ‡ ¦†hŞĆ ˘ŔAĐŢĚGń‹ÂşżéŕDÁ(Ž9ŕ‡ŠCÍQÄ[EG ?Ńćř»lö”d$—Ć$§6“Ěf|>]v$“ůÉ”WŠ5e)Ă«Q¶N«{u߭ڇB đˇ `@n•őýŐ<޶î`žÖ żüÇ@X>Ś€öppŻŤó˛˙ IF zË1/ endstream endobj 477 0 obj << /Length 156 /Filter /FlateDecode >> stream xÚ36Đ31Q0P0QĐ5T0˛T06QH1ä*ä2 (›Bd’sąś<ąôĂŚL¸ô=€Â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž.  6 ö˙˙Qý˙ő˙˙$0Č$0X$0`xp€áăćv6>0˛Ł ú€@ŚŘĂ.WO®@.}Ń/Š endstream endobj 481 0 obj << /Length 99 /Filter /FlateDecode >> stream xÚ31Ö3µT0P04F †† )†\…\@Ú$l‘IÎĺrňäŇ pé{€IO_…’˘ŇT.}§g ßE!¨'–ËÓEAžÁľˇţŔ˙0XŔľAžËŐ“+ ‰;“ endstream endobj 482 0 obj << /Length 157 /Filter /FlateDecode >> stream xÚ31Ö3µT0P0UĐ5W0¶T0µPH1ä*ä26 (™Bd’sąś<ąôĂŚŤąô=€Â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ě@ĚŔß#äÁHĚDŘ:Q'ţ€@Ě&> f0ńd82î>3Ń dfâ ¸™˘Dpązrr@Ä:Ő endstream endobj 483 0 obj << /Length 107 /Filter /FlateDecode >> stream xÚ31Ö3µT0P04F Ćf )†\…\††@ľ –IÎĺrňäŇW04äŇ÷ sé{ú*”•¦ré;8+E]˘zbą<]äěęüőěäđě:¸\=ąą{-= endstream endobj 484 0 obj << /Length 191 /Filter /FlateDecode >> stream xÚmĚ= Â@ŕ Óx„ť¸ ‰‚Ő‚?` A+ ±RK E[“›™Łä)S,;Îh%Xěűfćůh<Ą” }ĺ:exĹ\łTż:8^pV˘ÝQ>E»’mą¦űíqF;ŰĚ)C» }FéËEÜ$ s­´ŕXB×^H”Č©ÁĂ@ž?|Źbe¨®źŕzY©E—â˙đTZ_Őq×-`öRĹ!a~…„®K<.KÜâj/\ endstream endobj 485 0 obj << /Length 193 /Filter /FlateDecode >> stream xڕα‚@ ŕ’.<} L— &Ţ`˘“qRGŤ®â›áŁřŚ—;[pqÓᾤ˝´ý 5)+ĘHń+•9ís<ˇ’^&Ą|ěŽXLפ*LçÜĹÔ,črľ0­—S⺡MNŮMC±€Ä  ˙$z1Ú1Ţwxď!"Ëűâ>ô<ćôZ™iá&łN°?â>cíH ăRa¸ĘÉHŽ'c Ë:ÇŃ´m™¸O,Î ®đ —şYK endstream endobj 486 0 obj << /Length 201 /Filter /FlateDecode >> stream xÚmޱŠÂPEď’âÁ4ů„ĚěK¬® ›BĐĘB¬Ôr‹mM>í}ĘűËâě}VĚ™;Üą“úł™i©“ÔĄÖS=Tň'uĂů9&a˙+óNüFëFü·â»ĄžO—ŁřůęK+ń ÝVZî¤[(˛€ÂĐŰ f#2ł;ÜJ>ÂPD´Cv@Z }•„‹÷c˝C  ¤7¸ľĐ'Đ* 4u‘ö.ć7úąmp Ěb2rćcŔňÝÉZţI÷_ţ endstream endobj 487 0 obj << /Length 154 /Filter /FlateDecode >> stream xÚ31Ö3µT0P0asSC…C®B.cßÄ1’sąś<ąôĂŚŤąô=€˘\úžľ %EĄ©\úNÎ @ľ‹B´ˇ‚A,—§‹˙ű@â˙Ć˙˙Aűźz ńHđ?°*;&pő˙˙˙š4A€ĹđkŁa˙˙˙[~ `1.WO®@.ňĹ^Ł endstream endobj 488 0 obj << /Length 253 /Filter /FlateDecode >> stream xÚ}ʱJÄ@†˙#E`š}!óšÄä”k.pž` A+ ±RK E»#›ÎÇđUň(y„”[,g‚Ť˛ěǰó˙˙ĚÖŐÉzĂźňqąáşâęśźJzĄş`;ëłźÖă íZĘď¸.(żŇwĘŰk~űx¦|wsÁ%ĺ{ľ/ąx vĎ’€4¸lnfxYé•DdöItÁ§S¶n\Ĺ#7@efd=ş`’El6X4jB*˛`„éáľfŔ}EŹ_éh0‡íb•ôj“1SLÍ€,xÝ>v*‹Ĺ!*:MĂö–Ƣó˝:ť˛?-y‰%ۧF‚Í@—-ÝŇ7ăč‚> endstream endobj 489 0 obj << /Length 161 /Filter /FlateDecode >> stream xÚ31Ö3µT0P0bcSC…C®B.ßÄ1’sąś<ąôĂL ąô=€˘\úžľ %EĄ©\úNÎ @ľ‹B4Pe,—§‹Bý ř˙ť¬“Ś‘ň@dý ůó˙? ůű˙ ůB~°o’äAdü ÉŔ$˙É?Häz“ő˙ťř˙˙Ç˙˙I8—«'W zú endstream endobj 490 0 obj << /Length 132 /Filter /FlateDecode >> stream xÚ31Ö3µT0P0bcKS#…C®B.cC ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś€˘. Ń@-±\ž. ě ň ŘţĂÄ@ňx@ý˙@ü€á?×C1;}pý˙˙ţ˙˙˙†A|.WO®@.üŘO) endstream endobj 491 0 obj << /Length 115 /Filter /FlateDecode >> stream xÚ31Ö3µT0P0b e¨bČUČeläą ‰ä\.'O.ýpc.} (—ľ§ŻBIQi*—ľS€łď˘m¨`Ëĺé˘P˙˙Ă˙˙‰zÁŔ<Śú˙˙˙7ń˙,ĆĺęÉČî{\W endstream endobj 492 0 obj << /Length 171 /Filter /FlateDecode >> stream xÚ˝Š= Â@…·[&GČ\@7!Q°1#¸… •…X©Ą…˘ő^,7đć[n±ě8šÎČŹ÷WĂŃ3ä‚r„Ĺ9śAl&’ř]ö'¨-Ť\Ŕ,¤c—x˝ÜŽ`ęŐ s0 nĺąŰ =śî=Cężbq䙣Ň1 SĄe¬”ö‰K•vI'ě’ö‡mr˙/)Tžňě8R`ßűľ‡ą…5ĽízfĘ endstream endobj 493 0 obj << /Length 155 /Filter /FlateDecode >> stream xÚ31Ö3µT0P0bcc3…C®B.ßÄ1’sąś<ąôĂL ąô=€˘\úžľ %EĄ©\úNÎ @Q…h ĘX.O…úňţ˙¨˙$ţ˙$˙˙ĎŔP˙D2ţ˙`ß$ČČů@’Hţ“Čô&ë˙?:ń˙˙Ź˙˙7 “q.WO®@.‹Łll endstream endobj 494 0 obj << /Length 183 /Filter /FlateDecode >> stream xÚ}Ž=‚@…‡XLĂvNŕBL¬H·0ŃĘÂX©Ą…F[ŮŁíQ8Ą…a†‚Îb^2ď}ą™KJ)*%ł K†w4÷Ň‹ó +‹ú@¦@˝á)j»ĄçăuE]íV”ˇ®éQzB[Ä_PĄ ˘:…đá9o’.ęAµ@9(ˇdq%ź»7@â'aʏý/=ßµÓGĂ.^¬ÄTyhĆ ‰”pÁ A!\\[Üă>ťP: endstream endobj 495 0 obj << /Length 200 /Filter /FlateDecode >> stream xÚĄŹ= Â@…g°¦ń™ čfI"¦üSZY•ZZ(ښͣä[.(w“€–‚S|Ĺć˝7q4HRYs_Ź8Ö ů éL‘WCNâvµ?Ń$#µá(%µp:©lÉ×ËíHj˛š˛&5ă­ćpGŮŚs” V,ČS*7;(& A‰]t,ľŕ -Ŕ•ÇýGTÎŔťµ@Ű8×=ÓF–>Ľ®á ˇŻ†ľ$ÚńĽË_ČĄ÷ŞůF­Ń<Ł5˝ŢŻě endstream endobj 496 0 obj << /Length 158 /Filter /FlateDecode >> stream xÚ­É1 Â@ĐźJř—đźŔÝuŁÄj!Fp A+ ±RKAEëőh9JĽAĘÁqc!Ú[Ě™Ií`4-ĂÔËŢđ™m»îjw쎜{Vk±«y\Yů…\/·«|9ĂŞŤ˝e_Hx’+5ĐCôŃ8´äÂ#‚$ŇRC®ˇąš\őˇě¸˙B˙"¨żxo<óĽâőőIw endstream endobj 497 0 obj << /Length 155 /Filter /FlateDecode >> stream xÚ31Ö3µT0P0bc 3…C®B.cS ßÄI$çr9yré‡+›ré{Eąô=}JŠJSąôťś ąô]˘  bą<]ä€Ŕž˘ţ˙˙˙ @üżA€ĹH2…‚ů`€ťhŕŔ ß €AţAý~ [@ó˙ Ś˙€LxŔŔĺęÉČţ:B„ endstream endobj 498 0 obj << /Length 186 /Filter /FlateDecode >> stream xÚ5Í= Â0ŔńW:oéúN`úĄĐĹB­`A'qRGE7©…^Ě­×č ęء4ľŘ”É? ‰Âé,&ŹžQ@áśÎ>Ţ0ÔÍÓ[}pşb*Qě)ŚQ¬ą˘zÜźévI>ŠŚ>yG”˝•Ą:ĹôJ•^ý›]S |Á-,ZHZX:Č^<rś[CÂ×Á准’qĘz¤b&Őg¤aě¦QŚĄŔ˝†żŔ•Äţ$›Lă endstream endobj 499 0 obj << /Length 202 /Filter /FlateDecode >> stream xÚEŚ; ÂPEoH!LăśřŁ‚UŔBĐĘB¬ÔŇBŃN!…۲łt î@Ë!ăL@,ŢaćĚ»·µ{¸ŁŻŰá¨ĎŰ™ lµĂfOÄܒŁą©ZrÉŚOÇóŽÜp>âÜW!kJĆ‹/źLnRüQ;”Hˇ(Ô+€Řű­Üp{ÍçhĽŻ€/ O ¨.†ęçę«oźk> ą¶´¬4¶ú…Ą4Wč¬&F&ž”™äRŠ˘Ş§ÚŃ$ˇ}¨xY& endstream endobj 503 0 obj << /Length 102 /Filter /FlateDecode >> stream xÚ32Ó35V0P0b#CCc…C®B.C ’HÎĺrňäŇňąô=Ŕ¤§ŻBIQi*—ľS€ł‚!—ľ‹B´ˇ‚A,—§‹ýúőţ˙€AĎţ—«'W !‘$‡ endstream endobj 504 0 obj << /Length 111 /Filter /FlateDecode >> stream xÚ32Ó35V0P0b#Ccs…C®B.C ’HÎĺrňäŇW04ćŇ÷Šré{ú*”•¦ré;8+ré»(D*Äryş(đ7Ř?¨˙P˙á˙ńěđ70`¸ŐsązrrD7„ endstream endobj 505 0 obj << /Length 138 /Filter /FlateDecode >> stream xÚ35×31V0PaScSs…C®B.K ßÄI$çr9yré‡+Xré{Eąô=}JŠJSąôťś ąô]˘  bą<]ţVЎţĂ0¤ŘRüPŠ %ŹBŮŁPőę?b„PĚŠ˙Ş˙Ý˙8(.WO®@.‹† endstream endobj 506 0 obj << /Length 264 /Filter /FlateDecode >> stream xÚ…˝NÄ0 Ç]1Dňropő @ZµU™t`b81#ćô xĄlŚĽB$€Ž7śbě´Bb"Š~±ěż?â¶?é;ިˇăş§¶§ć”j|ƶoE]·„îźp3 ˝Ą¶A{)~´Ă˝ľĽ=˘Ý\źSŤvK»šŞ;¶rJ“€xţâP0ów4Éđ{\í .c9ŘNř]˙”"Ź˙ßYąpŇ&Zm­¬mĄ1¬÷BĎ`­XëX Ď2ÝĚ1Ď2s–PŞ)ŁÖ—ŕH˛ťr”Á€—LĄ5ř1ýŇýáUĄ—Wôš[$ťÜtUňÝ’ŚáYņ'ĽđrÔ endstream endobj 507 0 obj << /Length 122 /Filter /FlateDecode >> stream xÚ32Ó35V0Pa#SSK…C®B.#C ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś€˘. Ń@-±\ž. ŚŘ˙0đ˙!ů˙("”ŞÁţ3Ô#!ö˙ ĚÔF˙˙˙€#.WO®@.ťNq endstream endobj 508 0 obj << /Length 151 /Filter /FlateDecode >> stream xÚ35Ö30U0P0bS#cs…C®B. ßÄI$çr9yré‡+Xpé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţ1Ô`ř˙Źů˙ É˙˙”gţ$m˙7°˙«’Ě˙>0É˙ţ`ţ‰l@"ü˙˙Źý˙˙$—«'W Žá‰ endstream endobj 509 0 obj << /Length 187 /Filter /FlateDecode >> stream xÚ%Ś= ÂP„7¤¶ńŮ„‡Ć.ŕBĐĘB¬ÔŇBQ°“Ły”á•[„ŚűHńÁÎĚθb2+$Š+ä’óť]n: 2ç/*NârN7ćrZmĺůx]9]ě–bîJŽV9qµ*ý> stream xÚ36×34Q0P0bc#Sc…C®B.#K ßÄI$çr9yré‡+Yré{Eąô=}JŠJSąôťś ąô]˘  bą<]ř0°<¶‡âz ţÁŚ@ĚÄň˙˙?řŹ„™bTÂđĆ˙ ˙7~`řřý˙@Ç400˙cŕrőä äÎpR endstream endobj 511 0 obj << /Length 122 /Filter /FlateDecode >> stream xÚ31×37U0P0bCS…C®B.cc ßÄI$çr9yré‡+sé{Eąô=}JŠJSąôťś ąô]˘  bą<]ä€ŔDübvQ$ţ˙G%úAüè˙˙˙ÁĺęÉČB•\ endstream endobj 512 0 obj << /Length 188 /Filter /FlateDecode >> stream xڕϱ Â@ ŕ– Yú6O`[ĽŇĄT¨ĽAĐÉAśÔŃAQčP°ŹÖGé#tt«—Ştň $áB˘ÓyšpÄ :áDó%¦;éŘ摤Ň8ߨ0XÇnl•BłĺçăuĄ°Ř­ŘVK>Ú/'2%;ŽăµÇŔ%|ĂAtG*čA0‡¬`/şPu°˝Fô19€9¬a{ŃíDíŞb#úŘj3XĂä5SŻřS… imhO_o`Ť{ endstream endobj 516 0 obj << /Length 105 /Filter /FlateDecode >> stream xÚ36Ô34R0P°b#CS…C®B. m„@ $‘śËĺäÉĄäsé{€IO_…’˘ŇT.}§gC.}…hCX.OöňěÔ˙ů˙Ö˙±˙!˙ý—«'W áš(ť endstream endobj 517 0 obj << /Length 187 /Filter /FlateDecode >> stream xÚ33Ň32Q0P0bSKs…C®B.S3 ßÄI$çr9yré‡+šqé{Eąô=}JŠJSąôťś ąô]˘  bą<]ř˙ Ć˙˙€9˙?©ú˙˙€Ä~0˙a``Ęü«cRň˙Ř:ě˙€5Ú˙Ső`”ü˙†˙Ţ˙Ř)ö`ŠńR( Cţ^ ¤yÄPŔř:ô5>ŠËŐ“+ Šc endstream endobj 518 0 obj << /Length 291 /Filter /FlateDecode >> stream xÚŤŃ1jĂ0€a ‚·řŇ jR'YbHS¨‡B;u(™ÚŽZÚ­ŘľI®âŁä=ĽJďIq‰ÁT`ř$/˙“V‹«ëµIÍÂ~«ĚäkóšÁ,s»OÝÖýxy‡m É“YćÜŮSHĘ{óőůýÉöáĆděĚsfŇ=”;#ěŇŤđkTŃNUç„ÝDö3’8L¤đ4Ł1č¤裵>+*bôůT)ôŃ?ŁdĐ C~yE}ŽşQÂKZqľ<ŠšĄ¬8ZµT°b+ÎŹˇ1ÜĽĎ×nÎ N”żq÷AŞś(şF».äŔůgE¤žă…¸$ <†ŕAéÄń‚óGĹ.Ť!Ń šŐPĽĎ/X-Ĺ{Uü°­«ŁwĹîż‚ŰáĆÁĘ’ endstream endobj 519 0 obj << /Length 306 /Filter /FlateDecode >> stream xÚĹ’=NÄ@ …MÉÍ!ľ$)Čf«‘–E"T (‘AKr®’ŁäS¦XĹŘ“Ů,=S$_> stream xÚĹŇ˝ Â0đ‡Â-}„ŢěÇV¨ě čä Nęč čl­ŹŇGpěPz&±M„ĐÉ@á—„$ĺîź„Ó$BgüK|Ś<p8äs9‡3d°-Ć!°%_V¬đv˝ź€eë9ŔrÜčďˇČ‘ä°řxë©Ô)Q©TóĹ”ďxÔô˛©íeĄ4ČG¤ŞzMÄa)[Ľ"ei=šAikĘëLąôMĄ!çCŐhŐ×ř.TC×Ę#ł¦igÖ^w†Ło¶ęŞî´îľJ„-ă$äŠKH…­We¦N'Q<‹6đŻ?K endstream endobj 521 0 obj << /Length 208 /Filter /FlateDecode >> stream xÚŤŇ˝ Â0ŕ„…[úćžŔ´[' µ‚ťÄI'őŃ|ŁěµĐ´Ö@ໄ\ţ.ôű]Ô=ô0âÖa»:Ô›=Ä)Č%!Či> 2ťáéxŢŚçcô@&¸ňĐ]Cš ú¶ŚuăĹPŚq‹Á"p3q%ŚÚŃ«áҧ™ÎĐN°˘€ľđß(WUyxű¦9řł8ˇ ëŃVÁ6qŻĂ1 D„=¸˘$ء¨•D‰÷/Ŕ$…|®±ßd endstream endobj 522 0 obj << /Length 173 /Filter /FlateDecode >> stream xÚ37Đ31R0P0b3S3 …C®B.3rAÉą\Nž\úá f\ú@Q.}O_…’˘ŇT.}§gC.}…hCX.O…˙Đ@€>Ŕ`˙ŹAJ3Bi†z(mĄĺˇ4?”f‡Ń 43š+ÍřF3| @3€hf4;”ć‡Ňő`č+˘hz„~vö1’HťiP¤~ ‚ćrőä äśĎ endstream endobj 523 0 obj << /Length 300 /Filter /FlateDecode >> stream xÚÍŇ˝N„@đÝP\2 Źpó ÄX‘śg"…‰Vć*µ4QŁ5÷&÷*< ʰĺĆ™`ąřQ{ů±,ěÜĚż,OÓsL1Ç“ Ë3Ě/đ)7(r^L±ž<ľŔކä‹’k^†¤ľÁŹ÷ĎgHV·—A˛Ć‡ Ó Ôk4ü#gĚ«`Id ßKDť-XűHT±ú…HžQěd[Ďë;'ŰřëĄn—ü1‰ŞŢ“ŐĆi/jś®óÇ{;_…ă÷ZźÓöX\‹?b.®´ ęż«QŮ_äËó%ţ5Üt×őI˙Ąôs&µüAÚÉciÇUÝ h’NËN SµÓ¤#ťţvPHDH‰&‡4MÎŇnLĎ•OÝ!“č|&%ť­Ig]‚«îŕ ę¤ůr endstream endobj 524 0 obj << /Length 104 /Filter /FlateDecode >> stream xÚ31Ô37R0P0aK3 …C®B.cS ßÄI$çr9yré‡+›ré{Eąô=}JŠJSąôťś ąô]˘  bą<]ţÁlü†Q3č¸\=ąą‹i% endstream endobj 525 0 obj << /Length 278 /Filter /FlateDecode >> stream xÚŤÓMJÄ0Ŕń”. o“ H›dŽŐÂ8‚]ăĘ…ĚjtéBQč®˝‰WéMěşśĹ0ĎĽřW:…Đţ(üyÄšüt–+ŁÎܲf¦ňsőhás·at˛}†eú^-ć oÜ.čęV˝˝ľ?^®Ż”˝RV™ T+…xţi[Dü2hé; Ę_ĐŹ.°#Äź ě ÉGf Č,Dą#¤ ˛˝đŻ H_W3H|ÝŔ ¦ ¨gQPÜMAP]Ňr :)8P]Ę‚‚ŠiP]Í‚ę®.ęY¸ ¸cá‚’ö4<Ę]:‚l_Ś@ęcŕ0‚ćŔÂĎŽ… áđáů»%ŤĂĺśü®+¸/]zś endstream endobj 526 0 obj << /Length 286 /Filter /FlateDecode >> stream xÚ˝’±NÄ0 †sb¨äĺ!~čU ë1U:‰H01 ›€‘sîŃú(}„ŽŞ;¶RĐ!F:$_ţŘŽk{sqVťă ×xZa˝Áő%>WđuĹâ k»yz…m ĺÖ”7,CŮŢâÇűç ”Ű»+du‡Źěł‡v‡Îą‚:—>˘ö‚H%Ď0„čhâ}ÁGOÉäŕNÄhI˘öl+÷­›Ńé"‡$§>Şťx$O‰‘Aâ9Ń3Hŕ:7Ľ¦ICc0C0” üd˙ć4rŞGđËZĆą3h醥Aꎰ:wß*Ż˝8,´;$ÁĄqQRrş¤WEö¤˝g‡Ž˝{ !“Љ̳A:>6@ ĂřcňhٰÁu ÷đž¤ö} endstream endobj 527 0 obj << /Length 185 /Filter /FlateDecode >> stream xÚ37Ó35V0PasC3 …C®B.3s ßÄI$çr9yré‡+™sé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţ„ńĆřcüo€100ČUňŚ˙@ ő  űP3řúŃ v,ŚÔf [Í=čn†űć/¸Oˇ~0”ńĆ85 †)šcpązrrÚőĎ\ endstream endobj 528 0 obj << /Length 305 /Filter /FlateDecode >> stream xÚm‘˝JÄP…OŘ"p›Ľ€yÍf‰‘aa]Á‚VbĄ–Šv ÉŁĺQň)#\î83w‰.x›ŹĚď9“zu¶ŞhI5ť–t^S˝¦—Ň˝»j-Á%]2Ďon۸⪵+n$ěŠć–>?ľ^]±˝»˘Ň;z,iůäš<ŕH9ŕŘ0w{‰1‰ŕŰcÁ]Ω<˛ h=ňQŠ=6 zhľ,ÝŚ$üűýdŕ1bŠđĐ׆«ا¨#X«ęéÉA}ÉëÄĽŢiMËÖ©ĄS¬Ń-d§ÚpíAÜiČĚ$ r˘ńÉ0cúđGÖÝ‘»Ň"Řyäž*\ެŠĺ'¨ŞÍ5 ‰Đš?źŰ)¦ÔśhVVQĄ»nÜ˝ű÷ó× endstream endobj 529 0 obj << /Length 162 /Filter /FlateDecode >> stream xÚ37׳4T0P0bs3s…C®B.3K ßÄI$çr9yré‡+Yré{Eąô=}JŠJSąôťś ąô]˘ĆÄryş(Ř˙‡€D1ţ1đ˙o`ţ˙ ţÁ`˙ˇţ!˙ˇžĚ`G0ę ć5#F„Á€ŹńĘřńʨ †Áe0Ś2¨É`'â\®ž\\TŇË. endstream endobj 530 0 obj << /Length 208 /Filter /FlateDecode >> stream xÚí’= Â@…G,Óä™ č&"ů©ţ€)­,ÄJ--mMŽćQ> stream xڍѱJÄ@Ćń9R¦Ů7p÷ Ü˝p…$pž` A+‹ĂJ--mĎ<Ú=J!eаë|3\{¸üłü%Íćňş UĐë*4›đVó'ݱݰĹĂëo{ŽĎaÝpĽ—·ű‡đýőóÎqűxjŽ»°ŻCőÂý.řŚ•Îg¦U^|$ł_ ÉLTćÉOČčG"'9ů|ěd@: ýfŇ$j%Y#¤e¦%!-#â,BĘW ‘.ă’ŚÄ‹Ś$# ä„”§Ś;Y˙"ť‘ÎHg¤3ŇéxäŤôF^ŕÄB”lqb ĆkmĘCˇSlʤä*)Y$%ˤ¤KJvIÉĽ€tyŃs>|×ó˙‹^Ő& endstream endobj 532 0 obj << /Length 232 /Filter /FlateDecode >> stream xÚ}Ď˝NĂ0đ«Jˇl¬üął;Ta?ůěűpŰś7k©äBÎjiŃĂkÍďÜVb»ąĚ7/;ŢôĄ­8ÜjC'ź_o6÷×RsŘĘS-Ő3÷[ˇ&Ňĺ±0’Ć`Q·Đ0‘|T*őM *pŠÓŚ_¬°·ĂĹ2ô $ŠL‡o1Ă”Jc4|îĐĺÝśŽä~82ýŤ;á eSz™ńéşŇ)<Ć8`ŻÍŠN9y{Ń2Ęhŕ›žřĺlˇ— endstream endobj 533 0 obj << /Length 214 /Filter /FlateDecode >> stream xÚ­1 Â@E'l&GČ\@7‘E±1#BĐĘB¬ÔŇBQ°’Łí‘R¦gEě…áv>˙Ż™'SŠČĐ &3!3¦cŚ4#ŁNq›ĂÓő–ĚőRdÔůŠn×ű uşžSŚ:Ł]LŃóŚ’> stream xÚuŹ=nÂ@…gĺbĄi|Ď’eĹŇYâGŠ‹Hˇ˘@T’Djűh>ŠŹ°Ą äÉŰX ÉźVď˝yšyńĎŢËD¦ňä%ĽJÉÁó™C€8‘0ťĎ/*v[ ÝdvŐ»\/_Gv‹ŹĄxv+١hĎŐJĘž2Ő†(Wí ¨F˘şO†¶öFF›l@˛Ä&ż%`Ý}b —ÝČzdüeL,˘>2˝żÝ˙°~dgygL[Ť41Ƕ¦łŠ» ÚÖhKy“ęJ BaűsµQř óşâ îDŠ endstream endobj 535 0 obj << /Length 167 /Filter /FlateDecode >> stream xÚ36Ń32V0Pacs…C®B.cK ßÄI$çr9yré‡+[ré{Eąô=}JŠJSąôťś ąô]˘  bą<]ţ700đ˙ŔŔP˙˙ă˙˙?˙÷˙aŕ˙Ç˙ŹAţŹ<ř$ěADýÁ˙‡á˙0ÁüH0 ¤˙A6b#Č4oú˙@ÁĺęÉČčü®  endstream endobj 536 0 obj << /Length 281 /Filter /FlateDecode >> stream xÚ•‘=NÄ0…ÚÂ’!sH›´––E"T ()@Đß`ŻäŁä)·<ĚŘ‹Ĺ$Ĺ'ĎĎ{ĎIן5-5tA§ç-ukZwôÜÚ7Ű5¤oßZOŻv3ŘúžşĆÖ×R·őpCďź/¶ŢÜ^Rkë-=ÔŁ¶đ„/ŔqZq€gŢ XźxÂqdWŚjďŁIp‹ŹnIU¨ě¤i˙Ŕ+Â˙ńW%KK"5˛-CiÖKěŚ #;–A 58©E, ć˝k΢SvŕYlKł S^`‰%*#ĂGÝĹ4dP€ăă”ɲ€1ę:Ľ^.eiłŔĄüiŤţ‘C–¨žĚ%ý>+éÁ^ öÎ~ÝčČń endstream endobj 537 0 obj << /Length 167 /Filter /FlateDecode >> stream xÚ33Ň32Q0Pa3 ˛TH1ä*ä25ňÁ\Dr.—“'—~¸‚©)—ľP”KßÓWˇ¤¨4•Kß)ŔYÁKßE!ÚPÁ –ËÓEˇţü˙Ob†PŚF±˙Sö˙@Ô˙˙€ÔÁ˙˙©ăě˙©ó ň ę>˙? uBýP?Ř˙©(ÔlÔˇDý˙˙żů˙˙ř(.WO®@.Jĺ×m endstream endobj 538 0 obj << /Length 131 /Filter /FlateDecode >> stream xÚ36Ô34R0P0b#Ks…C®B.#ßÄ1’sąś<ąôĂŚL¸ô=€˘\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. 5 Ś˙˙7°˙?Dü˙ # P¨¨’¨?P˙1˙?ŔH{ôpązrrŮđD endstream endobj 539 0 obj << /Length 107 /Filter /FlateDecode >> stream xÚ36Ô34R0P0bc3K…C®B.#S ĚI$çr9yré‡+™ré{Eąô=}JŠJSąôťś ąô]˘  bą<]ę0ü˙ʉ™qŕ˙˙˙7 c.WO®@.„S—ś endstream endobj 540 0 obj << /Length 209 /Filter /FlateDecode >> stream xÚíŃ? ÂP đC!Ë;Bs_ëZA,T;:9“::( n>'Go qčQz„ŽJc޸îß—dűÚŤZŁE5eÚuj¶héâ}O˛SĆň°Xcˇž’ďˇĘu4˘ÝvżBŽ{ä˘îÓĚ%gŽQźŕh¬@ĺĚ&ŕŽlJ2§ćDxbÎŞ…çÔÎUdÂK¬ ŰŘ9TůŠ»`Pá+XÜUň.<ĽÉS*ń“©0y1Ćß Íźoňł–^Š_'řřďü# endstream endobj 541 0 obj << /Length 162 /Filter /FlateDecode >> stream xÚ33Ň32Q0Pa3 eŞbČUČej äą ‰ä\.'O.ýpSS.} (—ľ§ŻBIQi*—ľS€ł‚!—ľ‹B´ˇ‚A,—§‹C}ű?†˙˙ě˙7€¨˙˙©Ć˙˙©öö€Tüć˙óř˙10ţźˇö@¨ ě˙Ôę6ęŔP˘ţ˙˙ßü˙˙?|—«'W ă[« endstream endobj 542 0 obj << /Length 213 /Filter /FlateDecode >> stream xÚĄ1 ÂP †#B–ˇą€ľ[ĄSˇVđ ‚N⤎ŠÎőh=JŹĐ±C1&¶ŐE\|>řóó’?ádäůäц>…c &tđńŚA$˘GÁ´éěOX4 "4 ‘ŃŘ%]/·#šd5#MJ[ůh‡6%·y=ć\0`..łŞYĺ°€óßAK<ý@\Ŕ@Q‚#6·§-WQwu©;Sđwđ ÷?ńkB·KnĎú•ľÍĐ&jŃ×´…„–ěůű1ł´Áa®>7k.s‹k|]ĹŹf endstream endobj 543 0 obj << /Length 227 /Filter /FlateDecode >> stream xڵѱjAŕY,„i|çtďôN´Ś‚Wbe!V&eŠÖçŁ-ř>B|„-ŻX˙•D„ÄT±X>ŘŮeçźíuÚťLéJ+HŢ—,—×”?8Ź»‰ô˛ŻŇęťGŰąäŰ)öŮϲYoßŘŽ^ž$e;–E*É’‹±P鑪SÝ˝ęT+đé†(5OTÓ@u%BMwF=p§±ŚşoHý-euźař~Ď˙ěěŇnlŢ]ŁTȇ`1ć)†6AâĆŻbXiú DŹAăźü O žńĄÜĆ endstream endobj 544 0 obj << /Length 161 /Filter /FlateDecode >> stream xÚ31Ő37U0P0bcS…C®B.cK ßÄI$çr9yré‡+[ré{Eąô=}JŠJSąôťś ąô]˘  bą<]ęęţ˙oü˙ŕ˙˙ć˙ţ˙ď˙˙Hô˙ů˙ľü?ć˙űä˙1ţß"~Ŕ‰`‚˙ă˙ě?€ă ÁŔ€L 7ń˙?Đbl—«'W n endstream endobj 545 0 obj << /Length 223 /Filter /FlateDecode >> stream xÚEŹ1NÄ@ E?šb%79Âř0;Úě"Ş‘–E"T (·AKÜq­%GH™"б´4o4ßßţv]_ä+^sÍç™k{wüšéť6[í{ąT^Ž´o(=ňfKéÖdJÍ~|˝QÚß_s¦tŕ§ĚëgjŚ8ęŹU•ʇ R:EZ Ę·cŞV˘˙G@­‚V‡•ŠjçU'Řř„3rŹ¸ŘąÓ–˝µ—Łĺ:ŞÓ ľFg ńľ©u·Đ1ĚvĄMŞ#†bjż2;Ý4ô@ż*ť endstream endobj 546 0 obj << /Length 173 /Filter /FlateDecode >> stream xÚ31Ö35S0P0RĐ5T0¶P03VH1ä*ä26 (™@d’sąś<ąôĂŚMąô=€Â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ڰĚXv8Á'äá„=¨˙3ŕ˙˙˙Ă,X ť w'€ţü˙ůC=„`?Ŕ`˙żAţŹ<Ř7@ď˙˙ ˇ˙? ćrőä ä ,Źt endstream endobj 547 0 obj << /Length 166 /Filter /FlateDecode >> stream xÚŐĘ+Â@ŕi*6Ó#0€í6ÝÚ&Ą$¬ … (ŠD@@/G[Ç5ę°8¤Ă‚¨ÁŁľüŹ"e9Ą”ÓĐP!Zj îŃZ)%źełĂʡ^’µ¨§RŁv3:N[ÔŐ|LuM+Cé]MŕD Ě!ćßÄ a9PIŇcĐŁd€/-x>oŁ;wŕę*”Ě!aVBĚÝđ7őś8\ŕ ¦ä¤d endstream endobj 548 0 obj << /Length 216 /Filter /FlateDecode >> stream xÚ}Í=jĂ` `-ľA¬äł‹M)ňőPH§ !SÚ±CC ÉŃ|”ÁŁ'ꫯˇ¸’oţ4J$ëüQ˛LŢSţâ<ĂśŘh‡ő'Ź+v É3v/ز«^e»ůţ`7žO$e7•e*ÉŠ«©¨*…ÚÝ#ĐŃ3‘Q€Ćs;Đţ*ŃŘ— ř‰/‚Ô@iŕh#2ę+1@îđ„[|áiöơŮyÚÖ(ŰĆsöÄç“G=‘Ö· ·G¨Ô#¸ôˇî–ĘłŠßřŕ•pH endstream endobj 549 0 obj << /Length 234 /Filter /FlateDecode >> stream xÚ}ʱNĂ0†˙(C¤[úľ'¨”±4R[$2 ÁÄ€€‘ˇlU›GKß$/ૠÇůĽ0Ő˛őéě»Oţ››euĹ%ÇÓ\s]ó[E;jj­ËXƇ×Zw䟸©Éßé-ůîž?÷_ďä×®Čoůąâň…ş-‹ü˘•p ĐťŹŔiB1íŚE¸ mQ,GE!ýA‘Ë0)29Ă·Nň3Dś¤ŹhśI¤AŇ iţˇ1µ„„Éćô7şVÎpHšÉ4Y0Mlľ3ĂEŤgˇ°˛P1€jDßEćK ŰŽé(kЉ endstream endobj 550 0 obj << /Length 267 /Filter /FlateDecode >> stream xÚ}Ď˝JÄ@ŕRn“7pî h~(Âb`]Á‚VbĄ–ŠB !y´ř&ű)Sdw<ód„>¸ĂĚ™SťźĄäRĘq™Ku&ZËsÁo\iLs9Őáčé•× g÷Riή1笹‘Ź÷ĎÎÖ·—Rp¶‘‡BňGn6bڎŘĚ˙™-Ń‘eFGZ0ý‚Ucc^ĎpGí))€ˇ$ ·ô)Y†€Č=ň ÜĆŻă—Ą[Ç4Yęitěj·uGj†ż wAlhA´_Bóí“gô6UąĘT÷¶2u­Ś¶2Hľ–ňř’o÷í^î_Ë„>áë>ĆŻľă ř‹ endstream endobj 551 0 obj << /Length 126 /Filter /FlateDecode >> stream xÚ35Ó30T0P°b 3S…C®B.c ßÄI$çr9yré‡+[pé{Eąô=}JŠJSąôťś ąô]˘ĆÄryş(000````ň ˘H0˙ö@â˙,Äá˙0%#Śz˙˙l—«'W Řšź endstream endobj 552 0 obj << /Length 266 /Filter /FlateDecode >> stream xÚmбNĂ0ŕ‹ĹöďłĎăú˘|ďGýżýÓŔ/ĽŇqŻCýyÜófâîÎŻFî®0ËÝtíß^ßźąŰÜlýŔÝÎߣĚO;O$™9Á 1!rđHőâ°Đdš…Úő4›f˘&ç‚p–B•l9{„ôźČĂŐ6©8ů,Ö´Â/ővîK¤qb´űŇ·í˘+tÍŮŠ%+ żN»C7¶É"­EB´8Ńč¤V‹ęP Í#R¨I*š‡h~ jÁ:ąRᕤč[I®ÍĆlÍ`ΦüţĘ—ßň'‰Ä& endstream endobj 553 0 obj << /Length 258 /Filter /FlateDecode >> stream xÚ…±N…` …{Ă@Ňĺú $÷g%ą^Ltr0NzGŤÎđh< ŹŔČ@¨=…ăâň íééicu]”RH”«Rb)U”·’?ř­XHU­ť×w>5ś?É1r~geΛ{ůúüľp~z¸‘’ół<›Ń 7g!Ň‘RUc¦ÚµŠ’R;Q2Q˝P:X Ja2m0{´ţŁëűtĆ”yíl[ŔJ8 XĎ íĄ-ÖAvH¸xÎiO›zÚMąÍ÷YýSgâ˘ÄŤV6ë•Óo†¬GĐběÔůÇťÉĆď2ޏ´ŔşC’lÄŤLńUú‡[Ďźů]~(ß6üČ?údµŁ endstream endobj 554 0 obj << /Length 216 /Filter /FlateDecode >> stream xڭбjÂPŕ„ łärž 7ÁDpI *ˇĐNJ'utPÚ-4Ů|-7_ĂÍŐ­…ôć˙mťzŕŢŹs/üś{ÓńCk¤#»Ň‘ŽS]Ų•dbű¨k»‹ĺFŠRĚ‹&1 {*¦|Ô÷ÝÇZLń4ŐXĚL_mĚ›”3ulĺŽó‡š´Ř]â đI@B’¨I Ü/ŕťßsÁ„ĚĚČ'©Č¸ŕť€ßsABN–‘jŔ¸ŕť€AOBľ/#ů&-ŞąÇďżü'5Ło#óRžĺŚÔ‘ endstream endobj 555 0 obj << /Length 253 /Filter /FlateDecode >> stream xÚĄĐ1NĹ0 `?uäĄGxľ¤‘^:éńč€bF¬4G Ç GČءj°]&`ŁŞ>EIc˙µďŹ;Gy:räőžî>áÎófG}żžÜ=â~@{M;Źöś·Ńôňüú€vyJín¸Đ-2Đ€ÉL]_~ÔEťŐI-jVُ€8«Yĺz&Á? …}—BćŁÖćsí›$–SéÂhjääMM|wSSYNń-đµźNżmٞ8±®NZôTÜÔ2fé5J÷ü’äD 2ЏMĐrŕ[ÎĽŹ©Ń‚Î‚Ěż51˙=ž x…_‚˛¶d endstream endobj 559 0 obj << /Length 197 /Filter /FlateDecode >> stream xÚŤŽ± ‚`…Ź4wéş/Pj–)‚äÔÔMŐŘPÔš>šŹâ#46Č_Gth ľĺŢË=監(TW˝©Cő# |=yr•±Ď­«3Ż;/’fâět싳â^śl­÷Űă,Nş™+ç…î=u’-',ž]Ł˙Ć BR"/𠬽wý‚]ˇOJ HŃ4äMJ‡ę˙0?_9ş¨¤čÂŮÂ.6˛—í­†ŐľŃŤ†ô¤-ťiN«Í‹e™ÉVľ‘ťLŹ endstream endobj 560 0 obj << /Length 196 /Filter /FlateDecode >> stream xÚŤŹ= Â@…ź¤¦Éś čćGb¬Ťŕ‚VbĄ–Š‚•ńh%GH™"¨/ŮÂVřšťeŢűf Ć©šj?Ő8Ň$ÖC(g‰b…îg’©łŃ(łŕXŚ]ęőr;Š™®fĘw¦ŰPťŘLď@ |Čů “~‰nŻFç <z/ř¤@—”đ:ŽşMrpíńďß\3]8[ŘĹFö˛ÝiäÍÝhHOÚŇ™ćô˙´AĽHćVÖňxuO’ endstream endobj 561 0 obj << /Length 197 /Filter /FlateDecode >> stream xÚ=Ź;Â0DQ m“#°'Ŕ1ůQ. ˘@T@I‚Ž–Łpʰ'XĘČză™ě&Ůp:áSN8qjřhčBq&,âd ăp¦Â’Ţrś‘^ %mW|»ŢO¤‹őś é’w†Ł=Ů’•ś\ľŕ%Ň‹„NfN‚¦RŞ×8ţÔŽ;Óó§„Ŕ?]¨AČq„Ŕë¶ !帿ÁĹ;$E‹ďC3ţŃóNŐM€YBď¨vҶňż6Ân*§…Ą ýUKe endstream endobj 562 0 obj << /Length 194 /Filter /FlateDecode >> stream xÚEŹ1Â0AH×ä Ü °MśR. ˘@T@I‰Ž<Ť§ä ))ćĽ ŕbeÝx˝{6íŹG¬9aËvŔ‰á˝ˇĹ©Ě4Ű!ŔîH™#µć8%5—))·ŕËůz •-§lHĺĽ1¬·ärÖ-9· ď ňą—"“§HôéŇöEŔ •H$;5ĆšŔř˙2ŕ¨úŢ ďŕ€żÔó˘É@Lľlş úˇ)ĺa7lI3G+úůlJ endstream endobj 563 0 obj << /Length 110 /Filter /FlateDecode >> stream xÚ31Ół´P0P0´TеP01Q03VH1ä*ä22Š(BĄ’sąś<ąôĂŚL¸ô=€â\úžľ %EĄ©\úNÎ @ľ‹B´ˇ‚A,—§‹Bý˙˙QŔż? C ýGőĐG\®ž\\0ńoy endstream endobj 564 0 obj << /Length 112 /Filter /FlateDecode >> stream xÚ31Ół´P0P0VеP0˛P03VH1ä*ä22 (Bd’sąś<ąôĂŚL¸ô=€Â\úžľ %EĄ©\úNÎ @ľ‹B´ˇ‚A,—§‹Bý˙˙‘@ý˙˙ öC Ő˙˙Źę…\®ž\\ĽHB€ endstream endobj 565 0 obj << /Length 106 /Filter /FlateDecode >> stream xÚ31Ół´P0P0UеT01RĐ5RH1ä*ä26 (C$’sąś<ąôÌ͸ô=Ěąô=}JŠJSąôťś ąô]˘  bą<]ę˙˙˙˙Lń˙!ÁĺęÉČW51ń endstream endobj 566 0 obj << /Length 143 /Filter /FlateDecode >> stream xÚ31Ół´P0P04S02U06V05SH1ä*ä ˇ±!T*9—ËÉ“K?ČĺŇ÷Šsé{ú*”•¦ré;8+ů. ц ±\ž. ěř?Č˙°˙„˙€đżüţ˙ě˙조žˇ˙1üaüĂüůPíű˙üořĎPĂ`ÁŔĺęÉČŞL.D endstream endobj 567 0 obj << /Length 118 /Filter /FlateDecode >> stream xÚ31Ół´P0P0V0W01Q0±PH1ä*ä21PAC°Dr.—“'—~¸‚‰—ľP”KßÓWˇ¤¨4•Kß)ŔYČwQ6T0ĺňtQ``°a‚:Şö˙˙˙˙S$ţýG`1jŰ%€ţŕrőä äŔą>Ź endstream endobj 568 0 obj << /Length 142 /Filter /FlateDecode >> stream xÚ31Ół´P0P04SĐ54V06R04TH1ä*ä24 (™Ŕä’sąś<ąôĂ Mąô=€\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ěř?Č˙°˙a˙˙Ů˙“˙Ç˙ŹýCĂ?†?Ś@Čü˙ý‡˙ţřßPÇ`ÁŔĺęÉČŃ4,r endstream endobj 569 0 obj << /Length 96 /Filter /FlateDecode >> stream xÚ31Ół´P0P0Ć@ÚP!Ĺ« H(€ą`™ä\.'O.ýp —ľôôU()*MĺŇw pVň]˘zbą<]äěęüőěä¸\=ąąŠŽ– endstream endobj 570 0 obj << /Length 162 /Filter /FlateDecode >> stream xÚ31Ół´P0P0UеP01R03VH1ä*ä26 (Bd’sąś<ąôÌ͸ô=€Â\úžľ %EĄ©\úNÎ @ľ‹B´ˇ‚A,—§‹<bĆ@‚N° ?8$äÁD° ­ő ˘Dü`#ř2î©fâ2X3Iq,63© ă*@—«'W yK/ endstream endobj 571 0 obj << /Length 104 /Filter /FlateDecode >> stream xÚ31Ół´P0P0Ć@d©bČUČehäą`™ä\.'O.ýpCC.} 0—ľ§ŻBIQi*—ľS€łPÔE!¨'–ËÓEAžÁľˇţŔ˙0XŔľAž0Ŕ®ŹËŐ“+ 9Ü-I endstream endobj 572 0 obj << /Length 111 /Filter /FlateDecode >> stream xÚ31Ół´P0P0V04W01Q0¶PH1ä*ä21PA#CLr.—“'—~¸‚‰—ľPKßÓWˇ¤¨4•Kß)ŔYČwQ6T0ĺňtQ°˙˙˙˙źz ńď?*‹1pš¶ËŐ“+ ĎJS endstream endobj 573 0 obj << /Length 102 /Filter /FlateDecode >> stream xÚ31Ół´P0P°P04W0¶T02VH1ä*ä26PA3Dr.—“'—~¸‚±—ľ‡‚—ľ§ŻBIQi*—ľS€ł‚!—ľ‹B´ˇ‚A,—§‹Bý˙˙?ţ˙˙˙ĸ\=ąąE:(“ endstream endobj 574 0 obj << /Length 102 /Filter /FlateDecode >> stream xÚ31Ół´P0P°P04W0¶T02VH1ä*ä26PA3Dr.—“'—~¸‚±—ľ‡‚—ľ§ŻBIQi*—ľS€ł‚!—ľ‹B´ˇ‚A,—§‹Bý˙˙?ţ˙˙˙ĸ\=ąąE:(“ endstream endobj 575 0 obj << /Length 118 /Filter /FlateDecode >> stream xÚ31Ół´P0P04P0"sSs…C®B.#3 ¨‚‘9T*9—ËÉ“K?\ÁČŚKß(ÎĄďé«PRTšĘĄďŕ¬`ČĄď˘m¨`Ëĺé˘`ĂŔĎPÇ ßđźÁţ!\Ď`߀ ĚŔ‡Aöpązrr]7˝ endstream endobj 576 0 obj << /Length 172 /Filter /FlateDecode >> stream xÚ31Ół´P0P0bS3…C®B.rAÉą\Nž\úá &\ú@Q.}O_…’˘ŇT.}§gC.}…hCX.Oööţü&äȉů4Âţ˙˙˙ęÄż˙¨,Ć`„˘ę€hâ2üB0Ó° 0ţ`@Ě?ÄćDŚ0pązrrűV‹« endstream endobj 577 0 obj << /Length 262 /Filter /FlateDecode >> stream xÚu±NĂ@ †uä%+Űů iC™N*E"L ‰22€`ĺŇ7 or}ڇgě!učňIgźäď˙çőÉů’ ZĐń’ć§TW´)ń«Z†ť•›Çg\5ßQUc~%cĚ›kz{}Â|usAň^Ó}IĹ6kč FeŔ`Ć<@Ę!cf0?ßÜÚ]pťý ¦sŰy—„Ôú¨&dűH}śţ8…Ý*vó%ČäČÉVÇăf51СJęZ F‘ůG˙‚YĎű&Iý§âŁ˝Ń0¶n5 FŤzP— EôZI7•s°şÚ.^6x‹ż*H°Ü endstream endobj 578 0 obj << /Length 201 /Filter /FlateDecode >> stream xÚ•Ť1 Â@E'l&GČśŔMŚF­QÁ‚VbĄ–жIŽ–Łx„--ÄqFj%.Ěů˙Ďß^Ú )˘ľLŻKýíb> stream xÚ31Ół´P0P0bSSs…C®B.ßÄ1’sąś<ąôĂLڏô=€˘\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ö P߀ ˙ŔJ2~~€‡dţüť|"ŮţŔN‘üţ`%ĺę°’ö ő ěhL˛¨ FÖ˙˙'˙˙y“ü´Ťńű,$3üŔŔŚę˙3Ř˙o€˙AŚYśËŐ“+ H0‚6 endstream endobj 580 0 obj << /Length 198 /Filter /FlateDecode >> stream xÚ}ϱ Â0ŕ” …[|„ŢTkŃI¨Ě čä Nęč čj}´>Jˇc†Ň 4č „|4ůÓ;.ˇł)JąťŤq’ă)…+dią#Ç  Ä3 bĺnA¨5ŢoŹ3błŔD‰űĺT‰•µšYk[Âz^Dí«yĂ’Ć1 ¸é‰<­ý§QřSH¨hUsjD0NÍű/ëýŐňŁQG<óżTá]×ăKĹDbh@CŁ6„“3K[xŁGśj endstream endobj 581 0 obj << /Length 230 /Filter /FlateDecode >> stream xڥбJÄ@Ćń/¤LłŹ°óş Éi¬ç ¦´˛+µ´P®Ű©¸©ysÎĎ˝Q­‡%oÚőćé•¶=ą{®[r×é\Ăďź/ä¶·—\‘ŰńCĹĺ#ő;üĐ"ŹÓL EĐĹ(đJŁdťäG)‚2Ł3!_±#2±C˘[°â•Ă{GEţÁňŔá{˙űĺʰ :Z2 fFŠ…€bÖ9eŮ)úQSŤFĘO?žV2C—şę鎾?9ru endstream endobj 582 0 obj << /Length 197 /Filter /FlateDecode >> stream xÚ31Ół´P0P0bS3…C®B.C ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś€˘. Ń@-±\ž. ő˙˙700ü˙˙˙ü&˙É˙ @Y 4űĆ˙€$ý)&ů?€Hö ’L2ţA ˙Č:0Y&íq‘ Ržbb¦ůőH.©C¸ ŮÍ_@|ńťü¸ŻA! HČŔCé,ô !ÉĺęÉČÝI endstream endobj 583 0 obj << /Length 149 /Filter /FlateDecode >> stream xÚ31Ół´P0P0bSS3…C®B.C ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś€˘. Ń@-±\ž. ő˙˙˙˙Ă$ţ˙ĂBÖIć uD“6`’ůD2ţŔJţ˙OÄĄj2ŰřÁ¤|©$(4ţ7üÇA‚e¸\=ąąWD–Ü endstream endobj 584 0 obj << /Length 141 /Filter /FlateDecode >> stream xÚ31Ół´P0P0bS3…C®B.rAÉą\Nž\úá &\ú@Q.}O_…’˘ŇT.}§gC.}…hCX.O…ú˙˙˙˙űŹ€$ţ3``°'LČ|DřAü˙ŹŹŔ¦jĺDý˙ ˙˙Ŕ Ŕ\®ž\\,µ endstream endobj 585 0 obj << /Length 230 /Filter /FlateDecode >> stream xÚ•˝NĂ0€/Ęé?Bî¨Ő…vŠÔ©`b@LбÖŢ Ţ$R_ŕ¤.•ĺjźKĹŠ-}o¸ďł»ͦTĐ®JrŽ&7ôRâ+ş‚ÂťLăäy‹óíąíÚ?Ł­oéýícv~· í’K*ž°^ŔdňĂ`dĎPÉ‘ˇaŹDľ„ÓZN{¨8;@Ά:0śGdśzT €”Ű š3’Î#ěň§˙'dč!Q M„4·éňł† ýú™¨«â>ˇŠ1šĄšŁ5ßČŽĂ—t*Ś«ďńďć5 endstream endobj 586 0 obj << /Length 114 /Filter /FlateDecode >> stream xÚ31Ół´P0P0bSS3…C®B.ßÄ1’sąś<ąôĂLڏô=€˘\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ő˙ŕč˙˙p„,Îü~č˙˙˙ÉBÄ„—«'W NÁ§P endstream endobj 587 0 obj << /Length 105 /Filter /FlateDecode >> stream xÚ31Ół´P0P0bS3…C®B.c# ĚI$çr9yré‡+qé{Eąô=}JŠJSąôťś ąô]˘  bą<]ę˙˙˙÷ €ÄŘ0 %ŚË\®ž\\6Qg? endstream endobj 588 0 obj << /Length 126 /Filter /FlateDecode >> stream xÚ31Ół´P0P0bS3…C®B.rAÉą\Nž\úá &\ú@Q.}O_…’˘ŇT.}§gC.}…hCX.O…ú˙ę˙˙``ř'ę!P‚Č:„°'–¨˙`ŕb˙¸\=ąą”…jo endstream endobj 589 0 obj << /Length 201 /Filter /FlateDecode >> stream xÚ­Đ1 Â@Đ‹Ŕ4ąÎ \kP1‚)­,ÄJ--!9™D,,˝î¶T×]…S[Ěů3ŐçnĄQ§*9z¸K5—¦.s˝WÍj“9ú!˛!qެ«SdaŹVËő ™ßo“, ‘ţcP$”nPPBĄz@QÉČ(>Z°öđălíl/5.§žâŇ×ÄK=&MŁŘĄÄĆ(o9)Ť÷Ś[‘·•ä-Ç_m0ÂÍv˘ž`é®Ţfsě„8Ŕ„‰‰ endstream endobj 590 0 obj << /Length 199 /Filter /FlateDecode >> stream xÚeČ1 Â0Ćńá-ÁwÓ–ZtPˇ*ŘAĐÉAśÔŃAQPPRo¦7iqpT· Ą±I( 8Ľďű{~ŁÝBÝâĽ&6}\9°Ol[Lń,7„@gčą@GEŽqż;¬“>:@8wĐ^@8@–’ŹX&äaüĆs!Ëe—V^Äz“ŇHř4˝ ¦±6Qľµ±25> stream xÚÍ=‚@…ÇXLĂ č˛ň#V› &na˘•…±RK Ť¶ÂŃö(Ň‚°.CÇ lľâ˝ć}/N竌BJh&)^P˛¤«ÄF© ]ś Í厹Fq¤(E±u1 ˝Ł×ó}C‘ď×$Qt’žQĘZŰ‚gmľµ‡J9Ő€eĘ ‚şđë€7FçĐ´Ó?oaŚFňú˝ k©ďÄ öŞ,Íú|_ÂçŕFă&Ťh endstream endobj 592 0 obj << /Length 182 /Filter /FlateDecode >> stream xڭϱ Â0ŕHá^Â{ÓZěZ+AĐÉAśÔŃAŃŐöŃú(}„Ž$ç] 8Nů ąäżKšMó9&čxĄgž,\ÁĺĽOd+…ă f‡.łâS0~Ť÷Űă ¦Ř,Đ‚)qo19€/±"jőB¨.P«;UuĚD÷ŚFŻ Âó'a¸üyŁbhŚçF±Ą4j-iMËđO*Ş˙·ů"`éa oőĆ…t endstream endobj 593 0 obj << /Length 218 /Filter /FlateDecode >> stream xڝн 1 ŕČ Y|óÚ;©‹‚?ŕ ‚N⤎ŠÎ磝ř"®äb/YÄÁÁ>JÚ¤ˇ¶Ýču)˘&Őc˛jµiă­őÉZ=Ůěq Y’µh¦>Ť&™ŃéxޡÎGŁÓ*¦hŤÉR. eÎى/É".ŕ‹Ҭt ÖňŇŞŞ®ôwčťđŁVűhOé/oé»2C óxźűB§©’ŮbM•nŐ˙ĽćĄ7÷íÝĄ| "çţĂÔ€3ź©ŕĂŻ>ŕ$Áľ$ťJ endstream endobj 594 0 obj << /Length 250 /Filter /FlateDecode >> stream xÚuŹ1NĂ@E'raiš=ÂÎŔ1IL¨,… á ŞФDöѶăą.·ţü ‘(öigö˙?łÓęřlnc›ŮQiÓ›ťÚşÔ'ťTl˛=˙yąĐEŁĹĘ&•—lkŃ\ŮËóëF‹Ĺőą•Z,í¶´ńť6KłNZäa|„ ř 9€ŕ|t5»ˇîˇiĂ»H†„ť˙…ű JňŽbz<„Ź„ëĽrd'ľĄ0Ő´ †˝(9qp&8 %? cFżűiŤ=¶H^†Qčů #tü)„g/pxLkDĎ…3zô˘ŃýŠA endstream endobj 595 0 obj << /Length 127 /Filter /FlateDecode >> stream xÚ31Ół´P0P0bSS3…C®B.ßÄ1’sąś<ąôĂLڏô=€˘\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ő˙ Dü?€‹üĂ`ĎŔOY$Ů€$ ;Rţ˙?ó˙¬$X–ËŐ“+ V—Xę endstream endobj 596 0 obj << /Length 174 /Filter /FlateDecode >> stream xÚÝĘ1 Â@…á )Óä™ čfaµ Än!he!Vjiˇhť-GɶL2ކ€ŕ „á+ţ7&ť.擦‰&“R’ŇYă Ť‘S2–Ós‹jOĆ ZKFe7ô¸?/¨ňí’4Ş‚šâ#Ú‚J®"nëŚÝŻĂę;€ţĘĽQŻýşO„7ZBŘU$fMYDĚ@Č ÷˘ĎťěŢfň‚+‹;|WWŚ endstream endobj 597 0 obj << /Length 197 /Filter /FlateDecode >> stream xÚ}ÎÁ ‚@ŕÂ\|çjUÔę$A‚:uNŐ±CQWőŃöQô /¤mU˛%vř˙?,ăÓĹślriâç“ĐŮÁz® mňgCsşb” Ű“ç"[ËY˛ˇÇýyAm—ä ‹éŕ}Ä$¦ě–ČE'ÂŹ}2´FZ_V 7 W?ÓWăei f ĺßĘ˙Ą)XąĘP>•Vž*5y«ÔŕMg9V/«Îz¬VJAđf9ô'ŕ*ÁľLCx8 endstream endobj 598 0 obj << /Length 210 /Filter /FlateDecode >> stream xڍϱjÂ@Çń_pţKŢŔűż@{98Sj@-4 “8µ •¶ä-ŹrŹpn‘âA0fČňľżé§ăÇá€#Vü XÇÜŹů]Ń–´ö1âţÓeyŰĐ8%ąd­IľúL2ťń~÷ůAr<ź°"9ĺ•âhM锳AiËtJwďeB# LX‰6vs`ÔRaFčŘ$˙i4ł•‡š÷ ;ą˘QWytExÝ­'{¸úgk~ç϶É,O*Ť¨™áŹ$˝=t č%Ąť~©–§ endstream endobj 599 0 obj << /Length 242 /Filter /FlateDecode >> stream xÚmбnÂ@ P#$/ů„ř ¸…¨ť"•š©L :vhŐ®ÉńgáO@ü@$2D¸v."PtOńůâłĹă× h"+šŇ4¦}ßih¨/»/śĄhÖMĐĽË.štIż?źhfs Ń,hR°ĹtA ×đď÷LZ5;¨Á·: —GÍÄÄŢkŃ?ŞŢ±R/ęčRŞ7ux;©¬¸xl;µđ3{gúßşjmĺkŮÝx®şNš®|סëÖuޔΚ‰˛v:ťTć-tjO¬Ŕ;Á°‚Q ądŮć,żĹ˛Z8ÝŽËâ[Š+üRô endstream endobj 600 0 obj << /Length 201 /Filter /FlateDecode >> stream xڵͽ Â0đ+ ·ôzO`Z©E§‚`A'qRGE×6Ź–G©o ¸t(Ć;…TÜ%—w˙.ÍzŁ!ĹÔç›hŃ>Á¦2Ç2Jł;â¸@µ¦´ŹjÎ)ŞbA—óő€jĽśP‚jJ›„â-SŞžYmEc-äÎwňy îŕ7Rź†őؼ€5ü“-!Ňäl·Őé˛Ó<ŮĐ´âM nŤÓܝޣ­ÖtVúWYőwŰ8CŰ:żrś¸Â˝žbĹ endstream endobj 601 0 obj << /Length 186 /Filter /FlateDecode >> stream xÚ­Ď1 Â@…á aŹŕśŔM! L!he!Vjiˇ(X™ÍŁä–)×ykkéÂ|°łüĹŇţx$‘ 0‰ S9Ä|ć»W<ěO<-Řm$±[Ř–]±”ëĺvd7]Í$f—Ë6–hÇE.™÷ľ) ýŨÝť—Ń ÔFďidjBT’Ţ6-5Ú†RPRB *úszGŞH©v–*RÍ–*ŇďýđĐđĽŕ5{ň}ý endstream endobj 602 0 obj << /Length 220 /Filter /FlateDecode >> stream xÚuŹ=NÄ@ …_”b%79Âř ŐHË"‘ * D[n‚–™Łĺ&ě¶Ü"ŠyămafôY˛źíyýĹéő•.ő\O:í/µďô­“wa\ňögÇĘëVV´O¬K{Ç´´Ă˝~~|m¤]=Ü(łk}fĎ‹ kEÚ¨m&fhĚF í€hĆrá°ž +'Ř2ľ©ʉ3Ůq4|PYáÂŮŘš0eܦŃ齳súźÉ5ɧĄ\Ó@ÜńďeÝ'ýXćĆĆreSU¤4ąäQ~MQdĹ endstream endobj 603 0 obj << /Length 206 /Filter /FlateDecode >> stream xÚĄĎ˝ Â0đ+Â->‚÷Z+©Sˇ*ŘAĐÉAśÔŃAŃą}´>ŠŹ±bđĽ$*.b†áBîţ§zíá€:ÔĄVDJQÜŁm„T‘;÷ýËfŹi†á’T„áTĘf3:Ď; Óů¤:¦•üYc6¦\®ľ›;żlhkb¬Ě⍹„€™/N-ęÄZ6*±¨ńp·—§ąë™|ZX›?šĽ4®Źďěő˝>uóÎćsľ’—n—‚«Ý tněĆÍ N2\ŕKKv endstream endobj 604 0 obj << /Length 205 /Filter /FlateDecode >> stream xÚŤŹżn1 ‡]1śä%oĐó ´ą”Ň)$n@˘S‡Š Z•µ—ľY…G¸‘!бi…ÄÖ _¤Ď˛ýł=ľŚ©ˇgzpäźČ;Ú:üŔˇ٨ąT6{ś´hßhčŃ.DŁm—ôőyءť¬¦äĐÎčÝQłĆvF0ŕ`ř80¸cfṉ́bč˘9)zA}T$"ÜË'ŻS|_Qůź(·˝ÝŞ(ăM I +ëT÷PG“eyĹ?żŃ4dѸY÷z‚Ü1…ó_ń ° S endstream endobj 605 0 obj << /Length 220 /Filter /FlateDecode >> stream xÚťĐ; Â@ŕ )„isÁJĐůEü"Ăřb=A×Ű çaÄS~]ż endstream endobj 606 0 obj << /Length 216 /Filter /FlateDecode >> stream xÚuŹ1NÄ0E˙*…Ąir„ĚŔ › ¨,-‹D $¨(VT@I‚văŁů(>–)VľAĐaYOňŘóçą??˝ĽĐV=é´˙ŢĎťĽÉz`±ŐţěçćéU6Łř]âoX?ŢęÇűç‹řÍÝ•vâ·şë´}”q«¨µE XĚX™Í¨ĚŽp‹[PĎ0ÔLhB M ‘‡ŔĆ4ě‘™ćň±Ŕ¸ţEâ ŚĆţS“«D¸ĚiDf( šD“śE‹TłHIc %)>—/Đ~Ĺ’\Źr/_})oG endstream endobj 607 0 obj << /Length 164 /Filter /FlateDecode >> stream xÚ31Ół´P0P0bSs…C®B.c3 ĚI$çr9yré‡+›qé{Eąô=}JŠJSąôťś ąô]˘  bą<]˙300°˙?ŔŔ ˙˙C=ř˙˙„`üĎ˙ůřÁţ€ýcf ‚¨˙˙˙˙?€F€%5…Ć„ý˙˙@.ý‡N€%¸\=ąąCStň endstream endobj 608 0 obj << /Length 275 /Filter /FlateDecode >> stream xÚ…=NÄ@ …ĄÉMŽ_ňĂ(‚†‘–E"T+* ¤A·ÚDâ \%7!H9Ec{·BHLńidű=żßźťRI'tT×äň%=Vř‚ľ–jIM}h=<ăŞĹâŽ|ŤĹ•Ô±hŻéíőý ‹ŐÍUX¬iSQyŹíš ŤÉłă:ţ˛ś!1¦{.g˝‹éě ›t<A9ŔN¤tÂÂż´É˝ęŕ`nę [˘Yč'ă(3’@řÉ üĘ~sPşoŁi5ąÝE,b”ł6ÂyÔ0ɬ1$ÄV¸ ç îÁ˙ÁŮş[›ěLző #¸ňşh»&Ű;‚ţˇÄł$˛^MR} ^¶x‹?máĘ endstream endobj 609 0 obj << /Length 165 /Filter /FlateDecode >> stream xÚĹɱ Â@ ŕ: Yúć Ľkąť µ‚7:9“utPtľ>ZĄŹpcÁŇ(¸ÔÍÁ@>ţ?1ét>CŤ1ŻI0I±ŚŕFş–*áx†Ü‚Úˇ‰A­ř Ę®ńv˝ź@ĺ›F  ÜG¨` t>ŕˇö»îĺč'C/fťH=ű b‰¨účłš­'b6l öÁí¶˙ŃQă¨"ňDőĐ÷–¶đi—Ť¶ endstream endobj 610 0 obj << /Length 137 /Filter /FlateDecode >> stream xÚ31Ół´P0P0bCSs…C®B.cc ßÄI$çr9yré‡+sé{Eąô=}JŠJSąôťś ąô]˘  bą<]řŔů(B¬Ž`˙¨­ţ˙ ÂD00 ˘ţ˙˙˙ ˙aDś€HpązrrȧYA endstream endobj 611 0 obj << /Length 168 /Filter /FlateDecode >> stream xÚŐĎ1‚@Đ!&Ópćş, `E‚¸…‰VĆJ--4ÚęÍŁě(-Śă!¶¶ţä5˙W? Ć9E”R?Ö”$4Ěh§ńqÓF”ĺí´=`iP­(ÎQͤGećt>]ö¨ĘĹ„4ŞŠÖš˘ šŠ| ¸Ź°ţęşf˙!ĚNÔ^ :ŕ˙^Ă]寸3„˘° l™nüO(řÜôŘN .ń ú‹k7 endstream endobj 612 0 obj << /Length 217 /Filter /FlateDecode >> stream xڭνnÂ0pŁH·ä¸'Ŕ ¤Q™"•𠦉věP+ŽÄ‹eëkdëšŃU‡˙ÇGkÉ?é>í4ëž8ć^¸iĆŹż%ôIi?Ä1B–4,ČľrÚ'ű˛d‹ ŻW›w˛Ăé˛cž'/¨łkL8âďëTó¶E‚ŃĹňĆkŐä%t:u€­=|đş?őQ ;D»ńN÷ üd~UôČ7úĺ ł˛S[Řv0ŘĽ?˝b¶j®vĘ?Ł ¶kµ1Nš\*ďÎÖ7V§*=4Ł#SăŚ÷ endstream endobj 613 0 obj << /Length 123 /Filter /FlateDecode >> stream xÚ31Ół´P0P0b#S3…C®B.c3 ßÄI$çr9yré‡+›qé{Eąô=}JŠJSąôťś ąô]˘  bą<]ę˙``¨˙˙á?ś¨‡ ŚĂ—¨˙˙˙˙0Ä˙?€ „—«'W íâg• endstream endobj 614 0 obj << /Length 161 /Filter /FlateDecode >> stream xÚ31Ół´P0C …C®B.sD"9—ËÉ“K?\ÁÄśKß(ĘĄďé«PRTšĘĄďŕ¬`ČĄď˘m¨`Ëĺé˘ŔŔřńC}˙ţ? ˙ď˙“˙Çđ˙˙ű˙ ň˙˙Y–o`*á?Ŕţ˙ü„Ř!*9 °ţŹ=ţ˙g„˙˙Ő!ډ@dą\=ąąŞ÷ endstream endobj 615 0 obj << /Length 159 /Filter /FlateDecode >> stream xÚĹÉ1 Â@б¦Éś¸»a­1‚[ZY•ZZ(Zo޶Gɶ 2΢]ŕŔ<ţź±óérAšrY;#«ébđŽ6uťj ç–ŐlŽj#WTnKĎÇ늪ܭȠŞčhHźĐUE‹€[îĹ7ł(S˙ô‹#“dť5"${‹ÝŔö?zn<×Ě‘9 ý~qípŹ%8} endstream endobj 616 0 obj << /Length 198 /Filter /FlateDecode >> stream xÚŤŹ1‚@Eżˇ ™†#0Đe‰V$Љ&ZY+µ´Đh+{4ŽÂ(- ă˛ŘÚĽâOćĎ›$ͦń„‡š“1'šOš®§6ŚşÄMŽš¤v§¤V6&U¬ů~{śIÍ7 Ö¤rŢkŽTä ď dR" "/x"oř­ß"x AŤa…Ě„ˇÉ,Ş ŞŇ˘~~Űć5˙˘µÍo×U9ôőú“ö¸qNČ©9I§‹Ręď Ý3´,hKí`• endstream endobj 617 0 obj << /Length 221 /Filter /FlateDecode >> stream xڭбnÂ0ŕßb¨t ŹŔ˝@›Yť"QČP‰Ntě@łóhyÁc×s U‡.•đđÉş“Ďżm˧ç ç<ćÇqÎÖ˛Íy[ĐŽlˇŐśË[kóIÓš˛w¶e ­SVżňţëđAŮtůÂZťńJ­©ž10ô€óU¤QĎ"-D×±×ÉŻ<Ś´ĂNmA…Q/Ŕ%n®:¨~ŰDG˙´şú9ir2ÝL¤y?ŮRÎ<ÚÂč[S|—é\ŽŽčłÝO§÷éżéOýeęŇĽ¦7úF©ŹW endstream endobj 618 0 obj << /Length 229 /Filter /FlateDecode >> stream xڭϱJAŕ?lq0Í=ÂÍ ÝÓ%Ä*#xE@+ I-SD´5_,9Č ,Ř9nś˝sck‘ćc™ů˙őŁáő_ńĹĄc?fďřą¤5yŻSÇŁ´Z®hZ‘}dďÉŢéśl5ç·×÷˛Óű.ÉÎř©d· jĆ0í rů ŔDŞČWŔ@ä`D$ Łć ˘“€˘FˇŹ]ç67@–üHš€¶łů·mňtçt9OYŞć»®‰®´Őwě–µ±gßąďß˙Ů«…če&ÚĄśOM«“&Ć˙ú7§ŰŠč`źŹß endstream endobj 619 0 obj << /Length 172 /Filter /FlateDecode >> stream xÚµÎ1 A ĐÔiĽ“832VÂş‚SZY•ZZ(ZĎXYzŹâĹ#lą…lĚŰXZäÁOř7荆d¨/ă9C;‹GtV˛ibsŘ0ó¨Wä,ę™lQű9ťO—=ęl1!Ůć´–Ę}NĐ)!0„ZĽ2ó-ygŽÉg"(.’0P5tĹ·ÔAUɲĺ+Yü0ţÉŔ\%ĺ-nľĘ§—ř¦YW endstream endobj 620 0 obj << /Length 218 /Filter /FlateDecode >> stream xÚMŽ1JÄ`…ßbÂÜ`w. ~7»hXW0…ŕVbµZ * vnâUr”aË!ă›,ÍÇđ˝™Ç”ëó«K-t­gQË -Ł>Gy—劲p3%űWŮÔtą’pK-ˇľÓĎŹŻ ›űkŤ¶úµx’z«X §™ý 33䎅Łr¤CF40Ś@:bŞ #µŕLÉ‚ĽŞÁ‰Yő.ąŠdÄŚ Çć›¶ĺAîČş ălBĽł–{,ŞZxËĎŽ`1K{Żď+ćoürSËN~±ˇo' endstream endobj 621 0 obj << /Length 160 /Filter /FlateDecode >> stream xÚ31Ół´P0P0RĐ5T01P05PH1ä*ä26 ą†™ä\.'O.ýpcs.} 0—ľ§ŻBIQi*—ľS€łď˘m¨`Ëĺé˘ŔŔĎň $ő˙˙˙?Ä˙ ` ŇÍ#…ř$`'0ö üřÄů ě  ć˙˙˙˙S˙dÖ.WO®@.’Ř] endstream endobj 622 0 obj << /Length 159 /Filter /FlateDecode >> stream xÚ31Ół´P0P0RĐ5T01U0¶TH1ä*ä21 (@e’sąś<ąôĂLڏô=€Â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ő˙`ř˙ů˙,dýF Éř}üH¤<´’ę00ügü˙żá?`¨G"í˙?’ü˙›˛Ě˙¸\=ąąkqt endstream endobj 623 0 obj << /Length 174 /Filter /FlateDecode >> stream xÚ31Ół´P0P0bScK…C®B.ßÄ1’sąś<ąôĂLڏô=€˘\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ő˙ě˙7ü˙ßP˙˙& ‘eüŔŔü€Jţ``ŔŔ$ŔČ? ü@˛†ż•´cg@%ĺ4*ÉßPF˛řF2?ü€F2~~€F2ü?€NÖ7 H{ ćrőä äóV endstream endobj 624 0 obj << /Length 195 /Filter /FlateDecode >> stream xÚuν Â@ đĄŹĐ> stream xÚmν Â0ŕCáˇ÷¦Ő(v©ŕAĐÉAśÔŃAѵͣŐ7Q|ÁĹAŚwݤéGr—»śé6ł&آßt°ťá&…=>'|äÍz z¦zBQĐvŠÇĂi z0b z„Ë“Řö˝óoUúł÷ YU¨X)Ő§Ź-ČŘ˝ČFĹFç'{»“őÇ…¬yVůJtlÉHź!˛rł&µué]ĹŠ;7ä­ŘRš“ąĚCSQń‹¦ iť¬ĘÓŔěw…HČÂŘÂ>Ęłh endstream endobj 626 0 obj << /Length 237 /Filter /FlateDecode >> stream xÚeαNĂ0ŕ‹2Dş%Źŕ{pŇŠ.±TŠD$: &ĘČ‚‰73âEňa+RĹ‘sÔĆ‚ÁßđźÎ÷—óăĹ)eTĐQ‘S9Ł“mr|IJŇŚćűŃÝ.kÔk* ÔCŽşľ¤ç§—{ÔË«3ĘQŻč&§ěëµl [f۲cv’ŚÓ¨‡¸h+ÂŢÄ켍÷ R PPĂ›Lm5éÄÄ5“ťwŰQ?Ú‹_"|Źv“ŻŢÖ‰&ÔŠ*ţZýł ÜIM ę]4ŢO©`9k”—ĺ b{0ý‘ýD>€Ř7ĆóŻńůík endstream endobj 627 0 obj << /Length 171 /Filter /FlateDecode >> stream xÚŤÎ1 Â@…á aŹŕśŔM@ Fp A+ ±RK EۉGó(Á2EČ:/u ‹ý—ŮýŠ™Í§éB"IěĚIR9Ç|c»#Ľ¦ÝÇéĘ…g··™Ýş«ßČăţĽ°+¶K‰Ů•r%:˛/%!Ô•ĄéI­DăŻeň±äoKő˛ĘhĐѰ±Śj#0#0Ł?Y¦` ¦` ¦`Š]ÚĐ“nS^yŢńĘiô endstream endobj 628 0 obj << /Length 218 /Filter /FlateDecode >> stream xÚĄ1n@E?˘@š†#ě\ ^ c)‘ěĘ…•*qé"QŇŽĆQ8%ĹŠő2[$rëćłŇţ˙~ţ¸y.9áśRÎ3.žř#ĄOĘÖcÂEé_Ţ/T·¤Źś•¤_Ü™tűĘß_?gŇő~Ë)é†O)'oÔ6Ś`ŮPv*;ťťk . ,¢ UŹPC< ”èzDNř‚ůĆe™{ŕĘććÓÎĄÍ˙Â]—É·’~+|ç˘ 2˘%‚˘ęĄE_†IÖqh×Ň®ţ xË endstream endobj 629 0 obj << /Length 143 /Filter /FlateDecode >> stream xÚ31Ół´P0P°bSs…C®B.crAÉą\Nž\úá Ć\ú@Q.}O_…’˘ŇT.}§gC.}…hCX.OćöĚĹň@lĹő˙``âz ţĂç¸˙C?’ľĆö˙˙˙¨‡ŕ?P ćsązrrěRZö endstream endobj 630 0 obj << /Length 232 /Filter /FlateDecode >> stream xÚmŽżNĂ0‡‘K·xe‹ź'´ 0Y*E"L ‰vdÁÚřŃú(~ŹŞwH‘`¸Oş»ďţ,»óë+ßř•ÄňÂŻ.ý¶ĄwZt’7šjăőŤÖ=…'żč(ÜI•Bď??ľvÖ7ľĄ°ńĎ­o^¨ßx¸#€Č `Î0Ě#,óŽyB=:F̧0¤AĚè.O€=ˇđĚ {Ĺ™sŘ2tâÝ÷ 9ČůF˘štJ´Łş:ZëTTwHsÍŞćT«U‹ůŹ!‹Ş,†)b"†)3ţÚČtŰÓ#}ťçwo endstream endobj 631 0 obj << /Length 239 /Filter /FlateDecode >> stream xÚMбNĂ@ `G"yÉĘv~ö%-aŠÔ‰ H0u@LбCQ»’¸nŃ館Ń?I}űL§ŻóýúeCú-˝”żc»%H0Ź0cŽRb†LčÝ5áÁh†¦šRă"Ě&\/d Ŕ/©„솄Ná^J¬+J™ŻĘx#jC˙(Ńďä^ť ‡NwŚÚ6d`âNůVř?‰1F3:=Şł0+¸(-Ş…¶ř aO"{|lńdy‚ endstream endobj 632 0 obj << /Length 196 /Filter /FlateDecode >> stream xÚ•Ď=‚@ŕ%$Ópć.ÄőŻ"AL¤0ŃĘÂX©Ą…F;ŤŁpJ ľŮÄĆŘ8“ý’ť7[¬™ŽsyŚc Of|ŽčF&di\%8])ÉHďŮ„¤×’Î6ü¸?/¤“í’#Ň)"Ź”Ą¬”×*ĄüîC Ä–(„\čÓ -p- đż*XJ …ąĐ pZŕZŕYjŕW °” ¶( ˝0 úáG(Yů“bŔ_íŰ/Đ*Ł˝:řp^ endstream endobj 633 0 obj << /Length 217 /Filter /FlateDecode >> stream xڭαŠÂ@ŕ‘Â4ű;/ ›ś„@NÁÂYY•ZZ(ÚšÄWŮGÉ#¤Lqě:ŁÂqĺ5_1ĂĚ˙÷ÓîxD1 ¨“P˙)í> stream xÚm1NÄ0E'risĎ v7,•Ąe‘HÄV ()@Đ&9šŹâ#¤L<| Q`ÉŻŹćżń¦9»ÜÉJ¶rZËć\¶ň\óŻQŢýĽ<˝ňľĺę^Ö W7(sŐŢĘÇűç Wű»+©ą:ČC-«GnBä"éLdT‰¬ę@.Ă«ęGH‹„F3ĺ”16’ 6P9¸€nü\ęŃŃ Pbfç4Ręu˘YůĄšHq_#őB}Č!Űĉ¨\0ćşĐgřÜś!TF¨ŮIŕěÍAŘCÉ$ŁyńDE‚Ě}Hâ#°‰A _·|äoť_« endstream endobj 635 0 obj << /Length 187 /Filter /FlateDecode >> stream xÚ•Í1 Â@Đ‹Ŕ49‚sÝ„$«@Śŕ‚VbĄ–Š‚•z´%GH™bQgqŇ80Żĺ˙ ‡qL…Ô÷) (ŃÎÇ#rô(Šë—íSŤjEAŚjĆgTzNçÓeŹ*]LČG•ŃÚ'o:Ł+đĽx*Á´P§dÜ‚éĺśHđá.ń'oÇÓśR(@RBľŃšü­)Ó`ëęÎňŰn±˙´a˙ţ —§—řöđ\# endstream endobj 636 0 obj << /Length 232 /Filter /FlateDecode >> stream xÚu=NĂ@…źĺ"Ň4>ÂÎ`mŮ ¦Z) HPQ *HI‚çh{”=‚KV†ń)‚ćóóľyÓlÎ/[.ąáłŠ›š×üRŃŐs±äu»tž_iŰ‘ŕş%ŁeňÝ-ĽîÉo﮸"żăÇŠË'ęvŚ\8I@/#2‘Ł–D°R9ÇL˘’Kp)°Lz ż€ěO±nPY†]D‘ 5Ĺ>ć˘Lr‘é>AáĘŤ¶»pgżW·łiŇŰ˙9Ô«ËÔo°0ËZTăţľj~]wtOßý endstream endobj 637 0 obj << /Length 261 /Filter /FlateDecode >> stream xÚmбJÄ@ŕ )ÓěyÍĹ»‹gµpž` Á«,ÄJ--m/ŰůZy”€/0`0ěřďh#„Żeg˙?‹ćä|%3YĘq-‹SYžÉcÍ/> stream xÚĺ•˝NĂ0Ç/ň`É~â€6EBb!`b@LŔČ‚µÉŁőQň3D6w社B‹ +•˘äç;űî\ßßĹQqxr즮ş™+fôLÝSa^MQhĆA6?ľłą™Ü94™ÉYĚd~íŢß>žÍäěćÜáđ…»Çyf~á€YđôÚ‹BhńµĎ`‘Čx:šB¨Š ]yrÎÔCĆT‘ˇô Ţc™ń¶čŇ‘ b“é– ň<§=^ÝN`.çćÖ|b5¸? endstream endobj 642 0 obj << /Length 356 /Filter /FlateDecode >> stream xÚµ“±NÄ0 †Su”%Źż´UÜM‘ŽC˘L č&`dÁJ»ńZÝxŤĽ7v¨0±“ö‚ÝDë«“Řţ˙(Ëę°>‚Žá ‚e 'K¸«ÔŁZÔ>YÂ"®Ü>¨UŁŠkXÔŞ8÷iU4đüôrŻŠŐĺ)TŞXĂMĺF5kBěEřrÄĎqJ{Âí´Ž82jtţŹŃřL6[GĺaŰŃ&>GQâŔ8P*‘Q̸ÇŚ«ĺś@츕I±˙-µŰ‹ˇ‘ˇI9ĆcĆ«‹H‹YrTAâr ČÎEńdm´§]ůÎąsGóí%e8ÚÝ„mŠŃIéÄ»?ŃîĂööÁ‹©[DşţŹsF]ľă {CÚôa°Ěë6˝$^˝ťmçC—ŤŢ#$ŁśůRśŕcř±X:-qwH•%Ű!Ă@B¨łF]©/Ŕľjé endstream endobj 643 0 obj << /Length 316 /Filter /FlateDecode >> stream xÚť’=NÄ0…ąäĆGČ\ň#ABeiY$R AE¶J ´ë=Ú%GHąEäÁ3vĽR„Ą$ź=ăycçuÍů%Tpg5´´WđR«wŐ6~±‚.FžßÔŞWĺ#´Ť*oý˛*ű;řüřzUĺęţjU®á©†jŁú5!2śŹqĎ€úć\Ś î몛^=¨oaf+š endstream endobj 644 0 obj << /Length 225 /Filter /FlateDecode >> stream xÚíÓ˝ Â0ŕH‡Â-}„ŢFPě˘ŕŘAĐÉAśÔŃAŃM¨ŹÖGé#t¬Xz&¦ŐŠČńĺ.!#Âő&:Ř’ÓmŁh8¸°WČ„s[«Ňr=ř ]|¤ŇŔ˝1îw‡5đޤŹ2=Ŕą<´o€Ě eč7f~ÁvÁVĺ˙˛ßmąm˘(·O”ä–M¦ĚFZ#:i›‘Üh[ëR¨m«îgî(GÚÇü%2Ć˲™ů*'/ľ«ëŤ'§Ú¬ÜéN>t\ąr™ŐWˇSWĹđĂĐ)\Snă endstream endobj 645 0 obj << /Length 323 /Filter /FlateDecode >> stream xÚí”ÁN„0†K8Ě…G`^@ˇŮ¬Ę‰d]9čÉŮ“zô Ńóňh<ŠŹŔ‘Ť„q:­¤¬l ńd"$íGŰůgčL«3}ĽÄ —x´X`~‚§gř áň Í«µvs÷O°*!˝Ĺ<ôŇL@Z^áëËŰ#¤«ësäď5ŢiĚ6P®Q…ÔŞ€ĹsB407ďŽCn:Ç17ä¸h˘Ú2÷…li×+V2Ş }´JEb̆<Ro™—"Ä\‰^%¬D˘ŢgceĢfÄçK7ÁÄ$÷‡#¦Is5‡ŐëżĆs˙wŹÜg?ŃAîĽ\w“yOFÜ őăjÉŻ«oµ÷U“•W«µWĂŤWŰ—vť‘ll dwMxŰDV9qgĘ0ŹÚCČĚŽdą¨6>áČąřçYl®-ąh~ÉpQ |Őŕ´ endstream endobj 646 0 obj << /Length 201 /Filter /FlateDecode >> stream xÚíŇ? ÂP đH!‹GhNŕkQZť˙€ťÄI]mŹćQz„'v(ý|ŻUĐMÁŃáă—’)a«ŮęŠ'm“ +aGÖ>ď8°˝g[[¬¶ÜŹXÍ%hł›)«h"‡ýqĂŞ?Ďj( _Ľ%GC!š\M€1.Jk@b­©µabuÓ8łöäCźj(ȅέ čĚŚýî5}x~÷–<­öoT "sż4ÎŚ‘›V:TIŻć_šýýť@ů9ËŁg|(4 endstream endobj 647 0 obj << /Length 218 /Filter /FlateDecode >> stream xÚíұ Â0€á”…[ú˝ĐäZś UÁ‚N⤎Š®ÚGóQ|ÇĄ±IEEP\Ľĺ ţš*D…-l¶ IupA°†0޶ ‰řlľ‚$9Á090{é·›Ýd2ę"ěá”PÍ íˇ˘ő|¨ó¦î ˝úĆěŐ÷:¬ËzlŔƬ®őµ™Bč7˝ľ÷÷ ě7ĆYÝElú(źÝ›~ôÍ҆’Ůä:srëŃÍmH'ďlĂĘý“ýÖGžąa/–\^ÎeVÇĐOa 0«   endstream endobj 648 0 obj << /Length 150 /Filter /FlateDecode >> stream xÚí˱ Â@ ŕ۲Ü#'đ.´V:Ô Ţ čä Nęč čě«ő‘|!¶—¬‚łôň‘?¤¦i1Ă€Töc^#Q'‚+TCňžoÇ 4 ü«üjčÁ§5ŢoŹ3řfł@ßâž0 µhúŘÎä8u˘F•E«:ő)ZŁč8ËüÍ·Ú‰/Ł˙ŁŁ˙cdÉŻÂ2Á>ţŔjj endstream endobj 649 0 obj << /Length 401 /Filter /FlateDecode >> stream xÚŤÓżNĂ0pG,yń#ŘO@šV¨t˛TŠD$02€`Ĺ}´<ŠÁه¨ć|ľ#寨Tő;ßwVÚ®úŁĹ±ťŮĽOć¶ďöľWOj9‡…^—­»GµŢŞîÚ.çŞ;/ËŞŰ^Ř—ç×Ő­/OmŻşŤ˝éíěVm7VaňN”W“óĐ9×%đ‰{mAĆ[ –§˛ŕŢPnKBř] ŽP‡Ý{ŃŚµS´°+$tËX»ęÜ Č3TD'đ9::Jr‰ŕ÷«GŹÇD u†"~Fţů?x,<„á€úˇPîéń5©Ż‚™0~CŞpb…ź*ň„żÄŹołî´h¦äQš'h.6Ü稰㙂FQMĂé†Ó-§%§5§ …„ŁŮÂ'FäâŔ};îŁÉiÍiĂiWŇ®ÔÎFŠÓoĐ7d"čH0ŕ‚ÇCě©Pkmť=ŠÓđű– :ĄÁ > stream xÚ…”˝NĂ0Çyä%Źż¤ˇ´…)R)`b@LŔČ‚9}4?J!c†*ć>ě Ąˇx~Îť˙ľ;ź}YžÎvfWöäĚ^śŰ˛śŰ—ŇĽ›ŐţÎ`ľ`Űó›Yצx°«Ą)nđż)ę[űůńőjŠőÝ•-M±±ŹĄť=™zc•RÚ÷ŠGă˝#ĐŢűQäŁ1ÁÔřŽÜ8 c:ŕ >*±„–T-úâ’ĆŃz$V úŞ d­ „Ds )iMňLC ”äs3eÓö¨ő€´(ÇÝ*F $*ÎŤ(U!fŐ$uRŕ‘Ú@±ć?(ˇŔ#„# G·ČD8ą&Š(YŞăRĐí"7 AŚ˝P3‘ŽŘSÎ$Ť±‹ŮGrRŤVBíDfLdLnLŘ–í‘› Vr9NÝé!RFŰ q‰‘8$>Ů}â2ţKíoŇÓä|¸tŢĹëç·ÜG)‘ Ş(R˘A…ÎÎ{ˇV…Ţͺاé.ö)狪|/©¸—ąň,Â-ßđÝLJ!&ßFŢ |AúŘŕńXBçšëÚÜ›o-Łq endstream endobj 651 0 obj << /Length 280 /Filter /FlateDecode >> stream xÚÝŇ;NÄ0Љ\DzŤ—`Ż€ÄâŁPY‰HPQ * ¤A‡ť ; ;ş …„X“{› ˘ăY‘ŽťâúóŽÝŢţˇÍmüŠ#ëÜ˝sň(EnăóřëöA–ĄdW¶Č%;‹Ë’•çöůéĺ^˛ĺʼnu’­ěµłůŤ”+»ŘVX †]%”˘ŇiĘĚČSv•PjF)Ą)3#O…}A Ą>©(Ąô;dިWČS»Ż¨J:HµÔJ)ÝPkČPľ†甆z(é¨RTştC­!CůšâËTTŤaP )j h ›d¨1 bާ:(†mĄ¨6©4Ă&Őg×ާ†?ÔŹ]ü?¤yĘ_JNKą”o§bg endstream endobj 652 0 obj << /Length 381 /Filter /FlateDecode >> stream xÚŐÓMJÄ0ŕH…lz„ćÚi‡aăv!čĘĹ ęŇ…˘ŕ*íŃz”ˇË,Jâ÷“ČŕČ K»zšţĐď}›Uu2_č™^éăZźÖşŞćú±R/jYĂę Î|íáY­UŢęe­ĘK\WesĄß^ßźTąľ>ו*7z[éŮťj6ZÜ <Ž:ńAČ:Ń `Ŕ+ŕ"8‘… xř=L .aLčşá\ÂĐEŕ-—Đ#¬á+ şŹ˙I …SđěVĆQm‡·ĆĂŘ0Ł…V śŢÂYFńBč’wXV€ď R0%ꋌĺ¶đ<Á,cg‚Zřë |ő7¸=LŚüřż üŇEä>˘†ę´ôcě‚=ý.`dŞCh§K;FŽSżPô1g|^>$ĐSđłgŽ!äD;Ď ‰“JnC¨Öń3rę}äŢD«ĽÜs^YÜ‹đoÁť=S„© ©YCyŞ‹FݨOĘr endstream endobj 653 0 obj << /Length 423 /Filter /FlateDecode >> stream xÚ­Ô˝NĂ0ŕD"yÉ#Ä/i(maŠTŠD$02€`%~´<Šxěĺ¸;)** ѡúâŘgçěóaą;žč‘žéť=}°ŻËr¬oJuŻfSláóDŢ]ß©ůRz6UĹ µ«byŞžnU1?;ŇĄ*ú˛ÔŁ+µ\č~uÉ/hD5€c$І—¬ l †vm¸Ű Ű-*üĎhpN}RǨˊâvô‚ÄQić†ĆôĐś,’PôŚV”’ň5/ĚŞuA°)ŽŽ‘[/š<ńrňÁb_Vn‚8ßÉyĺ[UýZ6 ;`qĽő’M@Ń~VО¬x·P•áŹÁĎ’T+iB9IŔ‹•ÄĽZI6Ş‘ x3˛ź¨HöŕŁ×;«Cu|ŔŻí‹ĚşV˘Ć«ţ*ç?öĎrjÉÚż©úAnCů6ŮAŮVĄAMÚg- 2â5…ÜGţ µŔ}XRĄäëČů*ËŔ)5®ĆŠşđt\`—PçéË€Žź,śŽ¤Ü qYĐUŇö×K8ÝŇ¤Ž—ę\}©,ç` endstream endobj 657 0 obj << /Length 226 /Filter /FlateDecode >> stream xÚŤŃÁJÄ0ŕ„‚…AčŐĐy“˛mOB­`ÂîÉ,,¨GAEÁ›>ZĄŹĐŁ!¦ů+RŠCÂG’™$$§ĹÉşbÍ+ßMĹg%ßôLĆř±†ĂÂÝ#Ő–Ô CęĘĎ’˛×üúňö@ŞŢ\pAŞáŰ‚őŽlĂÂG*Bäźsŕ¤.ĚeßČč˛/ĐŠ… ŃĆߤďţ°d] ‰@̲_@čEÄž"ú€iŔąƵß̱n˛™žp0Ç!n˝Ä18Š(#Ţ#zĽ H@ ňĐă;şş´´ĄíWŁ" endstream endobj 658 0 obj << /Length 198 /Filter /FlateDecode >> stream xÚť± Â0Eoq(ĽĄPßhŇ‹…âP+ŘAĐÉAśÔQPQčŕĐOë§ô}i,:IΔäÝÜ“h4 bÖśđ 9ŇŹyĐ™BÍf%ÝŃîHYAj͡&5—}RĹ‚Ż—ŰT¶śr@*çMŔzKE΀N@§FŻ‚ x€¤-%đ08ŤˇW\ˇ‚gú-21éąű’ôü‹ňWZúńśßu2¶•Ôsëw[ŰÜZ,ëĺ··EV”E\ôÍ'hš´˘búD[ endstream endobj 659 0 obj << /Length 199 /Filter /FlateDecode >> stream xÚťO ‚@‡âBx ˝@Ř»@ŤN(Ń rÔŞE´Ş–AEAKŹćQ<‚Gh|*A´ŠůVóţĚ÷›I4c8â‘Ö¬cŽ>…t#ps¦}éxˇ4'µcZ™{Růš÷ç™TşYpH*ă}ČÁňŚK ®@ đ§€]6X¦V /a&Ě ¦Ű+ĚŚSv4ĂŐ7f—U˙Eőc›]~žsŠÎÁë­|‘lm[sIaU].Gz]‰śH|Ô|-sÚŇcŐL endstream endobj 660 0 obj << /Length 103 /Filter /FlateDecode >> stream xÚ32Ő34R0P°PĐ52V02Q0łPH1ä*ä24Š(XBĄ’sąś<ąôĂ Mąô=€â\úžľ %EĄ©\úNÎ @ľ‹B´ˇ‚A,—§‹Â˙˙˙ýaJäb.WO®@.Ťˇp endstream endobj 661 0 obj << /Length 103 /Filter /FlateDecode >> stream xÚ32Ő34R0P0TĐ52V04W0łPH1ä*ä24Š(XBĄ’sąś<ąôĂ Mąô=€â\úžľ %EĄ©\úNÎ @ľ‹B´ˇ‚A,—§‹Â˙˙˙1Ô %r1—«'W ń–E3 endstream endobj 662 0 obj << /Length 133 /Filter /FlateDecode >> stream xÚ=É1 Â@EŃ?â ¦x+pć'c#8… •EµT´Î,mv¦ ‚śîŢ|>Óśž‹’şdYđ˘x@=ůâwÎ7Ôî@őp›>Ă…-_Ď÷®Ţ­¨p [Ą?"4´ŇÉ'öŇ K6ÉźI&šĹLĆ2’©LÄJ%w9 Ö{|ɉ$_ endstream endobj 663 0 obj << /Length 132 /Filter /FlateDecode >> stream xÚ=ɱ Â0…á ń :śĐäÄt­Ě čä Ať›GË›i "ßö˙~1WOÇŔ™jĹŠ•‡¨ăŔ/ç|“:Š=PťŘMßĹĆ-_Ď÷Ul˝[QĹ6<*]+±a‰źÔË.—&›dR‘ Ś1”¸ăYGŮËáĂ$‰ endstream endobj 664 0 obj << /Length 95 /Filter /FlateDecode >> stream xÚ32Ő34R0P°bC K…C®B.K Ďȉ&çr9yré‡+Xré{€O_…’˘ŇT.}§gC.}…hCX.O†z†˙ 0XĎ ĂŔĺęÉČ[žx endstream endobj 665 0 obj << /Length 161 /Filter /FlateDecode >> stream xÚ31Ő3R0P0UĐ52V01P0łPH1ä*ä26Š(XBĄ’sąś<ąôĂŚM¸ô=€â\úžľ %EĄ©\úNÎ @ľ‹B´ˇ‚A,—§‹€Ś`˘F0 $;`| ‚NČ€ 8a" ŕDHł ÍF2-Cµ‘XËđŰH¤eh6’išŤx-cŕrőä äE-¶ endstream endobj 666 0 obj << /Length 102 /Filter /FlateDecode >> stream xÚ32Ő34R0P°bC cK…C®B.K ×ĉ'çr9yré‡+Xré{ąô=}JŠJSąôťś ąô]˘  bą<]dęţ7Ŕ`= ńS/—«'W ä" endstream endobj 667 0 obj << /Length 142 /Filter /FlateDecode >> stream xÚ32Ő34R0P°PĐ5´P0´T0¶TH1ä*ä24PASs¨Tr.—“'—~¸‚ˇ—ľPśKßÓWˇ¤¨4•Kß)ŔYÁKßE!ÚPÁ –ËÓEA†ˇžá Ö3Č0ŕz€`ý™ pČx€±±ą™ťŤŹ¨Ú‚ˇ€!ËŐ“+ ć|-s endstream endobj 668 0 obj << /Length 94 /Filter /FlateDecode >> stream xÚMÉ»@@EŃţ|Ĺůwî˝Gb •BT(„ß÷H4’]­í]˘)•šŃÍ8+6Ń1|cZ‘GHOóšűą@ň¶ BJJ7"–ĽďëŞĚŇ Ś endstream endobj 669 0 obj << /Length 91 /Filter /FlateDecode >> stream xÚ31Ő3R0B#cS#S…C®B. D"9—ËÉ“K?\ÁÄ„KßCÁKßÓWˇ¤¨4•Kß)ŔYÁKßE!ÚPÁ –ËÓEá?|€\®ž\\KŘF endstream endobj 670 0 obj << /Length 125 /Filter /FlateDecode >> stream xÚ31Ő3R0P°T06T06S03QH1ä*ä22 (Cd’sąś<ąôÌ̸ô=€Â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. v ň ő ö üżˇţŚŤ×1Č7€ôÂ2 |±—«'W ¤(Ş endstream endobj 671 0 obj << /Length 177 /Filter /FlateDecode >> stream xÚ35Đ32U0P0b 3…C®B.3 ßÄI$çr9yré‡+qé{Eąô=}JŠJSąôťś ąô]˘*cą<]˙1ü˙@ňăĆ  ědř0Ô%€Šěd=¬“˙Ŕ䪓 “u ˙ŕ ‡ÚőŞfh‘ Ç˙g¨˙˙Ăţ˙d’ËŐ“+ =Ĺ€ú endstream endobj 672 0 obj << /Length 181 /Filter /FlateDecode >> stream xÚű Â@ †˙ĂAČâ Íx­xUp(Ô vtr'utPtműh}”ľ‚Ű bĽÓI÷bHř’ü á`sČ‘ 3áxćÎd|/ôĄö'JsŇ61é…ë’Η|˝ÜޤÓŐŚ#ŇoÝäŽňŚŽ ×ÔĄž¸Ű>”Ĺ´)ĐmPÖN®•8•’J@ ĺ…GáÖĽă—· y[őŤöĎţĘ˝V€Rl"ňšç´¦«›–Ź endstream endobj 673 0 obj << /Length 157 /Filter /FlateDecode >> stream xÚ35Đ32U0P0b 3…C®B.3 ßÄI$çr9yré‡+qé{Eąô=}JŠJSąôťś ąô]˘*cą<]˙3ü˙w@ň20ţ‘ě$˙)ß"í@d=¬©e€0ţPźü˙PHZŘBOh˙ę˙˙°˙˙™ärőä ä5 †˘ endstream endobj 674 0 obj << /Length 194 /Filter /FlateDecode >> stream xÚŤÍ= Â@ŕR¦É„Ě Üü¨(‚?` A+ µT,D=ZŽâ,S„ÄÄFľbć˝Ý­…ŐFK}­SÔÔFM×ě% 9űĺX«­ôb13ŤB1#nĹÄc=N1˝I_1ťę/$(ş)P°/qá<+°Ň&¬läKş·śŠ/Wjó&Řył2ŔćcÎpt> stream xÚmĐ˝jĂ0Ŕń†ŽPŻÖÔ6%ÎhHS¨‡B;e(…Bұôd¶!C_Ë[ÇľBÁنâ«NW¨d,,~ř„଩ĺĹrˇ3}iw±ŕo—ă;ąýw>ŘľŕŞÂtŁ‹Ó;Ĺ´şŐűŹĂ3¦«»+m§ký`Ż> stream xÚ•Ń˝ Â@ ŕĹG0op­z'A+ŘAĐÉAśÔŃAŃŮ>ZĄŹĐѡܙ^2TčŇÂń‘´Í—Ě)˘» dJ×h-ÇQ6/.w\ehŽd-š-gŃd;z=ß74«ýšb4)ťbŠÎĄäů©|!T0ćě'‡ˇ €ř4, ˇ L”*0Vľ}©ÚU´¦vĐ~ÚÝ·'ăżCľdxxJůDv×5Ľvřw¤Ôá?®/u»Ňą­®ů “ |.ŔÉuÔB)ŕ&ĂţĂ)©˛ endstream endobj 677 0 obj << /Length 269 /Filter /FlateDecode >> stream xÚµ‘żJÄ@‡!E`¤µ8ĽyÝäH˘E pž` A+ µT,ÉŁĺQň)-–[ww"°µúŘ™eţ|SÇ›NąŕŁ —)—9?fôJEnöYJćá™¶ ©.rR6LŞąä÷·Ź'RŰ«3ÎHíř6ăôŽš¨'Ä@höXkcz‹nL† 0¦ˇ>[DPi¬G Ѩ Ňčz¸ĽC°·t`˙:D_íŚdr¨f¸ZŔjF=cř…¸ű˝Ě?`.-Ť°l[/áÇŤ;Čb?ĄO©y=÷^FŻ.Dd/Z{‘ ŻüĐ FĺF\ÝnŚ\3w*Čá gť7tMßVXvˇ endstream endobj 678 0 obj << /Length 211 /Filter /FlateDecode >> stream xÚµŃ1‚0ŕ’·pŢ lAÓĉ1‘ÁD'㤎ťéŃzŽŔČ@Ŕ–“j “%ÍĘĐÇ˙óĹ”ĹČp¦6ź#ŹńÁ 8Cý¨Wýát…4şG΀®Ő)Đ|Źűó4Ý.1šá!Bv„<ĂN­†˘í„µÔ’„µ˛ÄkŤ¤ł&ÂJcPýĘčŐĆIăJZkg-…1”?,ŤáŐźąwďknáţçŰŹ\Z7Ż!GßŘ|C›w"ť^úžlo}Ź•Ű«îV9ěŕůŞ˘ endstream endobj 679 0 obj << /Length 193 /Filter /FlateDecode >> stream xÚ}ѱ Â0Đ”‚…Cpuz_`5Ĺ®µ‚ťDÔQPQpÓOóSú ůšć*Rr<.—„‹äpŁŔ± c4ÂŁ„+(erQ¦eáp†$ľAĄ€/Ě*đl‰÷Űă> stream xÚ3µĐł´P0P0bSS3#…C®B.SC ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś€˘. Ń@-±\ž. ˙Á •bř€HŐ700ŘC(ů`ŠB1ŁPŚŘ(|Te€ťbŔ¤ P¨`ŠB±©˙˙±PP9J¨>4Ă ¦čBý&!^@Ą¸\=ąą6‡ŕ endstream endobj 681 0 obj << /Length 268 /Filter /FlateDecode >> stream xÚµŃÍJÄ0ŕ) ĂB_`ˇóšV4*ë ö čÉxRŹ…ôŃú(}„=”ĆÉ”¬aÁŁiá Ićç¬:ş¨©˘S:<&­IźĐsŤo¨+ źČÍÓ+nZT÷¤+T×|ŚŞ˝ˇŹ÷ĎT›ŰKŞQmé=b»%0VĚźaÍ–Ţ÷A;CĂzČ\Ç×Ŕ›;€†÷ĺP°fŕ3ÖöËb6łŮ~^“\óď`·łpÁfg śGÔD‡ÔŘżěA–˙GąCÎF‡_ˇ—<¸Xłď¸Xî)u'J_Ąo±ź‰±ĎRpžĚ!Î%XOË›óNć.ĚÓş|ŚsŽs—eB xŐâţ&Ź3 endstream endobj 682 0 obj << /Length 130 /Filter /FlateDecode >> stream xÚ33×37U0P0b3S3#…C®B.3C ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś€˘. Ń@-±\ž. ˙˙˙? ˙˙˙tšá˙ů ő ü†0 ôŃlôP÷o¸â•ËŐ“+ _ݶ* endstream endobj 683 0 obj << /Length 106 /Filter /FlateDecode >> stream xÚ36Ň33V0Pc3#…C®B.#3 ĚI$çr9yré‡+™qé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţ˙˙†˙?``¨o–ä7dżrązrrđéaž endstream endobj 684 0 obj << /Length 170 /Filter /FlateDecode >> stream xÚÝĐ1 Â@Đ‘ßä‚˙şŮě’Řb·´˛Vj§ ˘­ÉŃö(Á2…¸n°±đ6Ż)F§#­9fĹĂ„µä4á­¤©Ě‡1§úÓlT+V‰™ŹI9_Î׉b1aI˘äJrĽ&S2"çÚ/:˝×’wÔŤÇŮ_O¸ĆS#h±GŘâđ1˘;úXDČöćçş§[€¦†–ôÍüeß endstream endobj 685 0 obj << /Length 266 /Filter /FlateDecode >> stream xÚ]Ń;NÄ0ŕ‰RDšb}•âRŘnĄe‘H˘J$@P'b;NŔA(s®#¤Lí`Ź$˛…ýÉŹńŘž“ü¨¬lnŹ]«*[•öľŕgvć~¦Ô…»GŢÔś]»1gçÚ×öőĺíłÍĺ©-8ŰÚ›Âć·\o­tdd<”KKMKMaŚ;Ř .ŕ®ŕŚş óú0ď.á >Á>¨áN w&Đ`>…kěo† ßFőc7©»$řďŐŻHÔo8č={jpď?53ćšďšćj˙~™« ĽM7wŤö˙× uIö»}ÝRiµŽ"Óˇ|Vó˙đ Ą! endstream endobj 686 0 obj << /Length 144 /Filter /FlateDecode >> stream xÚ35Ó3±P0P0bS#3#…C®B.° ’HÎĺrňäŇW0±ŕŇ÷Šré{ú*”•¦ré;8+ré»(D*Äryş(ü˙˙˙2Éđ˙`¨o^$3^’L˛á ů0H9$ŇLÖÉ ’ńd˙Ăđ˙ýź˙ €Brązrrŕ3nX endstream endobj 687 0 obj << /Length 252 /Filter /FlateDecode >> stream xÚ}ŇÁj1ŕ . ‚Wo;OĐěZX÷¶ ş‡B{ň ‹-=•ŇŇŢ îřJűľ‚ŹŁŮt˛(Ú„$á›Â™btUd”Ň5ď"Ą|DĎ~ŕ8çľkÍĹę 'Ę9Ťs”·|ОşŁŻĎű)e(g´ŕg±š‘Ö5đJ´Ňş1*/G)€÷ť‘©g˝*Ł­G«=ClţééŔŠ-[VĎŇšŐ÷ŞäřCŻŽźZ —ă7–˘=Ú+q€,A ˝€ÖĐwTÖĂ€’&u4Ř-ŠUă(ú­qhKę$ÁźúÓ)n;%<.<2“™!WxSáţóí˝č endstream endobj 688 0 obj << /Length 250 /Filter /FlateDecode >> stream xÚ]ѱJÄ@ŕ )Óä˛O`ĺöĘŔy‚)­,DPN±:NEÁn}$!Ź’GŘr‹q63ͦXľ™Yößběöl»1Ťąŕc7Ćž›—?жÜ7±Ť‡#îz¬ďŤm±ľć)ÖýŤůúü~Ĺzw{ixş7üäű˝!úpu\Çćĵ€ ŕŘ–khŢÔì’ř¬>Ĺŕ¨R»Q¬|jÄbJÍg1ŁTŕ9XĹNĺ`1ĄĘÁâ,ć*/rpŞÄnL­ĽX†Ôbó95#čOő˘S»••ZŞĹĘśŤëÉ> stream xÚµ’±nÂ0†1Dş%ŹŔ˝8AMP¦H@Ąf¨ÔN SËČ‚•äŃň(yĆ (éÝ96¨c-Ůźí˙ź˙Ë"šÍ3Š(ˇéśŇ„Ňú‰ń€‰lF”¦VůŢă˛@łˇ$CóĆŰhŠw:Ď;4ËŹĹhÖôS´ĹbMĐ7 -čoĘĽ.+aˇŁĆW‘y!a paN8(Űe~´NŘŔHb+Ś[&Ž|‹EG˝M”ýťµ°äl”Ő#KË!×ü‰˝eó_ô÷ą<ţ ĎŰľ«zzçŔPýč<őëv÷Oýl˝ŻÎg¶Ô¬Ľ˛ÝŐE´ÎĆęWGWWď•«»ýđµŔOü˘}ź endstream endobj 690 0 obj << /Length 175 /Filter /FlateDecode >> stream xÚ33Ô3±T0P0bS33#…C®B.S# ßÄI$çr9yré‡+qé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţÁőJŇě˘ő ě?Ŕă?0ĹđBŐC©0e™’€B} “B1Ő¨µPG@\ĆüŮąö€Đ+ ` (V9„(P$€ŁăĹĺęÉČţ†ý endstream endobj 691 0 obj << /Length 330 /Filter /FlateDecode >> stream xÚµŃAK…@ŕY–Čk‡ŔůĄ>ňĺ; Żä!¨S‡‚ęTÔő)ôÇú#B@č"$n;ł*ĺŁc‚~˛3«ł3GŃÁl&¸§8Op~w±zR ­FÎúĐíZć*ĽÄdˇÂS»®Âü _ž_ďU¸ÁŁŻ’{Fó\Ýnhî†óá©G9SV‚µt6źJ´ľÓ_‚qÝ- 8;gÖ4NŻu’« ő übĽi endstream endobj 692 0 obj << /Length 230 /Filter /FlateDecode >> stream xÚťŃÍ ‚@đ• azŔyZÍÚşf‡ N˘Su *꬏ćŁě#xô Ů~i—HźŚňwf–±ţČC}ě Ť‘ đŕÁ/Š.˛ˇ~ł?AÝ ó.Dh´ÄŰő~¬fč q+‚v…XŠ+%„H c™Č‡”Ä\'¤“i…ÖzhIi|ÝÓ´&×:/ł?ĺŐĽw~RýżéÇ2}6rÓż™CÍë9Ą91uŁŚýüŢÎŞ9őůżöđłÉż6µ©6ţ˛-ĎM쩥ŽŐá]e'›(íü,G%VÉ•b0Ź` Ox1­Đ endstream endobj 693 0 obj << /Length 266 /Filter /FlateDecode >> stream xÚeĎ˝JÄ@đH±°MÚ«Ěľ€ćrw ąĆŔy‚)­,ÄJ--…á’GËŁě#¬Ý‚ËŤ39TÔćWĚ÷ó“Enć¦0Ç ł*Lą2ą~ÖË5ç¦,™ű'˝itvc–kť]pXgÍĄy}y{ÔŮćęĚä:Űš[t§›­ ˇ¦ˇ‘­˘ű6včZ5âČ'źĘ×@ěOČďč6ü˘úaĎĚ&č›~`űQ°Líɤ䀄hÂADDÜND×Đ(Anę%ĺčĄ=٨„Xö˛ç» űźÎ}d ň*ʉß;ľAŮ‹d|÷Hף‡MůH+§Śň“>oôµţ ß„k endstream endobj 694 0 obj << /Length 158 /Filter /FlateDecode >> stream xÚ33Ő32W0P0b3#J1ä*ä2µňÁ" ‰ä\.'O.ýpS .} (—ľ§ŻBIQi*—ľS€ł‚!—ľ‹B´ˇ‚A,—§‹‚ý0`Ŕ 0ü?Ŕ¤ę€d–o¨Óü `š˝ˇL3cĐ `š‘ }L3 D3@h†Q'ý˙bü˙D±cń&ÍĺęÉČ@ endstream endobj 695 0 obj << /Length 207 /Filter /FlateDecode >> stream xÚíŃÁJĂ@ŕ?äPy„Ě č&±Ů^!Ť`B=őP„BŰcAEÁ[|4ĄŹc’őźZ/9öěaů–vgaÇĎ®fĄfz­—…úR}ˇŰ\^Äç 3őÓßĘf/U#n©>wĎX\ó oŻď;qŐb®Lk]ńΓ4µ†ľĐ†~,â´źľO~śĚţ=×[ó™ň±yR“+ĺ>˘ÉźçÁ»:ᑸgF#Îć‚bnĚö8&kufŇY f°§0AjeąkäQ~­uI endstream endobj 696 0 obj << /Length 262 /Filter /FlateDecode >> stream xÚmбJA€áY‚iS™ĐÝ»č¦ Ä^!he!B@-­s >Ó=€`yŹňŠăÖ™]áöŽT;3ĹĎÚĺéňś et’‘µd3zJń 킇†ěYŘ<ľŕ:G}GvúŠÇ¨ókúx˙|F˝ľą ő†îS2oČą qíĐÄ•°«”+ŘyD˙>â•8‰”űc€•8c«ŕ\4‘{ö`*n;Ç5[F6Á„UE¤ô±Jäĺ‚8ęYH¦śÄrŕ¬gä@Ós/™>pë­Xöl”7i$ŻSµ>«ÓÁŤ~w_˙ţWżë ˙ÁČiuŘqyؤÄËońČmµ endstream endobj 697 0 obj << /Length 321 /Filter /FlateDecode >> stream xÚuŇĎKĂ0Ŕń+„aŻ;ą÷h Ł;ć{ôäA„Š'aŠ‚·Ć˙,°¤7ŻőVˇ4ľĽNˇíz|Hř&é">NN1ÄŹb\D8Źń!’/2Ih2ÄůIóĺţY.SÜ`’Čŕ‚¦e^âŰëűŁ –WgÉ`…·†w2]ˇµ5(kµ°v?=k@Ř@•# ™đsńGĎ0q¤áźĐ˘ĺ´–¶ě8n“Ö©‚©vś´I벒é¶<§=~ULź¶l‰a—b[3˝Ä'qݧeŽ*Ş&š!ŠšR3-ô -Ą*C7â.‚ ę)E{ŽsÜĄ )š©“.ó ř%s–Ż©Úc^Ĺô Cýa—ßÄšéýhę_ďŁeňŰÓŻ0H:}ó¦¬\4Đeé˘~Đ8ěqCă ˇ«vg—穼–żßíąô endstream endobj 698 0 obj << /Length 251 /Filter /FlateDecode >> stream xÚÝĎ1KĂ@đ-úťźfßÝ€,bĽ?ÄßÉBčţ_T|Ăż%t_ endstream endobj 699 0 obj << /Length 232 /Filter /FlateDecode >> stream xڅбJA…᳤Ü&m:ď8»1+[b·´˛APËŔFě’GŰGń¦´ŚsĎš]­Ź™)~.S–Çł͵´]čéLź ŮČÜîą]íđ¸–e-îV祸Ëô*®ľŇ×—·gqËës-Ä­ô®Đü^ę•úVřăđ>ĐضćY2î@ŃYŁ=Ţ“_h€1ť|> stream xÚmÎżŠÂ@đ/,âö„ťĐÍĘÚ ţShuĹq•ZZ(Úš<Ź$y”<–!q÷î,äŽĚ ó1v<qĆ–†í­á­ˇŮŚcŮŃĎfł§iNúmFzƤów>Ď;ŇÓŐŚ é9Îľ(ź3”Đ5€¨ !+ô‘ÖP®LîpšW.Pe@"€QměęÚ˘Ľ iÂ"őń¬Ž1ĹĹ”âü"Ú?´O’VHnq®LUOUoę*ýD6˘ói|UÔ´ČiMעLě endstream endobj 701 0 obj << /Length 210 /Filter /FlateDecode >> stream xڽн Â@ đ„B–>Bózm=ë(řvtr'utPś¤ŹvľIÁč¤KëőŞ: Ţđ’#ů“–Űđ=vŮçşÇ˛ÍA“—mHJ]t9Ug±¦nHbĘR’ę2‰pÄ»í~E˘;î±G˘Ď3=hNaź1ýŠ/kF˲܉©S”lx‹­đ騫`pĚ:F§l˝TĄveü¶V™ü`ü9ó©zďŐŞTąńbr^MćłÉRV ¨R'Ś:ąąq@&ô™x endstream endobj 702 0 obj << /Length 193 /Filter /FlateDecode >> stream xÚťŹ1 Â@E˙00MnĚtłf‹t¨` A+ ±RK E;19Ú%G°´uÖ`akóŠ?ţü±éŔäśrĆ}ĂYÎÖđÖĐ2+bĘvŘM6{*+ŇKÎ,é©Č¤«źŽçér>bCzĚ+Ă險1C˝DŻ(p.ˇîÜ lQ4‘CÝ!iľ(Ľ]Ł–őWŹç¨!ÉpE#kĘ%Ę7)ô©Öó%cŕ\Üęć_p€’0šT´ 7ę8>Ě endstream endobj 703 0 obj << /Length 210 /Filter /FlateDecode >> stream xÚ˝Î= Â@ŕ )’sÝĬ˘…üSZY•ZZD´“o¦7Ńh—B\gw±J)Ř|ĹĚđ浂F3¤€"އ$;ÔŽhbŠRň0 ¶´›Őű Š9I‰bĚcÉ„ö»ĂE: Ĺ´ÄdHŕ ¨’žŃ5:˙Pi=ueků“=B·Đ«jîüĽ›nĺ_t+k-×±ŐäśJfĆ÷fĄLűËţĺîWn噞ľé\yé§Ľ Uť;ë«3ëĽy…ŁgřŁĐz? endstream endobj 704 0 obj << /Length 204 /Filter /FlateDecode >> stream xÚuÎż Â0đ/t(Ü`_@轀¦±:YđŘAĐÉAśÔŃAŃMj-Źâ#8vëiQp0?¸K¸|6隌Nąc8ÍŘŢÚSje°í57ë Ň N-鉌IS>N[ŇŮ é/ '+*FŚŕ ®P†W R7HU®8#ôč#ňČ;Äo\ކČ]>řňËăK-§AZŕ/ĺ‹Ë/˛>—L^ľT^('N"†nhAUhwdňZ#Ş= d#Ť šÓr!Iš endstream endobj 705 0 obj << /Length 143 /Filter /FlateDecode >> stream xÚ32×33V0P0bcc3…C®B.cßÄ1’sąś<ąôĂŚ ąô=€˘\úžľ %EĄ©\úNÎ @Q…h ĘX.Oů ˙?00°``?đ‡żń<Ű3ţc°â:fř„ äâ˙˙˙Ă1%ćP}ĂP˙˙sązrr›_Ż endstream endobj 706 0 obj << /Length 261 /Filter /FlateDecode >> stream xÚ•=NÄ0…_äÂŇ4>B|ČŹĺ®´,) ˘@T@I‚íşŁäF('ŕ 9e k͇b (H˘/öřÍË›tG‡­Ż}ëÚÚwťď×ČŁđ]ó>n~ŽndŐKuETg¬KŐźűç§—{©V'žűµżfÓŤôk^ŔÄ".Ů·€…ýtŃDŠ©\0_fÄ+`G•Ďt–˙á~ďě¦Î€~…ŚÜˇř°ëďLcx«cŘă ¤§2%őIi—™(ئ4ćő¤ĘrB8±F‹ü†+ĺ ňOƬ™ő›Ü«>Q=9'ĺ|¸ ůVĹ)ćX,Či/—ň mh endstream endobj 707 0 obj << /Length 165 /Filter /FlateDecode >> stream xÚ35Đ32T0P0b 3c…C®B.S ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś ąô]˘ĆÄryş(0ţ`‚˙$;d“Śt"™˙€Hţ˙ @҆˙üŔü€ńçć Śż€Ę3ţg`řĂŔř‰üDţ\$3Ř‘˙˙¨˙˙™ärőä 䄆y endstream endobj 708 0 obj << /Length 124 /Filter /FlateDecode >> stream xÚ32Ő34R0Pc#3C…C®B.CK ßÄI$çr9yré‡+Zré{Eąô=}JŠJSąôťś€|…hCX.OĆ ěř   PśŔřˇ†Ř00˙‰Đ1˙ař˙˙qązrrŢÉHT endstream endobj 709 0 obj << /Length 150 /Filter /FlateDecode >> stream xÚ32×33V0PĐ5QĐ5´T02P03TH1ä*ä2 (XŔĺ’sąś<ąôĂŚŚąô=€\úžľ %EĄ©\úNÎ †\ú. ц ±\ž.  Ś˙ˇ  Pś(đŹÁ†˙¸ ulęęjţ3üŁ˙ücüPÁüŔŽý˙·¸\=ąąv9Eü endstream endobj 710 0 obj << /Length 213 /Filter /FlateDecode >> stream xÚ˝ÎÁJĂ@ŕ”ć`_@ě> stream xÚ32Ő34R0Pcc3c…C®B.#rAÉą\Nž\úá F\ú@Q.}O_…’˘ŇT.}§gC.}…hCX.OĆ ˙aýóĆÁŤ˙0ü˙˙‚¸\=ąąě±WÇ endstream endobj 712 0 obj << /Length 186 /Filter /FlateDecode >> stream xÚÝб Â0ŕ  ·ô äžŔ¤¶’Ej3:9“::( NÚGËŁô:¦´4¦‡âČqđqÇĂ©é8ŽHŇÄ·Š)‘tŠđŠJRWIż8^0Ő(v¤$Š•ź˘ĐkşßgéfAŠŚöţĚuFĚňX ŕlčňŔŹYhFAáQňâÉJ*ĂË‚YŕuÎ*>P«ňÎ'sxő'`€ ‚ŹüľçĘ·łs×ü—·ř3Ó endstream endobj 713 0 obj << /Length 154 /Filter /FlateDecode >> stream xÚ35Đ32T0P0b …C®B.S ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś ąô]˘ĆÄryş(0ţ`ţĂŔđ˙˙˙ iĂH~`~ŔŔţóóćß Ś?3€Č˙ ˙!‘Č‹d;ň˙˙ő˙ “\®ž\\ep endstream endobj 714 0 obj << /Length 188 /Filter /FlateDecode >> stream xÚŤŹ1 Â` …_q˛ôÍôďßVčdˇV° “8©Ł˘›hŹÖŁô;5ŤĐIä…ĽĽD“qŔ>‡<˛Y>X:S‹čwŠNö'Js2c2 ‘ÉäKľ^nG2éjĆ–LĆ[ËţŽňŚáĽ¸ďH5pG§Ć †%ÜBáŇx‚ĘĚA­xNÓX:íżčí>Ĺ´ůŮëI=îJŚRłh4 ‰Vę\_螡yNkú¤PM endstream endobj 715 0 obj << /Length 208 /Filter /FlateDecode >> stream xÚ­Ď1 Â@ĐYR¦ń™ č&˛˘] F0… •…X©Ą…˘`er´%GHą!Áu6 ‚Z‰Í+ţ‡Ůżż×ȧ>u©!)ź¶P)N}ŚžŐfŹQ‚rIJˇśrŽ2™ŃéxޡŚćc PĆ´âSkLbÚŐF{Ćzéä`ŞÂ)Á©3ˇApÚ€¸\A4ikh+đć/;ŇĄŐýÉ/׊÷y‰ÝÓ.L[ov3‡˘ÎŢ_ĺnBk/cCîůżĄŕ:ŤŐňMś$¸Ŕ;ť| endstream endobj 716 0 obj << /Length 223 /Filter /FlateDecode >> stream xڭϱjAŕąbaďśHö÷đ‚`ĽBĐ*E°Ň”)H!ŃG»GąG¸ňŠĹuÎł°ĐFlľbvůç;x$sźź’Śí Ű7 }‘MesšťźÖź4ÎÉĽ±MÉĚdN&źóĎ÷ď™ńâ•2~—¨ĺ<:€öEôö•řŹLt†jt‡ĐôşD°EX pčPŁýYůĽĂuwéo¤µ»Ú˝m‡¶OX6JCíTč:¨‘knůGŞC_ę 8Ą=PŐôĆÎ×—Ň4§%ŮŐo¶ endstream endobj 717 0 obj << /Length 145 /Filter /FlateDecode >> stream xÚ36Ő34S0P0bcc…C®B.c4H$çr9yré‡+pé{Eąô=}JŠJSąôťś ąô]˘  bą<]?đř˙ÁţĂ˙~ü˙xřűÇć?Ěź›˙0~gţĂř „0ţcH`üĂŔ€‚Đ3Íţ˙˙sązrr“»M[ endstream endobj 718 0 obj << /Length 203 /Filter /FlateDecode >> stream xÚ-ĚAjÂPŕ?dŤ70súň´ÔBłt墄¶ËB[Ü™Ł˝ŁĚâĘ·yŽĆĹ·˙ź™âqR–śqÁ–‹‚§–ż,ýQ^iń4šĎšŐd6śWdŢ4&S/y÷ż˙&3[ÍŮ’Yđ»ĺěęăč¶qđ’¸gc$Oĺ€čćv°˝ňwť €žŞx ‚4tHBŹ8„ÇŕtmÔ¨uUäuÝËŕpŐŢůAŰÝDŇ#rç&iN’BôŻKôZÓš.8WŻ endstream endobj 719 0 obj << /Length 151 /Filter /FlateDecode >> stream xÚ36Ő34S0P0RĐ5T06P05SH1ä*ä22 ąć™ä\.'O.ýp#s.} 0—ľ§ŻBIQi*—ľS€ł‚!—ľ‹B´ˇ‚A,—§‹Vl†+ ř313ł±ü˙˙ţC1#TŽŠ8fřĂđ€qă{ćův ăţ ŕrőä äwSM6 endstream endobj 720 0 obj << /Length 160 /Filter /FlateDecode >> stream xÚ35Đ32T0P0RĐ5T0±P01PH1ä*ä21 (Bd’sąś<ąôĂLLąô=€Â\úžľ %EĄ©\úNÎ @ľ‹B4Đ X.OĆ ţ˙`¨G%Ů00˙a`ţÁŔř‡˘fŚ$Đť čl0É÷ʎ†Ać?Đ?ň €$ű˙@’á?P—«'W rjy endstream endobj 721 0 obj << /Length 193 /Filter /FlateDecode >> stream xÚ]Í= Â@ŕYŃÖBČ\@71‹ÁJđL!he!B@- 19Ú%GHi٬Ř|Ĺ{đž şG.ő¨ă‘ę“? ť‡'T>‡.©oł=ŕ(Dą"壜qŚ2śÓĺ|ÝŁ-Ć䡜К‡6N¨(´]¤żÚ9¬'Ŕýă {‘ż6*}čŇ;‘”:‰•Úf›şVi§ucÖf­¬U)ž®1ç[ľŚŚmŚ?Ł˙6*qâ_¦ŔDµ endstream endobj 722 0 obj << /Length 248 /Filter /FlateDecode >> stream xÚmϱJĂPŕ? śĺ®ÄśĐ{ÓjÄĹ@­`ÁN"ÔQPQpöNşřP÷|ÇëşdŤ§Á6Ą”3|pţ?=Üď±á.ď%śö¸wĚw =Qjx>˙—Űę礯85¤ĎeM:żŕ—ç×{ŇýËSNHř:asCů€ëúł®ÂşXWUČ<&.*;d (‹ÝF‡ĺŇČa»Ń‹¨ > stream xÚMαJAŕ?lq0„lk!Ü<›Ă ±8ĽBĐ*E°RKÁHŇzűhű(ç¤Üâ¸uf«űÁĚ˙LÝÜ4/Y_ÝđíTt z%őRKýx˙˘MGnÇőŠÜ“tÉuĎ|ü9}’ŰĽ> stream xÚ]ĎÁJĂ@Đ; çÓxĘé%'S~Šé•ŇÄ\#ľČţ^Ź/4ĎIßqšľ1wŇů-żż}<“žŻ®9&˝ŕ{ő@ů‚űľ űÚ7lˇz P@?­[¨V„qtÖPíťA•ËŔ8.ě=®ŽśőĐÖÁ÷ČŮdFŐDb+˘Ý8w•óË:+ťcüwč9đ<±Ž<#O©Ę¬jČ\©ęÔŻRŐÉ*ˇ¸µńŮ•mm`g‰´ĚiM?ÍAP‘ endstream endobj 725 0 obj << /Length 199 /Filter /FlateDecode >> stream xÚ5Î= 1†áoI!Lł­…¸s“5"Z-řn!he!Vjiˇh˝9ÚeŹ`i!ĆŠĽ0 “ëĺ#vÜ—ă‡ěÇ|ČéLŢËětÔ‡ý‰&%Ů {Ov!·dË%_/·#ŮÉjĘ9Ůosv;*gśĹĂ7 ŞşŔ $O‰y˘ óŔ­»$mŕ}RKŠ ©đŤ*¨‚*¨‚*¨‚*IťQ’ ˙Ľ$˘’ ĘQ&2ŞŚŞ–îJuWŞk D$ňĺ_h^ŇšŢ8.GŁ endstream endobj 726 0 obj << /Length 191 /Filter /FlateDecode >> stream xÚ˝1 Â@Eż¤Lă2ĐÍš¸•DL!he!Vjiˇh'šŁĺ(9BĘ˘Ž»… ©…ĺ-ü)fţ‹‡ý‡soŔ±fŁy§éH‘‘0dąÉö@iNjĹ‘!5“T>çóé˛'•.&¬IeĽÖn(ĎŢ@đ*€Ä/¦SC^ŻÂ^‰$NĐ-8ßb,(püŞ OAý´-żËiUŰą®ŚÔ*ľm_ ëŔÚ°^ś!ëęcŤ¦9-é ÷@m endstream endobj 727 0 obj << /Length 126 /Filter /FlateDecode >> stream xÚ31Ő3R0P°bc 3C…C®B.#K ßÄI$çr9yré‡+Yré{Eąô=}JŠJSąôťś€|…hCX.O† Ě@ĚÄň@\€ý˙†˙ <˙Ăy¨řPĆő€ţů˙†ą\=ąąsŹUÇ endstream endobj 728 0 obj << /Length 242 /Filter /FlateDecode >> stream xÚu±JÄ@†˙%ĹÂî fžŔ$Ţ,ÄóSZY° –‚Š‚…HłVřŔ2u@JÜ&lá»lD€ŰáŔŞmwjR_Ż@>Ä ; lŇÝ?hŮťv* ŕŘ„žç÷°'Ř!¶nüE¶5ři>p §{N÷› áhd42žFJgÄaZt¦Ej‘Zô¦!Ů'äÄ’h }ú ąläV~h€p endstream endobj 729 0 obj << /Length 246 /Filter /FlateDecode >> stream xÚu±NĂ@ †ed!ň•Î/—kBÔí¤R$2 щ1cĄ‚čś<Ú=Ę=BĆ UíŁLp’żá?ű·ő77×Kިˇ«%5ŽZGo?°nY¬¨­ÓĎë×Ú'Ş[´÷,ŁíčëóđŽvýxK톞U/ŘmŠ#řyçŮTLP„ü%d'¸dý`†ŕŹ˙ŔČoÁfAŮ'~ÁĹVüN\™ěĚ'ÁČ(u€Ënä(ăąE›u,ą¨_ÚˇgŨ¸x·›qÂGŢĺc/VűôĂJ°s5M#źĘ1%”˛’Ôđ®Ă-~nn endstream endobj 730 0 obj << /Length 185 /Filter /FlateDecode >> stream xڕϱ Â@ €á–B‡P:w’> stream xڥбjĂ@ ŕßî@‹_ 4zö|±k:ŦP…dʤc! íÚřŃü(÷=»… éŘĺt:IüůăĂ„SÎů~ÂąçÂóŢÓ‘˛BŠ)ŮďËîfągąW)“«ŢřóôőNn¶xfOnÎkĎ醪9 †mŔvča‡árĄU‚Ň(€);ř'Q/$C 3ŤĚ!ę`.zĆ7lŤ(ki×Ň?n®!ąˇ˝aŞśŮđýÖ먠luňAIuĺ“2褑 Ň«âq«Ë4”2BĂ˝T´¤Đ]E endstream endobj 732 0 obj << /Length 249 /Filter /FlateDecode >> stream xÚuϱJÄ@ŕ?¤Lᾀ°óšä•óSZY ¨Ą ˘m˛Ź¶Ź˛ŹňŠŕúçr×| 3ËĚüőŮéJ ­ődĄu©M©/Ą|HŐ°XhS-ťç7Yw’ßkŐH~ͲäÝŤ~}~żJľľ˝ÔRňŤ>”Zá‘“=Íx~]Äě™Ď<Čp޲vŘ=ÖŰy‘ńKÖÍŮŔ”=z&>čł‘ix o@Ęş\ur'żĐx; endstream endobj 733 0 obj << /Length 202 /Filter /FlateDecode >> stream xÚ•Ď; Â@ŕ‘A’ ś čćM QL!he!‚ –‚Š‚ť9ZޞGH™B;‘RX¸ĹWĚî?łă#—l hč’ďSčŇŃÁ+z‘*Úúß›ĂăņĽĹB•Q¤Kşß'ńjFŠ„¶Ů;L˛Ať™0ÓŞŞŢ]ĘWCÁČ‹z&÷˝\ˇe (tČ ¦ĎXLÝ·žŔ!Ŕ)&ާګeÜ~îŮR27é˘uŃkdóż1y ]m€ó×řsđXp endstream endobj 734 0 obj << /Length 277 /Filter /FlateDecode >> stream xÚ]±JÄ@EoHÂü€ěĽĐ$›jŮŔş‚)­,ÄJ--… ɧͧĚ'Ś]аăťÍŞ §xóî}÷˝ęâ|)ąTr¶”ŞşçB˝©˛f1—şśž^Ő¦UŮ˝”µĘ®YVY{#ďź/*ŰÜ^Jˇ˛­<’?Şv+'Ú@ď-0Ĺ#"‹ ±ÁÉŤ|'İ+§„Y X˙˘9"1ÍŔfm)ÓŽzÂé+¤~čxăű/‹Č‡áŢ3FăY g…,ÚŹ@ç'D®ßÓV{:RťRh4…†zËŤÝQc;ÎuDěĆ*€˙` ‚"šAh^á°ĄK§†™‹˘p†´Ç[…«©«VÝ©o‡–qg endstream endobj 735 0 obj << /Length 252 /Filter /FlateDecode >> stream xÚuĐ1JÄ@ŕ?¤Ľf. ć]@“lbÚuSZY,Vj)˘h·ÜŔ+Í ĽBnŕ+§‰o˛±Řćaţy˙Tg§+Îąâ“W×?ôBe­›9×ĺţäţ‰Ö e·\Ö”]ę6eÍż˝ľ?R¶ľ>炲 o Îď¨Ů0â@:)vrŔ"yÄ‚IŹLʤi§ŘN×™vFo»™iÁô‡„€ »`%<)ơ•ÄáYt o‰%úřřS°KŚ uÄÄ+áˇPç÷Ť ěË´°N»ý2(ÚÜvđGáŽĂU*ĆÓD“šF ÝĐI2v: endstream endobj 739 0 obj << /Length 105 /Filter /FlateDecode >> stream xÚ3˛Đł0S0P0b##C…C®B. m„@ $‘śËĺäÉĄäsé{€IO_…’˘ŇT.}§gC.}…hCX.Oöůöęü˙€ő?ě?Č?`oŕrőä äu¬%ä endstream endobj 740 0 obj << /Length 91 /Filter /FlateDecode >> stream xÚ35Ôł4V0B#cS##3…C®B.SC° 1D"9—ËÉ“K?\ÁÔKßCÁKßÓWˇ¤¨4•Kß)ŔY(č˘ ÔËĺé˘đ  R\®ž\\ŔĘ&2 endstream endobj 741 0 obj << /Length 210 /Filter /FlateDecode >> stream xÚ•Ž±‚@ †KHşđô <HâD‚x‰NĆI4şŹĆŁÜ#0:kË “F/é—öî˙˙^:GŠ(“JĘR:ÄxĆDçHGmö',,š %š…ܢ±Kş^nG4ĹjF1š’¶1E;´%AŔŔÜÁą‡ óÂĆă&ŹŰJž\ݸîŘ}@ÝđŘ…bs ^ÄŔ×üࡸ ÂN;E«ÔRP)úT ŞőŢpŕ‡3ŇP_ş2Ô?ćü d6 ŔąĹ5>&,k« endstream endobj 742 0 obj << /Length 266 /Filter /FlateDecode >> stream xÚ}бNĂ0€a["Ý’G°ź'j•¶ –J‘Č€ęŚ@°A“GëŁä2z1ľł ‘ĄpR¤Ď—ĺ×­Ö‹Ť*ÔŇ«ĄŞęą„W¨pWŕ<`[~PŐôŤß‚®oŐűŰÇ číÝ•*AďÔc©Š=Ô;ĹüX†)Ä8‹ĚĄČ];éN Śëćи>ŕëŚom n]hĺ} ú&$ŠÎ$ČNĆEČ€Üó6¶JJ”ěY€ń ÄK&Ž”řů0xŘx\G Tz†óqŠ á¨AŃ9ˇĹäx`IŔ5›€˘ ˇĂd˘Ź„K'Ŕh>,Ă(lł˙®k¸‡nµ> endstream endobj 743 0 obj << /Length 217 /Filter /FlateDecode >> stream xÚĄ‘± Â0†O„[|ď Lk%v+Ô vtr'utPt®ŹÖGé#těP“öRHG „ŹKÂ˙ź[óĐ'Ź˝eHrAW(—şöLi..wŚSG’K[}Š"ÝŃëůľˇ÷kňQ$tŇ2gLRfU-Ő‡Y2k€Čě¦ăTuśč‡†c•3‹–ŁžĄCĐ~áPÇŇöłý­ëoĆ~M°Čä(Ŕ,Ý\Ă<6X˙űĘj—ZŔĄú“˝¬qűő˙R±ß’ýw~#•wsSýüÜyŕ&Ĺ~ŘŻć endstream endobj 744 0 obj << /Length 221 /Filter /FlateDecode >> stream xÚĹŇ=‚0ŕ’oá|'°ŕ:‘ &2čä`śÔŃAŁ3ŤŁxĆ„ÚŇ’ęŕ&„ä)%ĄĽ/ń|0™a#qĹcśńÁâĺ)†râx4şĂ8şwćkĽßg éfĐ ÷†Č3äň`„üiPÔb.i)¸†ĎK—ż|şEÂ4‚ZĂo ¸†'^ŇÂíQZpÄŇ6*ňěÔ˙Ŕ/ł?Çéa‡đT¦Çíś“|bşŕşÇ×UYeTÝŤéť”ň'e[x‚é? endstream endobj 745 0 obj << /Length 198 /Filter /FlateDecode >> stream xÚ}Ń˝ Â0ŕ”[ú˝'°­bp+Ô vtr'utPÜěŁőQ|źŔxm.ńŕř¸ËIÔd)LqD©Ć¨†¸Ďŕ*Ł:mËv`w„˘‚dŤ*dN]HŞ^Î×$ĹrŠÔ-qCK¶P•¨»x ź"oS%°Âzgs6¶ÖĆČQţTÖ˝Ť1ô(şý#ÇÍYÝI×ř«ť÷Y{ö§soźż¤p ¬ŹoCGé±qĂďĚjcČćş1˙Ö[»Â¬‚Ľ-GÇŹ endstream endobj 746 0 obj << /Length 169 /Filter /FlateDecode >> stream xÚ33Ő32W0P0b3C3#…C®B.S3 ßÄI$çr9yré‡+šqé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţÁ¬Cý†˙Ŕ”<„b‡PŚŠ•ŞPuĘ…’ĂIÉ1ČC(~le‡BŐA¨`ŠLý˙Ź›‚*i€iG5SŽhЦ(řŕ ¸\=ą঩ endstream endobj 747 0 obj << /Length 123 /Filter /FlateDecode >> stream xÚł0Ô34W0P0bss3#…C®B.s# ßÄI$çr9yré‡+qé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţ˙˙˙ʎţ?ŕb0Ô˙a``°˙Ç0ěPOâe WżŁ3I \®ž\\$čď@ endstream endobj 748 0 obj << /Length 102 /Filter /FlateDecode >> stream xÚ3¶ĐłP0P0as3#…C®B.cßÄ1’sąś<ąôĂŚŤąô=€˘\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ˙ Ť`°˙ÇŔ0J@ l!ÄĺęÉČÝ3x< endstream endobj 749 0 obj << /Length 141 /Filter /FlateDecode >> stream xÚ33Ň3¶T0P0bS 3#…C®B.Sc ßÄI$çr9yré‡+sé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţÁ¬Cý†‘BUŕˇ>঱QĚ(űdŠBÉC({őL1C(ů˙ţÁ¬—«'W ٸ¤u endstream endobj 750 0 obj << /Length 269 /Filter /FlateDecode >> stream xÚ˝’=NĂP Çeä%G/€^4e‹Ô‰ H0u@ť€‘sr´%GČ!Şń4AEyó{~¶őŹíŠͨ ‹ś—T\ŃsŽoXĚĹ)îkyzĹe…aKĹĂ­¸1Twôńţů‚ayż˘Ăšsší°Z”°3·ó`Ŕ]ÂŤ|#±ĽH îR ČzM“juë3h‘X"ÍPs„ŘŠÉ»WĺRM€ş!s 3Uĺ\§ŘS¨×}řš˙„?ô¸ć śůݱ?0éő°›{ź[AkwłM§±LŻQę®ÉŐ%ĽŹ4N2dî¶ ,§ůµ [ČqmpSá~ʆĐ÷ endstream endobj 751 0 obj << /Length 337 /Filter /FlateDecode >> stream xÚ˝’±JÄ@†wIŘ&ŹyIÂAîşŔy‚)­,ÄJ-í„|±€/’ÎŇ-S,7ţł»ÄÓ+ ÉćËfćßŮgą˘’j:ŞV´\P˝ ŰĘ<šşĆlI«*ţşą7ëÖ—Tצ8ĹĽ)Ú3z~zą3Ĺúü𽡫ŠĘkÓnH)Ől•żćŃCÎě<°MąÇ[ó€˛RťdČ'IƉ€LËo%" Ňt€AůT/†é ĘVe&€¬×MXŰűľĽĆĹ:1îC€%ŢoŕŕýÂzćšěkŢűěĆl µ03wb&ěE ě…鯹؏ç!}űy´É»ÝŮQ°?¸QŠ|îĆŕM ¶ľ¬­Ŕ.•´b{ čÁ—×€hˇ’6ŹŔü Ő˙ ˇł=Hy»·k×)€öE«Řza±^™“Ö\/™»— endstream endobj 752 0 obj << /Length 151 /Filter /FlateDecode >> stream xÚ37Ň32V0P0b3 3C…C®B.3 ’HÎĺrňäŇW03ćŇ÷Šré{ú*”•¦ré;8+ů. ц ±\ž. ö˙ÁŕNúC=ý°˘ůÔ7€hć?ő šńOf€Ó5şFW@hBô-Gf€Đ Ł4-Š®8i.WO®@.Ú¬§ endstream endobj 753 0 obj << /Length 201 /Filter /FlateDecode >> stream xÚ3·Ô3·P0P0VĐ5T07W03RH1ä*ä27 (Cd’sąś<ąôĂĚŤąô=€Â\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ˙ Dŕg1Ř˙c‚z †°ěFYŽ%fŐ ˛ţĂXü`Ö8ëłc–Áúd1˙?$YŚ ;ĹđHĘ' jűĹŚ`“€ŕ˙f1Ë0 ”l@Xň ŚI.WO®@.¸ëš endstream endobj 754 0 obj << /Length 258 /Filter /FlateDecode >> stream xÚuĐ1JÄP…á¦Ü&K·3QíŚ#BĐĘB¬ÔŇBQ°“ĄÝĄd –)$Ď{.‰b1đńňsHstp|6ˇ±»> Íax¨äYęĘÎůâţI¶­”7ˇ®¤Ľ°§R¶—áőĺíQĘíŐY°§»pkźÜI» 1ńŇ=(Ö©ŹŤ‘ @7!*ŚŢřF˛4˘VĆ'ů"yđ J,I,‰wO’nfr, &gFÂ$ś“`r¦'LţÁ$|¬ó?ů[ÎOĹ‚& Ž] ž\©Ź%“Ăd®ŮÂH|lˇů‚Ť]«ŹŤęc;ő±üÉśŁL©g˛K˝˙˙=Čy+×ň¬ŕÄŠ endstream endobj 755 0 obj << /Length 226 /Filter /FlateDecode >> stream xÚmĎ˝NĂ0đ”ÁŇ-y„Ü P'4­Äd©-`b@ť€‘łŰ'č+őQ"ńŢč`ő8;UŔĂOľó}ČłfŇ]qĂSľhyÖpwÉĎ-˝Q7פ†Óńĺé•=Ůîćdo4M¶żĺŹ÷ϲ‹»%·dWüŘrł¦~Ĺ0˛ŕ$…HĘX `ČŐ~@}€ ¨ăI ĎVń¤VŞ&$‹}RĎË´`\Se˝ě´^Bę•Mš#ż3]žéGódţ±>ŕr˝Ë˝^ôR|K¬ŹćK˘ŮJ,äź˙ĐuO÷ô„?}Ď endstream endobj 756 0 obj << /Length 205 /Filter /FlateDecode >> stream xڽѱ Â0ŕ“ …[ú˝жÔč(Ô vtr'utPtn-ŹŇGčء/Ť…â$fůŕBŽű/r<S@őC’’FíC<ˇ ąĐhhovGŚSô×$Côç\F?]Đĺ|= /§ÄŐ„6üf‹iB ÁýÇ"ţOV]<3ŽĐhĹT0)™ĽŠ)Ŕ­™ś»E7]DKţ2ôş)~BGkŃň>K3çsjîýĺfU•Ů(łž ]Ř(‡Ó7˙Łp–â 9  @ endstream endobj 757 0 obj << /Length 207 /Filter /FlateDecode >> stream xڝαŠÂ@ЦĽfţ`ó~`w2› ˛‚ë‚)­,–­ÔŇBq»…řiů”|BĘ)†Ľ}ĹŢćwxwn9zó#ÎąŕWĎeÁĺ;ď<©kÉőe{ YEnĂĹÜBcrՒϧß=ąŮę“=ą9{Ψš3Pw€2‘u›µ‹é ¦‡ŤiŹ,Ú¨dW‚2˝aCvÚ‘4Cä9ęáŽÖăeýşŰ©Ž F.IiL«w¶Ö©Äáş}U´¦*[e? endstream endobj 758 0 obj << /Length 211 /Filter /FlateDecode >> stream xÚ˝Ń1 Â0ŕH‡Â[z„Ľ h švŞ‚ťÄIťăMĽJobŹŕˇôůŇ.uÉ^Hř“č´—bŘU¨5&Ü)8‚V\ěc2ô+Űd9Ä+Ô â—!Îçx>]ög‹1ru‚kŢł|‚‚[h›‘ľ#FůWLé¨rH"‡yDw†Š€“Ä3+šëVDu“3ŞšíŇă‚0/-ĐOh=ÚŘ–,ŇľsľR±UÜŻ!QéâĆHŞ%Ă⦥€iKxĆ.¤Ľ endstream endobj 759 0 obj << /Length 208 /Filter /FlateDecode >> stream xÚmĎ1jĂ@Đ/T¦Ń ˛s{Ąh!©"e°Š€Są0©’”)l’Î MGѶT!4[ŰÁ;đŠ]fćŻ{š»gN8ăYĘα{äĎ”vä>•˦—Źo**˛v Ů•^“­^ůg˙űE¶X/8%[ň6ĺ䝪’é€H ęNš@šĽ ¦‹FÄ>÷J4^É{„ă…Ú˙!gÄ#¸ćßńĐ…w¨oŃɱ9ŁéŚ&ŔÂK¨ ŰCÚĐk‹é`DZýÇ8Ť eEotWÔqś endstream endobj 760 0 obj << /Length 160 /Filter /FlateDecode >> stream xÚ36Ô37Q0P0b3…C®B.c3 ĚI$çr9yré‡+›qé{Eąô=}JŠJSąôťś ąô]˘  bą<]Ř˙000Ô˙g``ü˙˙ű?ů ň?ě0ب˙ŔP˙Fü?%˙7€ ű@‚żH€´’Jü˙˙˙:A¦Qt#ę˙I4‚ËŐ“+ ĆEŤE endstream endobj 761 0 obj << /Length 261 /Filter /FlateDecode >> stream xÚŤĐ˝JÄ@đ9RlłoŕÎ h˛^ÎĂjá<Á‚VbĄ–ŠvBňhy”ř[nvüďx …)~0łóEÖţčtĹ Żřđ¸áµçÖó7Ď¦Ý Űđ‰ß?Ý?™mgęn7¦ľ@ŢÔÝ%żľĽ=šz{uĆw|ëąą3ÝŽ©’ˇŠ$ą™Drź+YČś—3őŮÂ)»D!ćÓ{¤a±‡óżüŮĄsöˇÎ§˛k¤%öP2‘Ĺ=·PůľtżÔQtÁ¨ÎeRęPGu˛*ş&¸ŘŁß¦â2ĺo«?}ŐĘŘŁ×Ć€ínrQ-î.»‹j,Iz đS‰Ěyg®Í']¨T endstream endobj 762 0 obj << /Length 159 /Filter /FlateDecode >> stream xÚ35×3W0P0bS33c…C®B.SC ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś€˘. Ń@-±\ž. ˙@ŕ?ŠB1Óź˛˙¦ţ˙QĚ˙˙7)ţ˙)9†ú@ʤ†ů„úˇ0Č˙RP¨lĂŕ¦ţ˙˙Ăţ˙˙¬—«'W łušË endstream endobj 763 0 obj << /Length 129 /Filter /FlateDecode >> stream xÚ3˛Đł0S0P0b#33…C®B.#C ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś€˘. Ń@-±\ž. Ś?˙0°˙cŕ˙Ď ˙ż R@@eřŔ†˙Hý?3-Ń˙˙?ŕËŐ“+ !;X endstream endobj 764 0 obj << /Length 209 /Filter /FlateDecode >> stream xÚĹŃż Â0đ–…[|„Ţ­¸ ţ;:9“::(şŞŕ‹őQÜ\;v(9“ďŐŐ„đ#Éĺ#!y·ÝĎ8ĺŽy—{Ţft > stream xÚ3˛Đł0S0P0b#s3c…C®B.## ßÄI$çr9yré‡+qé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţ3üGBě˙7ú˙˙qązrrłÔ] endstream endobj 766 0 obj << /Length 153 /Filter /FlateDecode >> stream xÚ35×3W0P0bS3C…C®B.SC ßÄI$çr9yré‡+ré{Eąô=}JŠJSąôťś€|…h –X.OĆ öţ˙! fţ˙żHńřHÉ1Ô?``˙gRĂüŻB}S˙0Č˙RP¨lĂŕ¦ţ˙˙Ăţ˙˙¬—«'W „Ś endstream endobj 767 0 obj << /Length 195 /Filter /FlateDecode >> stream xÚťŹ±‚0†KHná¸ĐR) bbťŚ“::ht†GăQxFĂymŮŚ‹ÉĺËőżôî˙3µČSL0ĹąBťŁ^âEÁtĆb‚:ő“ó Jň€:ąa¤Ůâóńş‚,w+T +<*LN`*˘î…3™1QËBW°DM4€DřłŃ7üd‘G±eëYXş/ugwŐý7ÉrřŹżvNw˝ď-˛>›=“-n'Ną|Ćóşě°6°‡;‡Ă endstream endobj 768 0 obj << /Length 203 /Filter /FlateDecode >> stream xÚµĐ1 Â@Đ [¦ń™ h˛č­„¨` A+ ±RK EëÍŃr”Á2…8ΚÄb§Ő?,;óMÜ‹)˘>uőڎ¦˝Ć-iDfTŹvGLR ×d4†sÉ1Lt9_&Ë I:ĄŤ<Úb:%`°łĎwGŔě°çB ö>ß`\‚â‚»AçQÁČĽ&s¨†üݎř ů׏ę]Ţ´[ç<ÚSęĂJ@±ucUU ¤Ň’˝î˙Ŕ®÷/ŕ,Ĺ>Íî¦e endstream endobj 769 0 obj << /Length 227 /Filter /FlateDecode >> stream xڵнjAđ˙qĹÁ4y„›ĐsŃ…ł:đĽ"TbeR¦PŇ­y_EđA<đ첅8Ů=E°4Őo™ťŮ™YÝićŠ[Üć†ĘYkî(ţP4'íŁ-ÖÝp5ű˘^Iٵ˘läâ”•ŻĽ\¬>)ë˝őŮE> stream xÚ31Ň35Q0P0bCJ1ä*ä26ňÁ" ‰ä\.'O.ýpcs.} (—ľ§ŻBIQi*—ľS€łď˘m¨`Ëĺé˘ŔřŹńĂ˙ě˙ţ˙ă˙˙ŕ˙?{ů˙˙ŮČ`˙Wa˙ůßńHüŔ„üć˙ ü€s``€ t$ţ˙˙ŹApązrrőX] endstream endobj 771 0 obj << /Length 223 /Filter /FlateDecode >> stream xÚ=ϱJ1ŕŮâ` ÷ ĚĽ€f×Ôćç n!he!Vw–ŠvrîŁíŁÜ#ląEČ8ăÉAř ˙ĚdHlĎŻ/ąĺŔg‡+ŽĽíčťBÔ°ĺ•Í­zňO"ů;ŤÉ÷÷üůńőJ~őpĂů5?wÜľPżf¸ů•Č ‘‚fż(pCU€‚ô|KäNCţČŢĐ;~$š&ŃÔ‰ĚhDĂÚž×mJFm=ZR*'2Ň8îH3ć#:Ý ŠtÚŮŢd{wąÎČ"¦$#ě Űžén gđ endstream endobj 772 0 obj << /Length 154 /Filter /FlateDecode >> stream xÚ31Đ3¶T0P0RĐ5T06Q0µPH1ä*ä26 (ZBd’sąś<ąôĂŚ ąô=€Â\úžľ %EĄ©\úNÎ @Q…h žX.Oö ĚŹ†ĺ‘°=×Cń˙F fbů˙˙˙üGÂŚP9*b9Bč†˙ ¸ţAý‡@‡=:đб \®ž\\1…j endstream endobj 773 0 obj << /Length 159 /Filter /FlateDecode >> stream xÚŐĎ1Â0 …aW ‘|‰ř‚:V*E"L @0·7áhäć!8Ógýv†„bPČPré{ cÉ˝ě<9xDäŃ{ł=pŮ­$xv3dvq.çÓeĎ®ZLµ–5Ţl8ÖBJd:R%Ł?08);ęű'”ßh:Ę€~ĐfzÇŘš›&j’˝« đó¤É&âiä%?9Ş~ endstream endobj 774 0 obj << /Length 218 /Filter /FlateDecode >> stream xÚmͱJAŕ˙Řâ`šĽ7OŕŢéX1‚WZYU’2…AÁBČĺÍN|‘‹´WnnśÝ l!ĂđÁ üSź_U\ň…nsÉuÉ«Š^©)9L}z,74oÉ>qS’˝Ó+Ůöžß¶ďk˛ó‡®Č.řYc^¨]°G!ýżé`<2%sJă€@ݏČÎ!ď”Ꮙ2S hŠRxśޏV&GL#>•|ÄG@ŕ#"ű@&{ů @ľűČωCdwč"™ Š1E{rźb†”,ÔŃmKŹô îSc} endstream endobj 775 0 obj << /Length 245 /Filter /FlateDecode >> stream xÚ}αJÄ@ŕY¶Lłop™7ŘŤž¤9 ś'BĐĘB®RË+N,„¤łô|•Ľo ű)·g‹l#Ă 3Ĺüĺ9:‘.Oiíč±Ŕ#–Žb­çĂĂ·5Ú;*Ú+٢­Żéĺůő íöć‚ ´;ş/Čí±Ţs¨8(ţfn!o˙`@Ëld*˘ŐŽ“=l–đJđĐzx‹Đ3Ş^č—ŮGP‚\0(afÁčQwKŚ+5f‚LŔYq>Cóřhľ*âg 4ŐÂC>ˇ„U¦OŃB6!řFK@Ľ¬ń ż—‡ endstream endobj 776 0 obj << /Length 267 /Filter /FlateDecode >> stream xÚmϱJÄ@ŕ [!op™Đ$zŽÎL!he!Wť–ŠÂBro¶â‹,X\›2Ĺ‘uv6²Żě?ó—ółË‚r:§ÓbAĺÍsz*đËśÜ)ÓÓöW fTćÝđ=fÍ-˝ż}$2!jBűn܉t…ZşBŰĄ˛—žy*ĎŇłóȸVÚAë“«D"Sß ńË*ż^7xŹż> stream xÚ35Ôł4V0P0bS3…C®B.cßÄ1’sąś<ąôĂŚÍąô=€˘\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ü @ "ęń?ŕ˙b‰˙â;řÇ’„=Đ×?Đ.WO®@.v)aG endstream endobj 778 0 obj << /Length 247 /Filter /FlateDecode >> stream xÚeĐ˝JÄ@đH±0Í>ÂîsŠŤóSZY•Z^q˘ť°y´^©ÚŢ]E‰î⣴> stream xÚuÁJÄ@ †3ô0Ë<Âä´¶.zXW°AOÄ“zô čą}´y”>BŹ=”Ć$++Bů ˙$ţä,ť^l¨ˇ–Nµç´mč9á¶*6´M‡—§WÜuXßS»ÁúZd¬»úx˙|Ázw{Iňż§‡DÍ#v{ŕ/ÂĚ<ŕDr3ôT#ä|Ľ@ ®Ą~üů·ŚŢşŞ ň :gůa?'ĄEq\„«´ÄódŤfŕ4§tŤćcŃܢ=‡Cłył;ŇęGĄŚ>Rö˙źĺ›łx–^9H`™’‹mZt/ąO/e«“¸łĆe»g´ŰÚZxŐá~ÇśÍ endstream endobj 780 0 obj << /Length 197 /Filter /FlateDecode >> stream xÚťĎÁ ‚@`Â\|ś'h•4¤Ŕ ňÔ©CtŞŽŠAľY>ŠŹŕŃ›9ż`·öŮfgoNŘe9~ČS—O]ÉÚÜ•TŽŠSŇ;öŇ«ö–tşćűíq&oě‘Nxď±{ 4aĂ0TeôšĐ‚6t~śĂlľ*hB ÚoúŚŕf°U)šť…h墍ż8Ě`%ŞÎR4 ŃĘE:v#Á6őĐ~»˙Uč3–)méܤ‰Ů endstream endobj 781 0 obj << /Length 247 /Filter /FlateDecode >> stream xڝнJÄ@đ˙U)Lk—yMs'6.ś'BĐę ±RK E;!ëřHćQň)·Xnť™XbcŠdvv>véOޏá%8nŹyŐđ˝Ł'jť^ąůäî‘ÖŐ[nŐ¦ş»ä—çת×Wg,˙ľ‘;·ÔmxŔ>Ę(*1ç<ýp43P“ÍфՀ˙ř.MP~XÍĎĽÓj íŃË #ü¤sú¨ůUBUľjg×góoĂliz]$hÁlÁżÄ·š‰~Đ.}P߬ď)ŕ> stream xÚ}±JÄ@†'¤8&Źpóš,m ś'BĐĘâ°RK E;!űhű(y„”—˙ŮAQ·řŘýgůgć?r‡'+i¤•'í±¬ąwüÄ­‰Ť¬]®Ü=ň¦çúFÚ׹î/ĺĺůőëÍՙཕť“ć–ű­•{Âé4€Ş“ ĹLTÍôy¤S˘!ř¤ľT*Ô/”p1Ä*3—ŃJ`©‹É=s6żĐę:ęIß“čGč&Đc M¶šię–ę5~1|ă Žqř—ÝO†efr®RÇ´ŁĎ[[6ŚMdđ™`5Yś:"CĹF(§„|Ţó5˙Bµ© endstream endobj 783 0 obj << /Length 210 /Filter /FlateDecode >> stream xÚĄĎ= Â@ŕ )Óäf. ›Ő(XüSZY•ZZ( br´Ĺ#¤´Ćť‰¸‚`ă_1˰ďuu«ßˇzÔÔÔŐÔkÓFăŁČ,ÍşSż¬w8HP-(ŠPMĚU2Ąăá´E5 IŁŃRS¸ÂdD ŕ j ±2S|[ob.f"°Ź—©±„ €sgÝÎŢMĚY_ 20_ĹŔ^ĹRÜGt%‹9}kN9]mĆƦ`­¬ÎĂę~éŐ–V˙§ÁúRË“Z.Âq‚s|‡zµ endstream endobj 787 0 obj << /Length 136 /Filter /FlateDecode >> stream xÚ32×3°P0P°PĐ5´T02P04PH1ä*ä24Š(YBĄ’sąś<ąôĂ ąô=€â\úžľ %EĄ©\úNÎ @Q…h ¦X.O9†ú†˙ ˙ᬠ—Ŕ€ ăĆćfv6> † $—«'W ÷ '® endstream endobj 788 0 obj << /Length 171 /Filter /FlateDecode >> stream xÚĺĚ1 Â@Đ [~ˇň/ »1F“JL!he!Vj§ ˘uöh%G°L˛î‚……7pŠWĚŔÄj RVsČŁÇ BşRäJœϲ?SVÜp”’\Řšd±äűíq$™­f’Ěy˛ÚQ‘3şĆ´_@ x6˙ÂÔQj‹yţÂka´–D DŤ~Ťü:čVđhŞt—Ť%¨š´¦7ĄTm endstream endobj 789 0 obj << /Length 229 /Filter /FlateDecode >> stream xÚuϱJAŕąba ď ĽyÝŮhş…Á+­RPK E;1 ľŘtľĆ˝±»âpť˝‹ S|Ĺ?;?¬źĎxžjösö3ľ­éüTCŤŹĆÍÍ=-r+öSrg“kÎůéńůŽÜââ„krKľŞyrMÍ’a{č„Ő®lBŠ-`a:`Đu)xŞu‹w­äG˝W‹ŐůÇ2©&eËŻśɦá¶ĎÚnh›‡Î ŮÍhüuťđ‡aǨ‡k}˙ˇ Ţ[ bÔŞµoźb»ý"E“z“†Oľ€Nş¤oÉŚla endstream endobj 790 0 obj << /Length 159 /Filter /FlateDecode >> stream xÚ35Ń34W0P0bSC…C®B. ’HÎĺrňäŇW01çŇ÷Šré{ú*”•¦ré;8+ré»(D*Äryş(0ţaüÇŔđ˙ű˙@RŽý´`üÁŔţ§€ńóź ˙`ř$@ä˙†z É€ ˙a/É ňmĂ˙˙?ě˙˙C&ą\=ąą?qjS endstream endobj 791 0 obj << /Length 144 /Filter /FlateDecode >> stream xÚ36׳4R0P0a3…C®B.c ’HÎĺrňäŇW06âŇ÷Šré{ú*”•¦ré;8+ré»(D*Äryş(0˙`ţđ˙‡üź˙?lěţ˙(¨g˙ńŕ?óĎ˙6ügü  u@lĂřźńţC{Ě ´÷˙˙pĚĺęÉČČöPę endstream endobj 792 0 obj << /Length 162 /Filter /FlateDecode >> stream xÚÍË1 Â@…á·¤Lˇ° čfqCĘ@Śŕ‚Vb--+'GË‘<@Čş!Xč lľâý3©ť™ŚžóÔpjŘZ>şíÇ„m:”ęL…#˝c›‘^…™´[óíz?‘.6 6¤KŢNäJV- đ-r˙eÜByDˇz 7˙«˙U}Ä`‡(řD,uxIé0nŇ·WR héhKo©b“ endstream endobj 793 0 obj << /Length 248 /Filter /FlateDecode >> stream xÚeĐżJÄ@đo \`^›BĽyÝÍ] ç ¦´˛á@-íÄŰG˛´ĚŁäR^w˘ůĂŮüŠ™]ľ™9ŽŽâ„ Oůpj8>ĺxĆ˝PS5śĚţZ÷O´LIßpśľpuŇé%ż˝ľ?’^^ťqDzĹ·›;JW\×…ŞËˇ~ lrŻ&V‰÷g¸îľ{„ť'Ŕ´N2¬;säŔ8GÖęĘvn=§·őĐŞĘQoĺb]pĐ» ~‹‹Ż^¶ă8ëőí®Ř:úg00ěś7~Ęžîż®JTĄÄŮ Ďľüś4s”M^!ŇyJ×ô[ÍX' endstream endobj 794 0 obj << /Length 207 /Filter /FlateDecode >> stream xÚ˝˝ ÂP FżŇˇĄŹĐĽ€ŢVn«“‚?`A'qRGE7Áúf}”>BÇŚނŠč*3$|9ş×î†ěłćV‡uČQÄŰ€¤}®+ę5“Íž†1©%kźÔTڤ⟎ç©á|Ä©1Żö׏¨8Ux·čă”Ŕ*ŕ%V7±38©“ÂÎ \Aî&°rOP ĺdeyÜżˇ>Xý ?c\%éý#řëŁćË'q¶(IŤŁ©fÔ‰µNšÄ´ …) endstream endobj 795 0 obj << /Length 131 /Filter /FlateDecode >> stream xÚ3±Đ37U0P°bC33…C®B.c# ßÄI$çr9yré‡+qé{Eąô=}JŠJSąôťś ąô]˘  bą<] >00013Ëń˙ ˙Ař9łůĂ ó˙úóCý˙˙˙aËŐ“+ Ět^@ endstream endobj 796 0 obj << /Length 259 /Filter /FlateDecode >> stream xÚ]ĐÁJ…@ĆńOf!"·."ç ĺÚÍE0p»A.‚Zµ ¨vµ ôŃ|ÁĄ‹ËťÎgH0?ń?p´¬NÎNmnąĘŇ®×öąwYUşĎąĺ‹§7ŮÔâîěŞwĄ§âękűůńő"nssa q[{_ŘüAę­…ŮČB´aD4%;>Ú#îp¨§Ýŕ{%*eĚdl”é§W”]čH˙‹ůOË·ž¦…dfä 3Âױt˘K҇óFĽoćűĽłMŘfl=łoÂ,"†EĚ"pLΉ~WІh–FšĄFł*Ö4×€& !Ś3ž´DWţËZnĺÎvj endstream endobj 797 0 obj << /Length 257 /Filter /FlateDecode >> stream xÚuĐżJÄ@đoŮ"0…y!óšDr1•óSZ) ¨Ą ˘­ÉŁĺQň[¦X2ÎćNĽ˛đ[ý÷ÍŐńéŠ3.řč„‹—%?çôNEĆa”Ővĺé•Ö Ą·\d”^j™ŇćŠ??ľ^(]_źsNé†ďsΨŮ0yµ("=¬·˘IŹ 5p‡oŹI—ŕu·ë~Ń˝vڧ śÚ§î´„©5âĐFť‡ŕ r¤“ q/ošAz˝ ąFĹĚxé¶`ÚcÎż¤ý=!ő‚)Ůa¦$Ľď°ăÜ ąĐď íkŮkRý—:ô5±Ś€•đš†.şˇÖĚ% endstream endobj 801 0 obj << /Length 106 /Filter /FlateDecode >> stream xÚ36Ó35Q0P04Fć †f )†\…\@$¤Ŕ2Éą\Nž\úá@.}0éé«PRTšĘĄďŕ¬`ČĄď˘m¨`Ëĺé˘Ŕţ@ţ‡ýźúő˙ţ#ßţŹüö\®ž\\hE*a endstream endobj 802 0 obj << /Length 95 /Filter /FlateDecode >> stream xÚ31Öł0U0P0T02T06W06RH1ä*ä2 … !2Éą\Nž\úá Ʀ\ú@a.}O_…’˘ŇT.}§g ßE!ÚPÁ –ËÓEá?< ťŕrőä äěWGz endstream endobj 803 0 obj << /Length 210 /Filter /FlateDecode >> stream xÚí’±‚@ †Ź0táčx °™ &2čä`śÔŃAŁł>Ú=ŠŹŕČ@¨í..,:Ůär_{ýŰ^Ň4…†óICĚƸŹŕIÂľuĺaw„Ľ˝Ć$=ç(čr—óő:_N1]ŕ&Âp eŠíV+kŃ]n‡C%0!ăŰ$Ş•ÓŘ”'ëlŠQ.1ř¬őDPë°¨‡¦iô†€•RŻŤHźO𤲀Űt ŞÔ—€?mµ6 ş™M?ó~˛¨˛­fŔ¬„Ľ0­T endstream endobj 804 0 obj << /Length 327 /Filter /FlateDecode >> stream xÚ•Óżj„0Ŕq%C ‹Ź`ž *˝B]®W¨Cˇť:”NmÇ-ív¨Ź–GÉ#dt—&ć—?RiDř¨ ~ýi]_\V´¤;˝×WôzGß*ňIę’šMš Żdß‘â‰Ö%)îôYRt÷ôűëçťű‡Z‘â@źőm^Hw ‰YmVěaܶb«Nß4RbŐXM›Î”\u®N›n•ňnbÁý |ä± –mśbçŢ©¶‹LE捴]$â±±7ć!3äťi»ČlŚťzçÚ.2Ob'Ţzş>¸ŃtîŤ!ň¸´Ź—Ć9™7Ę ×CîŇ.Ík&) 7LłČʬ ¦k–üÓůě“ËőÁóÇ ÁÍą!ľ·!×KkąKŰřĚ!×#°€ÜĄm<ćá“ĆĚţçÎFkó(­°żŹ4J@?űŻÉmGÉ/đc Ą endstream endobj 805 0 obj << /Length 267 /Filter /FlateDecode >> stream xÚµ“=n@…Ǣ@šfŹŕ9Al%"’C$SX˛+V*;eŠDIŤŁpJ ÄzÖ°ňÚîĚŠŐ·üě›y^çOĎ‘=“Jftń“ěॽ±˙ÂEŽzKI„zÉWQç+úýůűD˝XżQŚ:Ł]LŃć™óŃ@G¦j…ĚQ¨P¦ÚĎş§‰iz‚˙VČ8Jy›Ž¦<_’â­oSČrʎűşăJŹ^CoCżâÁŕK(®ĄvRť“ਾB,á|.ĹÝÚWKĄuĹɡË`DuO6®KNý™‡‘Ż6‘_i JGăT+É­”´ ç¤KP±„ű˛ˇJ¨đ˙~ ßsÜŕ uÍyë endstream endobj 806 0 obj << /Length 338 /Filter /FlateDecode >> stream xÚÍ“?N…@ĆgC±É6˝€QăÚ¸Éó™Ha˘•…±RK ŤvF8Ţä%^€’‚0Îě ‘ĽZ ř-;;3|óqvrX”şĐ§ú ÔĆhs¤źJőŞLˇů6Ç~çńEm*•ßiS¨üŠ^«ĽşÖďoĎ*ßÜ\čRĺ[}O‰TµŐ@W‚€dŞR‰;Č,Q–G¨9ŰCi ě7rXKËä0—Aŕ@$s;’˛ş:ń>GOĂ”11PV¨GG’Ş ŕ{ ré(µëÜ‘  J}1*7S(»$;SheIŮLő>âoúCřʍ^Ąf­i0Ó¤ÚŮIń™Î§ÉĚô¬đ§ Cś4ôqú˘ŹŽHşčG®ą‹nJŰč°¬‰®łścÔC +{ç7ZŰÎ۶>» Ú࿢‹*E!ĽŐeĄnŐ/ŮĎíă endstream endobj 807 0 obj << /Length 228 /Filter /FlateDecode >> stream xÚ•Ň= đ×t y G('«Ćv3ń#±‰NĆI4:—Łő(ÁŃIÓľú¤H~…ţiżŐŤE[ôLK;¶nc<`’ďgŹŘěqˇ\Š$A95˝(ł™8Ď;”ĂůHÄ(Çbe–Yc6ş,wh*ŕúŔ´.9)"1RH HP+wh ľyĹ›(¸/*±†řPč#qRDŇĄLůSőÜ×ő¸c_˙˙˝źčć“˝®˛ŹéPčŇĺ[Ě+^« —& ĘIş ¬)J˘˘t*Jl)sĹŞJ¶SŕN2\ŕîŔU\ endstream endobj 808 0 obj << /Length 349 /Filter /FlateDecode >> stream xÚŐ“±NÄ0 †]u¨”ĄŹPż´U‘®ť"‡D$02€`nyłăMNâ¸ń†ŞĆIÜ»´EŔJ÷“ă8vâ?ĎŠă˘Â x”cµŔ˛Ŕű\=©Ň83,OÜĘÝŁZÖ*˝Ć˛Ré9»UZ_ŕËóëJ——§«t…79f·Ş^!đŇ ű5D±Ĺ6XÖĚ;Đ–©‡Ćí¤uH@†cýN.|ÍŽrá.m@ťµÎłŰŻF|Ž=›Mb¶š Ö´`]Ăśb{)Đ$čŔU2¤ئçżô' Ă„cWľ|–rƬÇ,eŽ9sóýĂôOx^cfĄu=ţĚzĆ.‡–{6śü‡·›ňđÖS–1´ڏ;ôAýŹe&oVýögŰ›ů`¦_#ś7Äź˘)ŇNGĽĽ čŤöÝYmv˘MŁŮ­č×Üf !&\oę¬VWę ?¦! endstream endobj 809 0 obj << /Length 344 /Filter /FlateDecode >> stream xÚ•Ó±N„@ŕ%$ŰđěÜsT$ç™Ha˘•…±:--4ZĂŁń(<‰…„qŮřŮňH  ůwŘňlwUÜĚ\Űł8ĂÎĽĺúS{{źÍ·óó‡>V:}6Ĺ^§÷vT§Őůţúy×éńńÖä:=™—ÜdŻş:šŹF…öÚ]jQŻěŰĹÁ¨V‡÷pŇÁe × ž`)v‘⨇ăv‘âşI­ćH6G˛9’͑줅9’Í‘ÎÁK¤łD:K¤łD:—›ńĚĆŐ1aŢdă’P[=ďxŞW˙Ž5-ßő7”´|ď´¬µ1ÜÄ´¬©ĄČN®­'ń Ú¬ąÁkčű%Eđš{Ć^KĽ_„Ţ=٤éĎ ú„Ї\;ńŚć"¤=Ł˙ąéa7±ô¶oü;®uĽSňŻÍ×áRë»J?é¤[ą endstream endobj 810 0 obj << /Length 157 /Filter /FlateDecode >> stream xÚ3·Ô30T0P0bs #…C®B.3K ßÄI$çr9yré‡+Yré{Eąô=}JŠJSąôťś ąô]˘ĆÄryş(ü Ä0ř!Ô(c2~f0ÂH`0ăf°c0řáŚP†<Ăƨ‡1ţCŚ0;ŚÁcÔCĚŔ¤ř Ăŕrőä ä6n6 endstream endobj 811 0 obj << /Length 311 /Filter /FlateDecode >> stream xÚŤÔ±N„0Ŕń’oé#´O ”\<'HÎ3‘ÁD'㤎ÝHŕÉ ĆÁŃGđ‘áBýú•Iűť%)đ+,˙¦`ĘŐŃz­ ˝ÂaJŁOJ}oŕ Ś9Ć™ÂŮ=ş{„MůµĆyČĎqňćBż<ż>@ľą<Őň­ľ1ş¸…f«­µŁ #q·8&ĎtáŢ3űźxž=%Ýüć·őT]_¶'V1ü´± ňĂîSď>8|ş‹bGýx ˛¦~ه©¨_‰(JęŻfÔß2L©Šcâ–# ןî8ş~w‰˘[ŮstýJptýU,Ýr´,]˙Äű±ž#öc},»=ťÖ3ÖłTëc)íŰfôŃrLi‡G’vKA;+DEď ńß1Ą]ţ*Y÷‡¨ÄB8kŕ ~o§L endstream endobj 812 0 obj << /Length 209 /Filter /FlateDecode >> stream xÚł°Ôł0U0P0b c #…C®B.s ßÄI$çr9yré‡+[pé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţÁë˙8ëśőżÎJóű˙ ,fn0‹¤ÂŞ˙cŮ5CXň˙@Y ÂbGb}ŔÂúe1ceýˇ ź˝ěH,ln~÷ĺ ź#BBđPŚş`pÎb€±~ŔY 0SFYä± Iť—«'W TŰ4# endstream endobj 813 0 obj << /Length 290 /Filter /FlateDecode >> stream xÚµÓ±NÄ `H‡&˙ŇGč˙JkŤ×NMÎ3±‰NĆIMÔčÜ{4ĄŹŔŘá"R ÜßČŤ%)ů ~řˇŮśo®°ŔK<+±©±ľŔ×>ˇ©Lcuĺz^ŢaŰxĦqkšAtwřýőób{Ť%>•X> stream xÚł4Ô31W0P0b 3 C…C®B. rAÉą\Nž\úá \ú@Q.}O_…’˘ŇT.}§g ßE!ÚPÁ –ËÓEÁţ?ü!žu€ˇţ?3ő‡Äb°˙S˙Ââ˙W˙Âb˙WÂbţWßa1ţ«g€°Xu0V6V ŚeG,ëŚe˙Ć’'ťĹc1ڞ†%‹’śÍârőä äăCě< endstream endobj 815 0 obj << /Length 233 /Filter /FlateDecode >> stream xÚ퓱 Â@ †S:Y|„ćô]Ş‚ťÄIÝÄöŃú(>BGńLÓZD''—|üą˙r7śŃ¦©;¤©M CA‡ş>­ î0đYÔÔmťŐĂŐśŐeTŃ„űăU8A5¤…!˝ÄhH–ăŕpÉľe¨Ű ä§P±ţóď¸Vr˙…{ÂŮźyą%źŢرWáŰ K¶ąŽp,ěŠ+ľçą&űÂuaĎJNE±IŢM şś4y0犉%®Ţ­ŕŘ^žĂů ŽâAlćH 4Č—¬6eOć†E8Ă`ň| endstream endobj 816 0 obj << /Length 347 /Filter /FlateDecode >> stream xڕұJÄ0Ŕń YúÉ hŻw vąŔy‚ťÄIÝŽkÁÁ×ęćxŻĐ7đĆ ‡źůľ/ׄëˇHű#MHYO =ÖS}TčňDźNôC!źe9q‹c}:ĺ/÷Or^ÉüF—™_¸e™W—úőĺíQćó«3]Č|ˇoÝAw˛ZhpĂ !j€Í- ´GÝ ˇ #gM°rÎÜ>˛6n¦Ţ3˛xĺf[ň22>GŢ–üŤŃ_Ţt2Ŕľr ş NɆݲń•‘»aw{VdS"Ř9rćm÷Ľ"sŘ22Çq ćDŽä,‹ťxc'˛SoŚäDŽĚĽ1’ł8,¶ňĆ0NdoŚśő¶> c¬Ďâ°Ř[o łÁ»DŚÜeaXě¤w ď]đGoźmđş·‚uüzg|UNůj Ľ»–żyö l»îţ¶i[5ËóJ^Ë÷űř· endstream endobj 817 0 obj << /Length 322 /Filter /FlateDecode >> stream xÚŤŇMJĂ@Ŕń˛Ě&G9ITbݨĚBĐ•‹âJ]şPtťw´ĄGČ2‹Đń} Ĺ‚Đ@É/M;^2«úěâ:ÔáŠ?—auŢ÷éÚ–®kľäŻnÝ»ę9´­«îé[WőáűëçÝUëÇŰиj¶M¨_\ż >ę'!‹|ś°'ŚąŠ¸€ß fđ ˇdĐoéţ~ěŔĂ@k:$D§ ´jš2,Š"Sp#>S†QÁM98eĐs– )H)H)H)H)H)H)H)ř'…SŮ!µ?J‡Ô|”â' ĹhM†¤¨M ¸PŽ–"hŞDKĘM x*Ź6ž`Tčxô’t*ŚŤY‚MQźdQ›yDM IńÓ]‚š˘¦rZLRÁöăipw˝{rżqŤ% endstream endobj 818 0 obj << /Length 270 /Filter /FlateDecode >> stream xÚ•‘±JÄ@†'¤LsʰóšL® ś'BĐĘB¬> stream xÚÝ‘=NĂ@FÇJišÁsX[NŚ©"ĺGÂTPR€ ¶;®•ä 9BJGZí0;Ţ J¨Řęifw<~ßEqžU”QAg9•—Tôă –)fTŤűÎĂ3Îj4wTNĐ\IM}MoŻďOhf7sĘŃ,h•SvŹő‚`Úć_Ŕ ühv= ™{H™× łďńžˇ±ÁBĘ [rëˇ%k‰TťďË3¶ü·š.‚ 0=€;  ý Úż€“űv>ň;ö»ŐbC _Ć\”Éő¶Ařf #Ťŕc§—č,'·4/+;h‚ťĽq1h¸¬ń?7p% endstream endobj 820 0 obj << /Length 243 /Filter /FlateDecode >> stream xÚµ±NĂ0†/ę`é?BîŔ‰dSş`©‰ Heę€hÇ XI-ŹÂ#dĚ`ĺ¸s‚ştĹËgý÷Űżî·×~IyşŞ)x ö5ľŁ_‰XQ¸™&oG\7čväWčEF×<ŃçÇ×Ýz{O5ş ˝ÔT˝bł!€˙€śČŁ‚™Oޱޖ!2J`@;€÷PŽPČ<˛;…‘GgČ3E9cĚą*lĘ0´9Útüř / Îŕ Ýěi†Őnʲm'ľ©ż;)¤ř–),ĺbČß^‹ěJq™©Ý‚§®ŁzµlŃđˇÁgüÍF‹ľ endstream endobj 821 0 obj << /Length 253 /Filter /FlateDecode >> stream xÚŐŇ˝NĂ0đT"ÝâGČ˝u˘~n–ú!‘ &ÄŚ Ý7č+őQúíŘ!ĘźłŻń‚ŠÄ„dĺ—‹ťł˙Ęl4¬ć\ńŻjžU<ńsMo4ťHQÇúćé• Ů{žNČ^K™lsĂďź/d·K®É®řˇćꑚgáʱ‰w_ s=Ě˙‡$ p8E €.˘° (±s‡×…˘ŔźÂ4Ž2ěĄ*ȱÓ| ]ąŃ6&âÜ´LčÎpßŕÚ‹Ŕ_ŕ‡ýřËÇIHGN!ÄXĘ>±] łŹ7ž#†Ýfćýß".ŚÎF«?«Ç^Q 3Ň™Ö Ýщb= endstream endobj 822 0 obj << /Length 244 /Filter /FlateDecode >> stream xÚ…żJ1‡gŮ"0M!óş·`D«Ŕy‚[ZY•ZZ(Úşy´}”<•aÇ™ąăôP1|đĺ—?üâéáIO :˘žâ1ĹH=>cTąPc;÷O¸°»ˇŘcw!»á’^_ޱ[^ť‘ŘÝĘ™;Vŕ8Ś‘?dmgPÇj·\R…q :“dÄ„*Á |…Vbn¶;głEó çdö1Öo( Ř÷aăhDB˙cüł!ýD[Áo¬1żEnĄ ౦ä%ięÝînŞ6N:ó\ŇZŰ` æ]H›_ŮI<đ?yë­ś endstream endobj 823 0 obj << /Length 324 /Filter /FlateDecode >> stream xÚĄ‘?JĹ@Ć'¤XŘ&GČ\@“HňBŞ…çL!he!ŻRK EëÍŃÖ›ä¦L2Î쮂°áÇîüűľÉ®9o[,±Ćł‹w565>UúU7ż–Řv1ôř˘÷˝.î±étqÍďşčođýíăYűŰK¬tqŔ‡ ËŁîŻ|˘QŃŃ’“CD–F°ł"RcB|&;¦JŞť ŔĚĆeÂ%wąpUľëö3Bú?OűţÄÂ|€ G(ú‚^±'€f ‰]âTHżŘŻđ“|X9éʶĚÜ/O8E.‘> stream xÚ37Ö3°P0P0bsC c…C®B.33 ßÄI$çr9yré‡+™qé{Eąô=}JŠJSąôťś ąô]˘  bą<]ě0€Á˙˙$0a †aĂ˙eü˙ßf0˙˙˙Ěŕ‡xű˙ůőŔŚ:ű`PŰăçă?H˙˙ß  e00°˙?€Ěř‡ÁřCăÇ(ÎřŚv q€—«'W lů2 endstream endobj 825 0 obj << /Length 138 /Filter /FlateDecode >> stream xÚ36Ó35Q0Pacc …C®B.# ßÄI$çr9yré‡+Ypé{Eąô=}JŠJSąôťś ąô]˘  bą<]ěţ``ü˙€ů˙0f˙˙+†ÉÔ‚ô€ő’ ä0ü˙ʉaŕ˙˙˙@Ç\®ž\\ÍŮĄ; endstream endobj 826 0 obj << /Length 107 /Filter /FlateDecode >> stream xÚ36Ó35Q0Pac c…C®B.#K ßÄI$çr9yré‡+Yré{Eąô=}JŠJSąôťś ąô]˘  bą<]ě0ü˙ʉ™aăÄ˙„Žą\=ą൉Ă endstream endobj 827 0 obj << /Length 232 /Filter /FlateDecode >> stream xÚíŇ˝jAđ WÓÜ#Ü>·ÔŚ‚WZĄ©LĘ+łŹvŹrŹp!E¶›üçT°+‹ ó›ŹÝ-ĆŮÇvďŢXÓĹqöÁt;ćÍń';ë±j-->xsúŚÇéiNó©Y-×ďśgOŮ‘yÁĚ+ç#CYEI şO$RáxŠ%4DJʤnď«Ň ó˘ŁŘŇ×®U¶¤ HŞ@Yű$߸»Np·â§¤D@Ą(€ţżŘAx^ć §¨ĺ9ěĹE…˙ÇÍŰ„ÂĆip xśóś˙vÚiC endstream endobj 828 0 obj << /Length 184 /Filter /FlateDecode >> stream xÚíѱ‚@ ŕ& &]xúŢÜHLtr0Nęč ŃUy´{ጠ„zwŔˇÍ×6˙Ôd4”’™JBG´ń„qlfiG{Ř1+P¬)ŽQĚÍE± Ëůz@‘-§˘Či’Üb‘¤‚µ©ŇÁc®|ćÚ!P÷Ćái ŕ±®!`{čř.˙TĽĘV6ߡýAÓő_°yÍŔ4Ő8+p…o âřš endstream endobj 829 0 obj << /Length 231 /Filter /FlateDecode >> stream xÚµ‘±‚0†kHnáĽĐ‚±0’ &2čä`śÔŃAŁ3<šŹÂ#02Î^KL%!_sý{˝ţ¬ćI‚!.qaĽ@ĄđÁCT±Ý9ß +@P% 7ş ˛Řâóńş‚Ěv+Ś@ćxŚ0> stream xÚÍŃ˝NĂ0đ‹2DşĹŹ{pBóˇN–J‘Č€D§¨02€čśĽŻ”7ŕň-[+U9.¶«*SŐ%úéě;Ű˙ăëlD etu3˘2ˇ<Ł—߱ȥšPYúĄç7śT¨çTä¨ďĄŽşz ĎŹĺ+ęÉă-Ą¨§ô”R˛ŔjJ!7 0Ľ†xóŚ bf Ĺ­ięfŘŞPď ě¤xÁŹ fŘ BîdYqë  iĺ`ËćurĎóă?3ýźďŠđ!ŘXĚ>1źˇ “}ĽűŔŁ•íčA}űő»˙ŐŰa˛sc!C:‡Ý9ŕOżD(f§SŔ» gř ‘dü endstream endobj 831 0 obj << /Length 169 /Filter /FlateDecode >> stream xÚŐĎ;Â0 ĐtőŇ#Ô' Ť’VbŞTŠD$02€`nŹĆQz„T d¨jś20őXö“üYśé™žcŠš+ă4xRp“s?¶aqĽ@iAîĐä W<i×xż=Î ËÍČ ÷ ÓŘ Eá˘^ą6ˇ–­É±Câ‰:_ř:WóŃ«}ßÍO_ /h‰ Ćmú ýIž™–¶đj^¤ď endstream endobj 832 0 obj << /Length 259 /Filter /FlateDecode >> stream xÚ]Đ1NĂ@ĐĄ°4ľ;ŰŠŤBĄ$\ ‘ŠQ%Ú¬ŹćŁě\¦°vY)˘yŇî·çŹÝT—ëk.ąć‹Šë57 żUôIőJ/Kn®ćäő6O\ݍ¸×k*şţţúy§bóxË[~®¸|ˇnËXĘp8™ÎŮë…HDŃFä#ň°Ô々Ú~Ŕţ¨¨7ö'ÉQČ”´^;LKZ+45qj@.dętÜÇv“ů!¤¸Ç"iíĐÄĚôehÖ”ôÁjŰ]˙dV絳˝ÍSuž‡č ±ýő?h©›ÓęgĺcfKxýşëhGżÁ•ˇZ endstream endobj 833 0 obj << /Length 186 /Filter /FlateDecode >> stream xÚ35Ô34S0P0RĐ5T01Q07SH1ä*ä21 (›Cd’sąś<ąôĂL ąô=€Â\úžľ %EĄ©\úNÎ @Q…h žX.O†ŔOţÁN2bĚH$;É&ĺÁ¤=¬“˙A$3ä˙˙˙˙?†˙8H¨úANň7PJĘĂç‚”˙Ç`$˙Hţ˙ ŔŘ`˙đ(Čţß˙ ýß E` qązrr:é“p endstream endobj 834 0 obj << /Length 187 /Filter /FlateDecode >> stream xÚíŃ1 Â@Đ  Óä™ čfŃlě1‚[ZY•ZZ(ZÇÎkŮyŰt¦Ž»‰… а{üáĂŔŹ»ť°O!ő¨­(VőhĄp‹ZŰ0¤(j.Ë ¦匴F9˛1J3¦ýî°F™N¤Pf4W.ĐdI ŕńKü#ZX€řă+üĎŢ8äŻČ’ ŕö„wĺÂ6î .n źŹÁÉÁNĂő<sUĂv‹öÁ848Ĺ”Ěđn endstream endobj 835 0 obj << /Length 252 /Filter /FlateDecode >> stream xڅбJÄ@€áYR¦É#d^@7ąÜl ś'BĐĘB¬ÔňŠí°¸×ĘÜ+äR¦gvE8°X>YŘźÍ/Η%”ŃYJyN«Ś^RÜaľaB«Ąß> stream xÚ•Ń1j„@Ćń7XÓx牚Ťŕ6l6‹@RĄXR%)S$$ť¸ćfB.2©ŇNi!ľĽ7ăĘ.V?řˇňÇu~žf*U+u–©ő…ĘWę9“o˛(čfŞňK˙äéUn*™<¨˘É Ý–Iu«>Ţ?_d˛ą»R™L¶jG/z”ŐV!â­Ť˙Cě´Ř@µp` 'h–Îě'–Ä‘vÄ ˇ3k"úótĹ{O<ľ8‚ FŘ ¦evb8Ń83Mđ‹mH Є̎iĂoě“zŃĚ>úBa"0‡Ži5s?hbé8–TÔ0µcíŮĚÄô00c*ÓCďŮ»1í‚Ö ¸i<Ť¸8Î^°óŽ‹­gëvJpĎi\DäXî‘וĽ—!‚ý) endstream endobj 837 0 obj << /Length 310 /Filter /FlateDecode >> stream xÚ…Đ1NĂ@б\XÚĆGđ\ś8ÁM,… á * D” č"ÖTą–o+řlé"ň0łłDQXOš]yţţňôx:ÁNđ¨bYâÉĆćŮ”OG8›…Łű'ł¨M~eaň ž›ĽľÄ×—·G“/®Îplň%ŢŽqtgę%Qm˙3˘ "Vě–ĺĎŠ<łźł•čXú1f3j îÔ„MĹVl!e±y‹ şo+ =Ěď¬Zy·Çę˝ĂÎČ[‘ÄcoFG\{SZ·ęƛЦQ?䍉`߆µ™=m˙»•;4ëMŰ?l½ťţś};Y«íTťjť¶Ä­őj´Ó©Ú őIP×Z§ël§klku釾2#}UJ.´҆RĚym®ÍaÉ˝ď endstream endobj 838 0 obj << /Length 137 /Filter /FlateDecode >> stream xÚ33Ő37W0P04¦ć ć )†\…\&f  ,“śËĺäÉĄ®`bĆĄďćŇ÷ôU()*MĺŇw pV0äŇwQ6T0ĺňtQ```c;0ůD0I~0Y"Ů˙Ić˙ ň?&ů¤ćDĺ(I˛ô˙˙ŕ"ą\=ąąVI˘” endstream endobj 839 0 obj << /Length 301 /Filter /FlateDecode >> stream xÚ}ŃMJĹ0ŕ)Y˛é’Ř–G_]x>Á.]ąWęŇ…˘ëôh=JŽeĄăü? ÚŻif¦“tßź ChĂžŻ6 §á±s/®ßŃ\¦ĽđđěŁknCżsÍ%˝uÍxŢ^ßź\s¸>ťkŽá® í˝ŹŔo@ŁB,DŤ¸'€DdZš"-š,-ÚB/6¨3"x‰š˘äç”™ś®—ÓĘ®k‰í ËpŢ7q|Ě$păFúćšżČ »ůdíL™@ÚAvüZ´HĄŮFÓ¬¦YM«5Ţk|,ZdÖěIłeb4Đj`Môäłg!@ŤTt¶«`[ČBÍ».ŕA8ă˛EţőËwĚ•b«ÔŠW˘’üÉü'îbt7î}tű” endstream endobj 840 0 obj << /Length 305 /Filter /FlateDecode >> stream xÚŤ‘˝N„@LJlA˛ ŹŔĽ€ĹgErž‰&ZY+µ´ĐhÍ=Ú> Ź@IAç‹ á·ě|ýgf.ëK xQá®ÂzŹŻ•˙đ!đe‰ő•Y^ŢýˇőĹ#†ŕ‹[ľöE{‡_źßoľ8Ü_cĺ‹#>UX>űö)Eŕ§Ł‰żŽNŁČGG#›"qhfHřÔ8ľĎéäfEĘAEIĹČ=ż˙„Ĺ-Î’%$©#쵂H\ŔŐWčfäą  Íhg™…™cgÝşi†ą8iZţG«`©s+´¤É,25×ô\iÜ`2[Ě[¸¨ČE3)Dä/ţbZÁť1.8G •I¬łéUuužRŻáŤÍ:îXÔ&ĽoÝ´í]ÖŻ"MşÎÝß´ţÁ˙éýëo endstream endobj 841 0 obj << /Length 225 /Filter /FlateDecode >> stream xڽнjĂ0đ ‚[ôş'ěPŰt±!tęP2µ;´4›qüh~?‚G‚$ÎýĹC»ő@úˇBw—&ó,ă®+]pöČo1}R2ć˘ń8^Ľ~в$˙ĚIF~{Í’/wüýu|'żÜŻ8&żć—Ł•kžŤnűLMÔĐ@;ŃÁž&žEőD-twń>‡5 pU/jh:ŘŠ¶,PW+D5Ŕ^Ôťh ma#:ôYŔVpÔ=ěDÓŠşb~9¬a€g‰ć/Ě˙źuř˙wiSŇ]]Óq endstream endobj 842 0 obj << /Length 285 /Filter /FlateDecode >> stream xÚ­Ń˝JÄ@đY l“GČĽ€&áH˘Ť ç ¦´˛+µ´P´N-ʞʰ`“bąu>r‡"X?˛ŮLćżÓ6']‡¶x\c[awŠOµ}µÍšéńLß<ľŘMoË;lÖ¶Ľ˘e[ö×řţöńlËÍÍÖ¶Üâ}ŤŐí·hF8s0;ŕŰ¤Žˇ+*łŻLʨ€•Yń ‘ iţźŚk›ŕäď!%Nóą4Ťtíaŕ(.JÚ‚bŇî> stream xÚŤ’=NÄ0…'ÚÂ’›!sHRd ‘–E"T ()@ Qa-GŮ#¤Lyxcó´‘•Oňóx~ž×ÍaŰrĹ ÔĽ®ą=âűÚ>٦ÁfĹíqRîí¦·ĺ57Ť-ϱmËţ‚_ž_ląą<ĺÚ–[ľ©ąşµý–‰ČŇOdŔ%2…Č ¸9SQväTňÔy2ŮSÁ Tŕ» 2NŤXFvY ňŚř_ČąčíC!š‹"Ţş%R­î/şQ‘‰(ڶ"!×V$ŢMŔ x#$“0"»W ­ ÎPrÂ(¨ě$Ó7´Ŕy?â Âîßčö"^Ň\ć%ňI‘Édľ«^EŔ€AíČRÉŻiP7ë@tĘę4F¦ľĂ}śŇ·  CÔGÉžőöĘ~†\ö endstream endobj 847 0 obj << /Length 382 /Filter /FlateDecode >> stream xÚťÔ1NĂ0€áD,yń⸑J‘Č€b˘Ś ŘJ“Łĺ(>‚Ç UŤťÄĎĎ)‘",eřUM~żVĘőĹŐJâŇ^R®„, ±“ěÉbm·Š~ĂÝ|}g›ŠĺOvcÍň;·Ďňę^|}~ż±|óp#$Ë·âYŠâ…U[‘ô«LđŠU7KeÚYĄF-1zVÔt ĹÍqV™9-Ti̬jcĐË˙DÚG:ś˘‹U#ĄşF)R]"«‚¨Xµ )h‹Ĺ[ś‚7±(RfRd ViŹ%¤¸ž(E:8AŠ}$ű](E7U“öR‹hw.BLÂĐ^d™Šx'Ć)„Ézť ËTTö2%AaźËΕ[Łř‘ŇQę/éa`D a¢jűBLĺĂđ˙”x•5 J‘%çňaĘQ˛ü›4>ËTɨŁW;NËą†ůIA ˛ř0¤!‹Őţ˙@÷źöę†CÚĹĹn+öČ~?]T˘ endstream endobj 848 0 obj << /Length 200 /Filter /FlateDecode >> stream xÚł4×32Q0P0bKCK …C®B. ßÄ1’sąś<ąôĂ,Ląô=€˘\úžľ %EĄ©\úNÎ †\ú. ц ±\ž. ˙á ćĆ˙˙řL$¦<‚ÉŽ`2" HĚzÓţś)Ź•ÉŹ•ÉNÉŚÄü€ŤÉHH3ü É@$“™“+“Á”G0ëáLć˙0&ĂD2Ů\dŰř 9’ ßiÄ„€Q&$Bł3‰L.WO®@.u·pÎ endstream endobj 849 0 obj << /Length 410 /Filter /FlateDecode >> stream xÚÝ”ÍJÄ0ÇSz!/ 4/ mV„Âş‚=zň žÔŁEoBűföQözěahL2I›Ôýđl(ß43“I2ą§gKQsq˛R.…, ń,Ů“…±Ú°ŔżOŻlU±ü^[–,ż6?X^ÝŹ÷Ď–Żn/…důZű3•ľX{ű¨ŢEäµ;IýsŞ÷ľcŰ!Íß©ÜFîáÄ4ŢôAâ3ęwť”Îh(‰hěŽmä» ÉwUa7ҨSiÔĹ4ępu?Ź”!óŞŃä–Ę©M‡—*ŃP;•R¶űĘHÁ¸W7sĘ•o3)Şbă4Ň*ć©©Îr4)mđjRüěŞbwěy”K endstream endobj 850 0 obj << /Length 107 /Filter /FlateDecode >> stream xÚ35Ó33V0P0acK …C®B.s ßÄI$çr9yré‡+sé{Eąô=}JŠJSąôťś ąô]˘  bą<]ţŔ?\$ă˙˙ Łä( !ń§.WO®@.!•ý8 endstream endobj 851 0 obj << /Length 308 /Filter /FlateDecode >> stream xÚĄ’1N…@†gCA2 G`. @˘lIň|&Rhea¬|–íŚxŻÄ <‚Ć‚0Î̲ϼDm„dř`ggţď÷¨¤CÚ«Č×T×´©đ}Iz×>¬\ßâŞĹâ‚|‰Ĺ‰|Ƣ=Ą‡űÇ,VgGTa±¦ËŠĘ+l×đvuĚöLůC!š x¶”r~`]íś„Tł VIÓm©Á¤ oß0/Đm+ÖHł-8íŁÚŮ ŕ˙ĐHĹ´‚ăňĚ%'bÁ eA†„ lŽR§(~ FYt‘G»%4¨˙xÚ‚Íáč~Vŕ´  *ßLĺ÷Ł Ë^Tjžňç Cy–Äş›ý=äLŮßKg ť9”’Ť‰Ń鏀Ç-žăţuO endstream endobj 852 0 obj << /Length 274 /Filter /FlateDecode >> stream xÚ˝‘1NÄ0Eä"Ň4>Bć¤HŘ­,-‹D $¨(PR€ %>ZŽ’#l™"Š™±WA‰›g}{ţŘóŰÍé†+nř¤ć¶á¶ĺÇš^¨ŮŠXq{–Nži×QyËÍ–ĘK‘©ě®říőý‰ĘÝő9×Tîů®ćęžş=(te!LJBzá ň„pLa'=ö0sŞ˛ ŕ–´ďEsB5qÁgZÓoVŽ‘ů‘V˝ż°PJ}!öJ§,–D;'š^Ezţdřgţ|‡˙F÷ ăżWšŃ®”9!óÄ!×9Â&Ńg1¬Â#Ěę&Ť$|¤ 3ńČfÍk€‘»j`GÍsA?óMťŁ…[Ĺ©tŃŃ }g¸z endstream endobj 853 0 obj << /Length 275 /Filter /FlateDecode >> stream xÚŤ’żjÄ0 Će2´äâhCIĆŔő ÍPh§ĄS۱CËÝěCZJ–ńfŔüé áî endstream endobj 854 0 obj << /Length 191 /Filter /FlateDecode >> stream xÚ31×3V0P0bS CC…C®B.S ’JÎĺrňäŇW05ćŇ÷ sé{ú*”•¦ré;8+ů. ц ±\ž. @đ˙”˙˙Ěů˙H2©ţ˙쀤Ŕję˙1ţ˙Tń‡H1ţ˙Áţ˙PáĹţ˙ĹŁ€(y8Ňg˙żJ1ÍR ő `JŽL1Đťú˙ěg|Ôąl”GŔü—«'W ¦» endstream endobj 855 0 obj << /Length 369 /Filter /FlateDecode >> stream xÚ­’±NĂ0†/ĘÉKÁ~H*J#¦HĄHd@‚‰uFL îŁĺ x?‚GVźĎn*PĹúbźßý—®;]ŞV-ŐÉY«şsµZ©§…x]«čąXĄ­Ç±DsŻşV4×a]4ĂŤzűxÍúöR-DłQ ŐnŰQŔŁßhĂk$"TáŃHtPpúËAŤŁž|íANmíC¨‘b©=«Ř\Išč*WEđ…I¤ §?AFŔ˙c.Ýg¸‡TE¶Éţ€T{€čĆH~’?d¬&Ç>ÉCK®F źĂ(,«@aR7ĘC°ż;źaĘ€» ař ”Gi‰1ď1XŞ"őbWâ Ëčt>éŕX‘V žŘ úM€NŢq2¦çÂŃč–вI3čă Ď:f—îę=ß>Ę;3 sÓÂ\rýÜaj.·Y†I§â˘ě]”—l!×fq5;ń „sp endstream endobj 856 0 obj << /Length 146 /Filter /FlateDecode >> stream xÚ31V0P0bcKCC…C®B.c€b%çr9yré‡+›pé{€„ąô=}JŠJSąôťś€|…hCX.Oţ ö?€Dý ń˙ă˙˙P‚ů˙˙B1X/İy`“iŘöÖ˙ÇA0€‰za?Jü‚Ř.WO®@.Ó3˝Ž endstream endobj 857 0 obj << /Length 286 /Filter /FlateDecode >> stream xÚíŇAJĂPŕ”. łé:'č{ ŃU ­Đ,]ąWęŇ…b×/ĹxŹŇĄGČR!dĚĽyó$Áî ľLÂ˙'CÎÜ˝i§’–„°$„%!, aůJE:Ű‘>÷–ôNšňAšĽO"j“ş$ŠúJjâ/XĐÁSüŽ:‰ÇQ3jŽ4Ą¸—~áí‘Ć7™Ť¤N${Öź%u,©JęXR7”Ô±¤n()ŽŞônÍ»¨y#ő_%\Ă7 vPĄ endstream endobj 858 0 obj << /Length 111 /Filter /FlateDecode >> stream xÚ31V0P0aC…C®B.cS „’JÎĺrňäŇW06ĺŇ÷ sé{ú*”•¦ré;8+ré»(D*Äryş(0°˙o`ř˙Á&ęA„ý(1Ä` ţ€Ťŕrőä ä.sŘŕ endstream endobj 859 0 obj << /Length 258 /Filter /FlateDecode >> stream xÚíÓżJÄ@đ‘+Óä Ľ}s8ő@88O0… •…X©Ą ˘`eöŃâ›,,MąEČř}I á@ě®XŘßěüa‹ńůáŢbáfnŽăó·?w·^Őç‘ͧ›{]š]"ÇkvаfĹ™{~ząÓlu~ě]»+Ô\k±v’šČ2ŠH‚‹™ÉŽY@КѩYÍ`;zjeÂŰŕR¬“´žZ58J‰$”Ő}¤A/yĂş´¤B‡Ŕ°´$ŔUÇŢ© ôťďŇÜö>˘?ĂŻ~ĺ_ľ8zđÝŃťŚßúášn7wEÇÍčfë­˙ÁŘ7Ăća9ąţj=)ôBż´VĽM endstream endobj 860 0 obj << /Length 198 /Filter /FlateDecode >> stream xÚíұ Â@ Đ”B–ţć®EÚë j;:9“: * ní§őSî:vc®…ŽĹÍĹ!ÇK.!Kâ| %â)E!Ľ˘Ö’ű6µ‡3¦9Ş-iŤj)UTůŠî·Ç UşžS€*Ł]@ţóŚŔc€˘fW˘“Çl:%Ěu§ÂáW+§~·Ť®ÂŽ<ޤS”°WĘS¶t[UVł^qŻ'ČľV+cU÷2ŞUţőÉ•°‘Óáć[á"Ç ~ÎÉ$„ endstream endobj 861 0 obj << /Length 267 /Filter /FlateDecode >> stream xÚ˝’±NĂ0†u¨tKÁ÷ʼn¨śn‘J+‘ &ÄT¨Ú9}´>Jˇc†(×;۲,ťČ|>ű·.÷˙Uu·Ä—¸(±şGkńŁ„o°+.h+żłű‚ućí Ě#—Á4OxŘ?Á¬ź°łÁ·‹wh6¨”ŇtRňdD˝śÔ gftáďŚ:Ő sÖčQÄŁ_¨zm>ÝörUÇ"QđË-¤ÁťĹÜĂ wÍhJ ś"ÔÎ5ův´ş[€\ţnilňżáď4r?:™X€ÉTÝŔGç›ç2oJźÜI~EŁ§â¦©ď™$ÁĄ¤ĺlt?Ňó,m/p{"ô endstream endobj 862 0 obj << /Length 285 /Filter /FlateDecode >> stream xÚÝŇ˝NĂ0`W"ÝŇGČ˝rÂOšN–Ú"‘ &ÄŚ ㊱ŹĐGiĹŹ±C•Ăg»m¤fČb}¶ĎÎéÎEŽ)^âŮyE†ůľdđ^Mqz¶žß`V‚|ŔIňĆ®,ońóăëäěnŽČ>f>Aą@“‘B‘N¨ Şj§Ąý§ź]D;§µ•ÜhˇH QńÁ1Q󍊶¬†e‡§Š7F˘8XxiV»WE} ?ră^ő‰’ŽĚ Ť;jţچfźôÔ «ÓŞőU÷X{ŻúĐ#Óí[tč屿ˇç-§˘Y±ŐşvíµZmc޵ú¶ŻÇř|ř•yą'㹥˿… \—pżő [a endstream endobj 863 0 obj << /Length 184 /Filter /FlateDecode >> stream xÚĺŃ˝ Â0ŕ‡Â-yą'0­6Ą¨ ftr'uTÜšGóQň;祝\ÄÝăă~˛äňá +0Á§.0×xHá:ă: eěOPZPÔ¨wAŮ%Ţ®÷#¨r5ĹÔ ·)&;°3’DÜ"†Z*rLDä™^cj&öUŘ‘ŽžË^ĽÝďtŚ;ś;jÁďUÍxa|‹t-†ž?ăţ>˙ßW`na o™Ľ? endstream endobj 864 0 obj << /Length 296 /Filter /FlateDecode >> stream xÚ]1NÄ0E”"’›\)sHRÄ4H‘–E"Tjˇ¤A‡”-GÉ\ş0ĆăhĹ’OöĚ˙?¶˝h,5ÔŃyKť%kéĄ5ď¦k(ţö2Uof7ú‘şĆÔ·rmęáŽ>?ľ^M˝»ż¦ÖÔ{zj©y6Ăž€1ŕ (ç+ bv`柀ŚçśŠU›Jô”Ő"š€~ň#Ć ČN€>…tâű%Á%ř1€č!*0jQ ¸AĎzŚđj:ޖѬĹ> stream xÚÝŃ= Â@ŕ )¦É2ĐÍĆ(IŁ#¸… •…X©Ą…˘ťŹćQr„”)Äuvý! jcĺ_13Ő{ť b€-lHl‡H\JŘ@Ó2Ŕ$Ľ]kH)F1!­A¨î¶űtÜG "Ă™Ä`*CĆř‰±oző_ěŐĚkjŁSÓµr«gő­ąŃŃFOÓTúŤ÷˙˙Ń˙™&Ď.Y<ĺä,I—¬(âŠdúě”&t^PkŹÔʦž‹-˛b0P0+ Čf endstream endobj 866 0 obj << /Length 199 /Filter /FlateDecode >> stream xÚíĚ= Â@ŕ ir„ť Č&H~ş@Ś` A+ ±RK EëxŻ”ä ą)SHĆY·,´ł°űŢ{đ’| iP2˘(¤m€Śc)}Š"»lö¨—Ǩ§RŁ.ft:žw¨łůÔ9­ň×Xä._n€Y”ň#ˇ¨4RF©‘÷×H}¨ôUʨ|#¶ŞŔąy˘AmäŠÜš[ŁĽ+w‰ĘcˇĂwčź’/î¬skĺ2WVör €“ř@T"Ţ endstream endobj 867 0 obj << /Length 370 /Filter /FlateDecode >> stream xڝұJÄ@ŕYR¶É#d_@“EďĐć§‚)­,ÄJ--íŽË‚/+_#ŕÎńÖ™Él ÇŮXŘowů™ť¬µv˙ČäćŔěYcóc3?4÷V?i›Ďp97óٰw÷¨—ĄÎ®ńĐLg縮łňÂĽ<ż>člyyb¬ÎNÍŤ5ů­.OŤÇ/ĆŃBá˝űŻŔ{€Ę7UŽäD) RľŁ=٬Ŕ÷8[ÓéQ+Vł­j3ZIFu¬v[¤H1ď‘ZV'呢Q “ý–jI ĄX5kęKHH0ʱ> stream xÚŐ“±NĂ0†/ň`É‹Á~ŇTS¤R$2 ÁÄ€(#V’GËŁä2fzśűR”1t€ ÉŰ÷ßö9[­Ď˛s»˛Ůš^ôÝlě>SŻ*Ďi`ü÷sO/j[ŞôŢćąJŻÝ¸JËűţöń¬ŇííĄÍTşł™]=Şrg@âĆ{’kG…Ł.L"‚D"MkÄŔ¸‰Ę-¬Z"ătĽ€¦!¤n Č>P­;&ęM3ٶ0¸í*lZ¦`·că}¨ëdÄ9ލđČ_gĽ+GÚď#qî!VŢŽ›ţŤű?Q=’F ÇdřŔ  ŕ÷ľgęř8pÂ"‚E‡JŐŞc(č„’Ő‘b~¨†9±°\Âr Ë –;¦*9…ć¤űŠÉŔLÔ.P4ĹŐ?pąż¤Ď?N˙ńá&ÜL’lęaĂŤx|M3Bľ§ˇĄ“łpŰ&÷SEˇJuUŞ;ő'©JŁ endstream endobj 872 0 obj << /Length 497 /Filter /FlateDecode >> stream xÚ˝Ö˝ŽÔ0đD."ąń#$O@.pw\gé8$¶@‚Š]”W‚vă7#ŹâGpéÂň5&ńx¤Ä¤ Ň6żýö?ă·Ż^Ľş«îőünn»áú¦ű:đg>\ßÍtŕňć—'~âý§îx˙îâĽ?˝ď~|˙ůŤ÷÷ŢtďşĎóŹ=ňÓCWŧ¶Uţ0WBŤ?HR Ş€$LÇh}ŚĚ>Őö1wżOQ;“:BňäáKIhśż™%}."/HřŽP}!›QCČb–$ÍL 5¦ÎĂo4!ˇ«‘˝Âw%T»Đ­Uł¤ó™)ˇĆ„łćQ5JHčpşW#§v “"MşU%$U•‡/+Bc$ť˙LÉÇłlPôűT»8=l…÷"ö—\F(|f5&Î>Ź˘ß'ˇă´\ Lí'÷šôe,ýy¶H.4ýŤ é ňËl5(ú=ŞÝ2Ím¶Ĺ·‰Y˛,!Ôeyý ˝l?ŔŐءvZCRÉŮŔ$Őř”śŤ]“ëäl`ň ™ŚÖđˇÚ%ŰŐfwŞ-b–,of5&ąxý6 ťÜFGżRKIšä˛Â¸µUřlü˙,vµů˙ÄßžřGţśˇ}‘ endstream endobj 873 0 obj << /Length 422 /Filter /FlateDecode >> stream xÚŐ–˝NĂ0…eä%ŹP?iÚ˘Ž‘J‘Č€bFĚÉŁń(~„Ś˘\š:­sŹ­XUaŔR”čłăź{ĎąrvąĽX/ä\®wO¶Zěź—LĽ‹ląÚ! űÎç7±)Dú w"˝éąH‹[ůůńő*ŇÍÝ•ĚDş•Ź™ś?‰b+É´ď o#@¨töłţĂ@»ź6&RĂ›J˘Š™ŞCkB˘†`XĆ€RďŐ€\ŻkŔLŻk@˘O3†/j"h ťt§‚ŇôAwv<ĽQ˝™‹ĽŮ·ă×%KK¸–´Qü–="4P<Řěą \Ů1›ć<‚d4—ŇkĐńĐCkTŢĂŠŮXë?*<ľÂ5č}a‚AŽ1 ¦2Äd¨Ű·%‚e™ŁÖuf¦€–(b¨Oş˛ť Ú_ˇDN=~잨' ¦Á ĺ`%U:J›Đ úĄEG5čąKźßňâ¸ňp›U^ #]cŘ…¤ďá Đy/5€.FşF‰ëBÜ‹ şŔĄ endstream endobj 874 0 obj << /Length 569 /Filter /FlateDecode >> stream xÚí–ÁnÜ †Çň‰ Ź`^ Ýz»É)MĄîˇR{ęˇę©Í1‡T͵ö›ôUü(<‚Ź>X¦0 kƶš¤Ůc‘v ßxŕĂ őĺŐ«ýĄ~­ë˝ľŘëúpŔß÷ZŢËúMí Ţt¸"ó·;y}”»ĎÚ›äî}°ČÝńţůăáVî®?ľŐßč/Ţď«<Ţh bśĹ§Ąvĺś Ď‚@éŰ®›|}EDP8,-€Š@Eŕ•ť=ś@˙?yáŰ]ph,‰ńŢĽ_ć"R ŐP"(±˙Đ×(G+§*Ôľ ˇ.|Żż48()¶¨sWĹâ =Ř˝ YQ€ĹąÓ Áۢ#0`´© G učů×)rPEĐ3P¦ąĆĺ·ą® Ň]+Đž@XÂL諞+GĐäŚ8š5`sŰĆ–ůd7@µ"_ŽM 8P› c z.k`ňE ŔťČAsĎî?8;hţ Ľřë›3€ĹÖ^ń„Ó 6€ý;ʵ Ş{,BÎ TÝ"lUíđĐgÚEp4<đ#`š> stream xÚÍÖ=n0p#$/ź ŕŠŃRšJe¨ÔNŞNMÇ­ÚŽĆQrĆ jüń$[(jAŠ„~!ćY÷ţ´Ř\ms’‘-˙ĐMNh~M`šś˛_ż|}Ç»§O śŢŤŽÓňž|}~żát÷pC(N÷ä™’ě—{2ĚGŤÎ‡B˝MĂѦÎ&±šF­Mâ—(ë2nśťĆËZřÉÉ 4m`&&ן)–ĹΤ®*(·ś É[*T‰-)ÄD Ţ …"Q…NŤAˇM8U‰ZUŞÎµ:ťËש7)±IěČMµAHŤA!HG7‰Ç榓AČ—:Ş ę/HIě˛TŻš§äω­„Vń,{}+OZüçë–5Ż€Ô."żŽ t_jwsF0;DťÇ´ jÝó˘Ŕř†tb0Ý++á!´#F,ŽWjg¨ §5Qb$ F1Ó´HÖ{·Ć˘Ţ­O ”±ß–ř˙¸R–” endstream endobj 876 0 obj << /Length 319 /Filter /FlateDecode >> stream xÚ˝Ö˝NĂ0đł2Xş%Ź`?‰!Ş`˛TŠD$02€`Ĺr˝Đ~Đ6DÓĂvIď›î›!PŽ@(‰!PÎX…#H„, " Â7€K›*ËdČÇX+9Ą@6Č(äQPÁ Üúö˙¬cßJ˝» ĎCĄrü˘¦‡CٰűOÇ‚Ą1đ—QŇÁ!|MŰtŘtČŇA°Ć\‹ŕ˘đÓ»E«Á:×`il°š6Xo<@ű6X Gp]šŘá{ľ?Žĺ1ŔW5ßńě); endstream endobj 877 0 obj << /Length 237 /Filter /FlateDecode >> stream xÚíŐ˝ Â0ŕ“ [ňŢŘĆ˙-P+ŘAĐÉAśÔŃAŃŐľŞŹŕčP¬­¨xR+^HŕKą$„čF«ÖmOí¬ęz‡tSÓBăuݧĽäůŕ|…A„Ţ$›ĺŁ7ČűŃ‹†´Ýě–čŁeiŞÉźaRĘâđ9-Čk  8ÁpJN°h8§äéé™N°sÎŞ“ĘIi1aNV Ü<;ą˙ÍâXPe*'«NÎ3eśŠóé}<žcé´Ö}ÍĘĘŮÚ‘˝_óÎŃąŹ˝Č…Šźä=ţüóţąÝ")›ŘŹpŚŠéľa endstream endobj 878 0 obj << /Length 148 /Filter /FlateDecode >> stream xÚ34łÔ30W0PaC3#C#…C®B.CS X$™śËĺäÉĄ®”ŕŇ÷‰sé{ú*”•¦ré;8+ré»(D*Äryş(ü‡‚†z(óŔ@‰10°˙˙˙˙˙˙fŚŠŤŠŤŠŤŠŃY ¸Řh|ŚŠŤŠŤŠ s±ÁÔĺrőä äJ$, endstream endobj 879 0 obj << /Length 116 /Filter /FlateDecode >> stream xÚ3·Ô30W0P0bsC#…C®B.3 ’JÎĺrňäŇW03çŇ÷ sé{ú*”•¦ré;8+ré»(D*Äryş(ü‡‚ä1˙˙˙ÁŁŚQĆ(c”AW…Ĺ—«'W Ę  endstream endobj 880 0 obj << /Length 202 /Filter /FlateDecode >> stream xÚíŐ1 ÂP ŕ‡B–á徦ѩP+řA'qRGEçz4Źäč ƶš¤vúC†ďĎ”)şýěĺC!!E!® v@ĺUPĹrµ…Ä€žcľ=.zĐf‚‡ýq:™‘@§¸ –`RägnN™ćč8óĹy§eË–-˙ţůgTžšb\‡ňü¬ů şVv*Ľ zVú’ĘĘX2“dAW˛#é•ĎđE_RIf‚. z’J’UIţŚť×Z„‘<|jd endstream endobj 881 0 obj << /Length 510 /Filter /FlateDecode >> stream xÚí–±NÄ0 @SÝP)K?ˇů(=+‡Ä H01 &`dÁÜ~Z>ĺ>ˇc‡SL›¶ŽťT!`˘C•>»¶“8vňÓĺáJ©|©–*?iG«•zĚĺ‹ĚŹĎZANńĂł\oev«Z‘Ě.;‰Ě¶WęíőýIfëës•ËlŁîrut/·%ú'F°'€š‘˛%ŕ«pĄÂCŔ^¤‚€ŔIÚŞŚďŃLmÍbF·ďČZ ˇ”h( ¤Q:Ě)AÓĹ s¦KkŘšă ˘>ť+çĚý>t.F§).č(+1˝Ú-ĺŕsç&XŃ(0˛MTť‘š8pnF˛![°’‚lS/ť’’äRďeJ€“jŚ—ŁęfÇM$ű1%±Gę0ŃH¬›Ä#Í,’zÄK~1—1?FJv†»Żż$ŕ“ęźü™ą;,7~“|;{Ůi2áóő <ˬ&„ČĚJÂjTÝcBvyőPĎ"¶T¸ÚŰWQź”śŘͧU웚c˛ě$a]¦ů¬ďhZV-ĐĂ0bD;UA éž˝“’Ңi\)éÔ{¦ëţŹIÇŻi$2 •ÝďŢ@چ ,Á¶ŢL¦Ľ›,]ĺÜŕfáVę>—I"ŮTŻŮŃëžę«Úô7˝énôÂ&/¶ňF~& endstream endobj 882 0 obj << /Length 691 /Filter /FlateDecode >> stream xÚí—=ŽŐ0ÇĄ°ä&G°/oł<ĐVDZ‰W AE¨€’R|´t\# ĽŽQĎ8ţ'BŃÓŇ‘"‰~vfĆöxţNóäúáQ_éćZ?8ÚÇăF7ÇŁţĐČϲytc[,Ľ9úö÷źäíIŢhŰ&/°IN/ő×/ß>ĘĂí«gş‘‡;ý¶ŃWďäéNîŞa,Ř%ŕĚHg ä]x§–Čś€©P&€  /J€!e»ř»7s&ósb¦·÷2Ş–Pş`H,TH-cŞévi‹¦;2L¦ ˙bRźŃUt?÷Ł ďT… őmmĚß%źC IŁ‘•ŚôI×h@$ Ő-“™“:™Ţ–‚UŚä‹âŢ[Fćđ­ęLöS›$ÍAńŻH™‘,m(‘ŞŚ DÄ +śŃ=¤ÎČĤ‰˝ETF¦˝„íł 7#ó˝‘.#°“Ě|›_H 'ć?ůäľÖëŇlÉÉ}eďz§\¶ăöěĺu¸¬’ě©QëʶI˛z¸YEYĄ5©Ć4^G\UdÍUőT”ý}^’Â÷÷Ő 9p*cÓŻgşSÚ ˇąSś3l’“^Găî“Ó`gB®9ˇOűMR12ä¤=oÁȸ"”„+˘ˇ¤M&ŔĆŤ!pb–Ý nRN° p2ljq/e'äËČ—h©L;;č—Ű„źü·É°ú;X“žL>ĂʆNÓ1ŻţD&N*Č˙VŠ<Ŕx˛O ˇaůü$_Ë?«ˇŐ endstream endobj 883 0 obj << /Length 227 /Filter /FlateDecode >> stream xÚíÖ; Â@ŕ Â49Bć&kě>Ŕ‚VbĄ–ж&GËQr„”Áu7݉),$"ěŔ?Ě|sá}ŻăĐCŢëĘpÜr8÷}I^ę¸ŮĂ0w‰ňîT9¸á OÇóÜá|„r㊣·†pŚŽ •49cVŮE—Ŕl!Ň `˝€E  ±¶„Ó %!×Á’pŐŐAF J”@P ç ŘiTěöWŕBˇő+¸UŕšS°Fˇ, 0đ7=źŹ¬1€I ¸Â¤€ endstream endobj 884 0 obj << /Length 328 /Filter /FlateDecode >> stream xÚíÖ±NĂ0Đ‹2Dň’ORWiS¤R$2 ÁÄ€:AÇ XI?­ź’OȡŠqßĺ©, Čžśgç|>/§–ËK•É™Ľ’s©×ResůŞÄ›P e|f ëW_vbUôÉlS"˝ëDZÜËŹ÷Ď­HW7ŇđZ>›ß6˘XKíĆ;k˙ž"­kp#ę×8A^Ăâ'Ož> stream xÚ˝Ő1O„0Ŕńwa éŇŹ@?čŕvÉy&2čä`śÔŃAŁ3|4> ‘áöµĄď:Š ĆßᕿĎÚ+.Ë‹˛P{U”ćKˇŠ«R˝âSűkýŇŢĽ`îľ~c%ň'ĄďüoĽşWß_?ď"?>ܨBä'ő¬—{ŐIĄ»ş Ôu ŻY85¨±Ó߀Ö¸zŁdšFú˝F懴€k´’¸¶t‹Ě˛O —“6ŕ€IKŮ@ŤŹ’¶ËfjAD&äČ=ÜD{ŮßL1™L/“ ˛ŹÉd‚ěb2Ń^v¬ˇ˛–eÎJ–IîĎ•Ť†¬a™qŮĚYőR-iŢ °–‹>۸üš3C ¤lŢ_ąh್k›čáŁĂĚíŁĂĚżŤNzži”.u&ůĚ|´‘ĎL×ň™içą@ŤEŻEłEŃlCá4Í•-Ő“h¶ŮJ4[Í6Ôˇă“^‰mşĺ"”9Ný†Đ˘Ě] D‹2CĄZŤ‡5‹tZ–YO-Ëś¸vöóÎh&üĽˇhťŃúL\ś$Q>łĆ wČỬčj¦ $n+ń(~U™ăw endstream endobj 886 0 obj << /Length 419 /Filter /FlateDecode >> stream xÚ˝”±NĂ0†[e¨ä%Ź`ż$‘@%BÂR‰ H01 &`dÁÔ!y´đ&•xH,¬>ß9vh%j®swţď|E~´_,U®–jŻPEľTĺz(Äł(K»›«ňţş«Jd7Ş,Eva·EV]Ş×—·G‘­®NU!˛3u[¨üNTgjfG ÍĚŹŔŚv´ĽNúp ``ĐĐ,Ŕ›Ŕ#ţŁ9njč,đ¸d i¬‚–|9sşwVČ\=PHm`öjrô 6.@¶3Î §0üŇ)@pş jŰ.Đî> é0 ôŚę˙;`úýZBW Ő‹,¤Ń@m”ÄÄŮCŤ©a l1PyyuśäŁn&V´Ź…)™ÇYH ž —`t°”ó]@lĂbCŃü0…n ä@ÇpĂ:vşŽĂůd0řy|X‘R xí䡕¤ ÖXa%‚UTbákě Vř|Ž5żĹµ­]±żŤîđ†KŞĹ©ç¶ă¦ŽęČŚ!ő{Ü…|c畸_ěĐz endstream endobj 887 0 obj << /Length 374 /Filter /FlateDecode >> stream xÚíŐ=NĂ0pG*yÉâ @bZUbŠTŠD$SadÁJ,10rނʒ#xô`ĹŘ~Nq¤&*¨L´ŰĎ–ż”÷eGĹ!;¦ťÓF›R6›Ň[F+ćvĽ°3]Ý“EEň+jgH~ć&H^ťÓ§Çç;’/.N(#ů’^3ZÜjIB5Gëź1†Çřcˇ˛§´§IOxŻ˝6ʨH™1â[¶ŘôZŘŐŢZ©“čTjTŮÉŽ§°ĐęµE(…VoĘ1˝K_Ă čĂm—ům¬>ąŻh2PŃÔÂn-ČźGX©ždH ÷j‚„<´vŁ*Ýúeî¤AéAĄîÚ[ĘüJ>ř»řWâ»ÖOľß¶51VYc9VÉc č˛Ňôr$CĆř†Ä©8›­Žs«_P”iUŁ(ď˛äQ/h˛Ć_Ex‰‰ŚzŔÚmzOLx«“]#“p[Üş‰î˙…Ö°ň†ö€Ą?Ě ¸5‹ÉiE.Ɇy endstream endobj 888 0 obj << /Length 357 /Filter /FlateDecode >> stream xÚŐ“żN„@Ć!›LĂ#°/ ŔĹÓŁÚä<)L´˛¸X©Ą…F[áŃöQxJ răÎĚîńoě¤X~,;ßÎÂ÷ULJĺRúD”ş*tu¤ďJx„ŐÂMşÇĄĽą}€u ůµ^- ?wÓ×úůéĺňőĺ©.!ßčm©‹¨7:rWŚcä/Ř %¸ĚbËŘvR„6ÁPQ˝áĹ)öT*RÖŤ<4\m:®bE^ĹŞ÷nÁ@,Iiąe$Ψ¨ÂđöŚ ‹§„č [é™6 ř}ߣšă.`úé–Íq Çžˇ¤oâ1r­4íůĚpř â?Ă_śmüÍOż~…éŃUź`ć¬íźµ3ŚĹgô;'¤sJhjXđ•°gdÓň9cvµŘ„˝ľG5…Áű3•´Xî& {4$VóÖu‰÷ k3|6‡(ôD‰µSާtSć­ÇX&ᬆ+x&8HF endstream endobj 889 0 obj << /Length 361 /Filter /FlateDecode >> stream xÚ핱N…0†KHşđôŞDăÔäzMd0ŃÉÁ8©ŁFgx4…G`d {N[  !Ä\'/Ëé×6çü”óy–ťĘ+‘‰Kq"…”ąůąx•üËěBĎgz"7«/ď|WđôQčžŢâO‹;ńőůýĆÓÝýµ<Ý‹')˛g^쟸ťĆ @;‡?&yxÄ|*Źt¤‰ŚTT#…Ôcްăú‘ôFGşßšjK Ś©ĆRť¶FgIAŁóö–°c!ť„ 1 î'ŠtĺÉU1¦Ä@”¸Ş©IoIe3óC őŚŔqG`¤,Rh„-Rdd.RĽB‰yˇ ¤6SiŽĺ ˙Šsfę—ßo{O¬uÖZG®uň˛|Ż„žŹ|Çůä{Ó÷­ďéf~űAHZŘŰSăďŚ`*ˇĽ€p·@eI+¬b`–(ö#)şĎĹéÁŔ&Š0Đđ›‚?đ&Ϭ endstream endobj 890 0 obj << /Length 360 /Filter /FlateDecode >> stream xÚ˝“˝N„@Ç—l±É6<űĘaDŹŠä<)L´˛¸X©Ą…Fkx4…G ¤ Ś3;;äâǡŤ“Üĺ—ů^öżĹůq^¸•;sG™+N\qę3űb×9:W®Č9ňđl7•MďÜ:·éşmZ]»·×÷'›nn.\fÓ­Űenuo«­Sh¬h™ ŚŚ%"0q†hjč9uT1''Đad⪖ňąĘ·n”Š|̇´Ż l@ ÄÔÍ˙±Ă‡|s,čT¨¨ýx?Ń·jŽôkÂĚ(lŤý±Úđ¦ź0ž± §˘ůÉöĺALÁú;–Qě78ßú?`ý'Ë%L~ŔI0>ŚŃ`DŰ{¨=c/ŠÚGÓ+y)¦ BÄ®„oĐŃ"6tĎĽx“ůśu6Ú¤äÍDŁŐęA‰¬MĎj¤^_49Z9Gäł4-d¦đáG5k­‡–ÇKC揑H\^Ş˛—•˝µ/„@ endstream endobj 891 0 obj << /Length 227 /Filter /FlateDecode >> stream xÚíÔ˝ Â@ đ+BˇyŻE©n‚`A'qRGEçóŃîQ|ÇĄ1ąXQWG=hůőšüsth–µSL0㫟`Úíâ6…ô:ĽˇĎňjł‡av‰˝Ř©lÍgx:žw`‡ó¦`Ǹâ¤5äc4˛"ş]Ž*E“.A–bhaȸBԢ¸RÓŐhł#©¸LJe@%‰ˇµV“Jn—!˘Š9˙Sţ”{‘HN©Éďj„łHIÄůÚnµb_KżÄŹŠt})ÉóĎäżţú]9Ş˙—ß&9,ŕ‘sňp endstream endobj 892 0 obj << /Length 530 /Filter /FlateDecode >> stream xÚÍ•?ŽÔ0ĆĄ°ä&G/I`YfFZ‰)ŘŠQ%Z&T\+ŕĚR¦°ňđűçxFD! \Śóół??Űź=]»ąß=ö­żö÷®ř®}ä·Wţ]ç>şí&6·ľ{x-Á·ÜÍŢ5ŻüvăšçpÍţ…˙üéË{×ÜĽ|ę;×Üúםo߸ý­7©ÔGŞvĐSŔ„ß SÁŚp€!†Á`<–ŃÄź{M%„~ Ô±Ďl°±ŽŘđóH€RQĐ ”¨_FÝ*‚ŤJQ1P¤b jŔśd *“¤Ťóěú°bŠ™ÚhŮŕPZZ…ÂČ@@P*L—U˙üÍNöŕdwÖ71Űk“ť‚Im_NŽAÎK:mv›řŔPr“üi´<'gĘ’±Ç/ň;Ř~''2TßŘŁ â^Î@|-ŔާňÄdĺľ^óeëĐŻÂĂq¦BąP‘điĘ;+Ś|¦Ů(qŤ”!‡‘q«0łű…"“ ĎR í9fjiRś•ý` ÔO5¦PŠJőSě>Ń;$Ď_H抭aq‡=µ=d Šs€ůO`ţ=¬dΡ׬łőŕMŰé˛ăľěŢĘJ· ?¬^ŞZrýŰ(CqJšZşüÜC´­8d\ž…’‰űčĚ­čÔXë…¶‹%Ô"ju›Čśş{¶wwî7Št6 endstream endobj 893 0 obj << /Length 266 /Filter /FlateDecode >> stream xÚíÔ˝JAŕ )Óä2OŕîhDŇxDđŠ€©,$•IiŃNȉ…ťyŕsX¤¸GąG¸ň ɸ?ŮäIaąýůfaŘbvéTťP^čAtŽÔ=Ă)ÁH™”˛ ł»€~ ňőČk“Źđéńy˛3@9Ä;B5xBE"vÁĚIG–µµ5kŐŞTÄ%é)ßK7ÔfŻČ÷ž•éÄĚ«ÁÚ…W«ţöj§şÎĆ«“Ćôşe˝ě.h]®Áś:˝ć2«Ěé-µc«÷¤BąÓR”őčÓháµ ´v*śľż(?XŮź(­Uë_‹mčďĹ~?Ç\Ĺ0†AÖ˝ endstream endobj 894 0 obj << /Length 174 /Filter /FlateDecode >> stream xÚ33Đ3T0P0bSC…C®B.3 €’JÎĺrňäŇW01ăŇ÷ sé{ú*”•¦ré;8+ré»(DMŠĺňtQ``¨o````ü˙H2˙˙$Ů˙˙’ü˙˙Iů˙˙€¤ý˙˙p˛ţ˙˙RHd˝Ó &Clر⒡ęaľű˙źX _#HćQr¨’ 8ý˙‡’ËŐ“+ ůW endstream endobj 895 0 obj << /Length 388 /Filter /FlateDecode >> stream xÚíŐ±N„@`.$ŰÜ#°O lĽ;’óL¤0ŃĘÂXé•­ÁXXú>ŠĽ‰<%ĹĺĆ…™eČŮy•’\Âdîgg6ł80Ç:ŐGögŚŃfq¨ďŚzP&]ŘKiˇ»y{Ż–ąJ®´˝ˇ’łîşJňsýôřĽVÉňâD•¬ôµŃéŤĘW:‚˘ ÜAD%śď A†#"DřŹżŤ°›z/±̨T!Ę á0oqČj@Q¸>+» [@Ô¸˛€+ ¸˛@˛‡TfHeF´đ â •®E\ĺ!"ÂÇćbDFđ?5^đJäł˝ůÔď"˙rź¶Óč‹ü‚P ŘÚ!Öm +Ú"šĐĺ±'őĚ屨vu$ŻAł1 Ű.wa?..·q‚şM0‰’g$ś Ńp ÉłnŘf Ěő-ŚźÇmŚ1¶°ú> stream xÚ33Đ3T0P0bSSCc…C®B.€b%çr9yré‡+sé{€„ąô=}JŠJSąôťś ąô]˘&Ĺryş(000Ô700ü˙˙żDI2ŘIv$’y”%‡? J˙˙˙Crązrr!÷ž endstream endobj 897 0 obj << /Length 256 /Filter /FlateDecode >> stream xÚíÔ˝jAđ‘Â4>‚óŮ]C6 ŻLeR%)SD’.p,ěôÄçHaqŹrŹpĺÁqvĎ%X$Mp`?~˙b¦ÓŇ—¦MšnäsMí+z2řŠF»D;»Ďă F1Ş1IŽj 1ŞxHo“÷gTŃč– ŞÝŇ÷ ĐeđĹĚ.óD ćÍŹşţrwTcy‹ zMţj¤ŇgÔ´Pg?QÚŮÉ(űnľ!ˇ•v5ć|ř™W”yeĄ¦©oľÓĚP^jűšW´rJ‚–­KĄľ**Ž(?YŮŻ(=ë¬-ö%ëĹŻźżöcĽĂ-Ę?[ endstream endobj 898 0 obj << /Length 347 /Filter /FlateDecode >> stream xÚŐ”;NÄ0†Ąä&GŘą$FĽ¶˛´,) ˘@T@I‚:9šŹ’#¤Laeđc;,+¨pá|˛Ç3¶ó˙őůˇ8Ná@€¨Ź`} O‚żňő‰­Á|ÜÔă ß4Ľş3Ľşr}s ďoĎĽÚÜ\€ŕŐîÔĽŮł 'šD 34Ť¸´ÜĎ!!Č„¨‚‚rÔŚµŘůđ±•_ Q1Vř-şE:u=Ť¸ŮÜGJ›¨°il"eSö>s?gvU\z*@ŐÓť8¦f¦X63.8w€ŘĄ\D6'Őž[Teä>ĺUäaËČŁ ×-÷sY˙–1ňôů/g_ŢgzçßóOţ]őЧĽÔIä> stream xÚ핱N„@†×P\˛ ŹŔľ€ÂŠąä*’óL¤0ŃĘÂXť–­!±°ô|1>†<%aśŮY¸@ŁFŻ˝o—ů˙Ů˝Nď;zˇ5WŰ{Ň:T‹P]hy-u0Çyś C»şľ’ËXú§ —¤H+ŇŹŹÔíÍÝĄô—ÇűJKĄÎ´ ÎeĽRB$Ja>  ł€„ˇjɡؒK1k(Şp,ÂyĎ$Ý×BĚL"Ńšm‘´Ŕ#§äQď‰ä# Ďü çXcEޅɨ™L‰lTöÄhLM$#˛Ď e–ňOC*:” ¨ĄjĄşCŢ$Á(ąÓ”~ťfôĺ/QúÝ'čNü~CżŃ€ĆoÖÔŤěß]P>ÖmŻä˝>*Ú#Űě¸rł7ű}ŰďiîwřťŔFHďycNôV4DŻUc@ôvŻ\uRtŞÍ<°Â†P‚Ó ˇ> stream xÚíÔ˝NĂ0ŕ‹+5ÝWG˛‡roZHĄ¦ňx"ďäŞ80ĎÍłÉÄĎŢ>đYĹó+i¦x~fgx^ťËç§—{žĎ.N¤âů\^+YÜđj.Á\ 6v´ąJD32'†K€Ô)3jiŁ@4.6 RÄt IŘײ”Ť‹ďB8ižµ daƨ fxĄTĽşbö‹‘2›ŔÜŢH”Ŕ蝤ťÄ‡—«č“î´6 ÝPňĄ_rJ b^IP˝RşU@®č­Ę‚´S˙ŁĘQu‘ôŽÔFÂ?.˝ˇ]|ÁrT?˙ÍlTń~#ö ţľ#٦˘}ť¬ Öúa˝W†>¸ăĽ2ß÷f‰qßjŚ{şÇ¨ß“Î ¨´ő˘sB,˝(aąŔP… е—]“čÁËÜíď*é< 2ůMĘ  ălPjóZ}łýRŮďwř®ĹO+~ɿΠ„k endstream endobj 901 0 obj << /Length 228 /Filter /FlateDecode >> stream xÚíÎĎjÂ@đ‘sÉy7Q˘„@ŞĐ őäˇôT= ¶Tđ–OÁdŢ endstream endobj 902 0 obj << /Length 394 /Filter /FlateDecode >> stream xÚu’±NĂ@ †etK!÷T´J;E*E˘L @0ÇŹŢ$kĆ §óůZ*’!źzż˙Úżo˝:żXÚĘÖölaëµÝ,íóÂĽ™ş˛ünVrňôj¶{SŢŰş2ĺµ˙Ů”űűńţůbĘííĄ]rg¶z4űť€†RȉdZ"‚!ń_ꄌah ę u^ßş G X‡‰?áJL Ä3› Â<@îÁ1d„ĹČ*$„Í ¶í˙Đ Í0ţ’ShTčz˙ŹőśĹ ‚Ô5DbŢ„śÂ°ţ™Ř40€DČrâńĂc¤ęŕČ-ÇeÓ\ŞFUŁŠşŘdh)SV1\…\ÇLćŤĐĐč˘Č d )ą)–ý8 î'A'0ţBqÝnbÍzÎÚ>őqÝÔÉ”['e’żź2~ှą¬ľÂfýßűIrFpa«^7†ex‹!dęÝ{¶eOsµ7wćBń}d endstream endobj 903 0 obj << /Length 243 /Filter /FlateDecode >> stream xÚíÓ±ĘÂ0đH†Â-y„Ü hëVP?° “8©Ł˘«íŁů(}Çbľ¦× ZĹEÁLżÜ Âý»í†nˇŹm¬k š¨[—6Đ ňŞźß›Ô[¬ˇšb'5´uPŃwŰý ToÜG j€3Ťţ˘2Ćř‰ŃyŢ+O@>FXA\ąG­îŕU ¤Cč;ÜÁs±)ŽíĚ+¸Žřá‹ŕĄź‘–k,ŽŮÂČÄâLa±â‚°8Đö¸ĹąšIjýKĘ3 DFĎ#bŽehLB±,Vž•Ó¨”?ţ"Ŕ?†Ňá endstream endobj 904 0 obj << /Length 258 /Filter /FlateDecode >> stream xÚíÔÁJ1ŕ,{Ěeß@ç4«”!P+¸AO¤'őŘCEÁŰöÍěŁě#ô¸‡â8™¤ÚB"x˛9$|É$™ÓO'ţjô8Ä#B˘3¬řH0ňCŮöXź¦ł‡)Śpw(ŕ®d\sŤ/ĎŻOŕF7HŕĆxOč'ĐŚŃÓ.LU/3G2÷Š(Á_É„ôźMŞ’Š$›d’ʬvŻ˝ţ™řw*~¬r—Ь÷MŮm…MUIŇD'óÁNµŞó-˝eUx•´”——?Ś&’””ťäĹ\BJŞ…(^‘ ňy–4Ól˛4pV_ š;kY]׊Ąć[6ţ¨-Áe·đ Ą®,J endstream endobj 905 0 obj << /Length 369 /Filter /FlateDecode >> stream xÚµÓ1N„@Ćń!$Ópć Łk˘Éş&Rhea¶RK Ť¶°/Fbá5č,Ą¤0ÎđŢŔcµ‘bÉoHHţ_X)űňX$b!ö¤2'âNňG.“#sl|Ďnř2ăńµ0x|nÎyś]ç§—{//O…äńJÜH‘¬y¶Ú^Š1–šűć?Ä­Kf/ «ŞSÔß)¬ľÉÓş•TQ ďj@›)©Ni§Â‰Qp¦ŰԢ4Q„RNöÝ(D5T>ăýš*čU Âř ˘ A–T0„‹‡t§´—"‚x©@A|>R‹‚x5§Ťăq”ďÔĹă¨Ŕ©ËĹô ŐnŚÇ!PnwC€R"EdăÝVm?Äç#µ˝lĽ˘ňFÚ2ńۆęu‰«©Ţ™ÜŹŠęs$=ČÄërFLĂg8©?ćßĺţSŠ´šU¨›?*Đő¬|űł<šľ#FÓwU°)ńłŚ_ń/zcA endstream endobj 906 0 obj << /Length 499 /Filter /FlateDecode >> stream xÚ˝Ő±nŰ0` pá#/ĐĘr㙤)PÚ©CŃ©ÉŘ!A˛Z|3ëQř5bĹ;R<&†˛Ue2 ßOÝ>ľßÔN]©wťę{u˝WwŕÝŐ§…węú>űó—ßyűS-xűuqŢż©§Çç{ŢŢ|˙¬:ŢŢŞ_ťÚýćÇ[ĺĂeegĆÂÝübÂ{ÍX^.WnH,Rí—ˇń~ĚÄ%¤rđQ !Ň„d.Sď'X>Ś®’ČRr/I"5°˘‡)‰L&J\n@CA#’ň/©A’#ć1Ň…w=ˇš’„)‰XA tJ¤ays™ „ľ@r%ٸiáHS"_ĺťCF5&ÉęĎ!Ł’ |ÜŤţ€dť |i 4&Z¦ĚHA—‘ éH:Sĺ`?zJSM)„_Gb„l2"‰L§Lş±Đh†9R_ 9JcřĺW‰ęLS&#/ÍP' IG˛„ú@®$h†´ţ€dť ÄJĂJc&7C©9¨K®Ô{Iż˘3Ą ęĘ$Wb„,áW‰ć7Č@]™šDŽŇ¸69#ýO‡-ŇůpJI#Ů7ëĘÄBx*Q"ŤŰ„‡Ą>’Ţ$9­űá‘MI ÍŰÔä?‰ĺâ_Žü˙3č^ endstream endobj 907 0 obj << /Length 492 /Filter /FlateDecode >> stream xÚµÔ±ŽÓ0ÇqG"yÉ#Ä/‰ąžS¤ă耺 oÁšäÄ‹Ebŕ5˛Ýš1Ccçoű˙ó©E]čĐčÓHmżŽ˙Öúđ\żTŤ:¨g­´nÔ«ꋖߤn®íçŤŇWWţîç{ys”őGeoÉú­»#ëă;őăűĎŻ˛ľy˙ZiYߪOZ5wňx«Ś{­BÖ^‡˙!Q3 ÷rpšvU‹}Ëʉ4ł˛¨UŤô] i@µ^+¨¤Ť®ô™W—Ţ+cöëŠĘ˘V鵹“||>Ł ’Ź/&T5ł||9-q!B<-DPëEń”ÔGm Šď˘L\ż˘˛ =ާ{ĺ ‘µÇű…đű ÚăýBx•A{ĽO÷Ş@ kŹ Aű Ťrńa!H}”‹ďm rń+ęesÔ/–Íý=Łţ$zdŮřÇ eX6׌g$ mĂ Ôű­}JaN©2ë…*ÍrV…™Ď*‡Ř+Ăô'űT˝¸T]˘-Ćň00–·˙)a: cyř@ä•?­OQnp*؇§‚}Ȥ÷n)»DoŁ Ňť˛T *OÄyɬ‹dÖ÷ßă 'śŕ!™Y|&í&rŇE0‰öPŔi&ťŻt†’ÉHwřśě8ŘUňÍQ~ؤ·Q endstream endobj 911 0 obj << /Length1 1381 /Length2 6029 /Length3 0 /Length 6979 /Filter /FlateDecode >> stream xÚŤx4\íÚ¶ ZÔhчču†čŃ{ôNDc0ŚĚčDŻŃ{ !: ˘÷ ˘G˘'J‚ńMňć=çĽç˙×úľ5kíŮĎ}_w{žëÚ3ks°ę (Ř!mˇŞHZ$”(iš€ PD&âŕ0‚ˇáĐżíD&Pw ‰ú„’;ŚĆŘ”Áh P‰<đ€@"H\ ’‘îRe°'Ě -x€D@QDJHWw#Sçď[7„’”ç˙PpşĂ `@Śv„ş`*BŔp€!˘}ţ‘‚űľ#í*%$äĺĺ%vA "Ýdyř^0´#ŔŠ‚ş{BíżFč€] F$â9ÂP9 ‘öh/°;€1Ŕa(… ń@ŘAÝęC -€®+ńXë/?ŕĎć@‚ Ąűý+ ń; ]\ÁÂ`CşŞZ‚ho4?ڰűĂQHL<Ř m1€ß­Ş ú0fÂ?óˇ î0W4J˙šQčWĚ6« ě”..PEô«?e;‚Ůwˇ?‡ëŚ@z!üţ^ŮĂvöżĆ°óp2FŔÜ< Ę0ŃżmP4@()&& @ÝPoŁĐŻF>®ĐßÎßfĚ ~®HW€=f hĚŠů"ňC=ˇ´»4Ŕď?˙\@; °…:ŔD˙ÎŽ1Cí˙ZcÎßć °bč}ţug‰a÷ů7ü÷ ©©*¨ńýů_NEE¤7ŔO@X )€@ 1€¸¸( ŕźyôŔ°?}üG¬Â ü«]Ě>ýݲçp˙ŕźątćBÜ˙&ú# (‚ą€ţĎt˙ň˙cůŻ,˙+Ń˙»#U8ü·źű/Ŕ˙ă»Ŕŕ>ćz 1*ĐFb´€řo¨)ô/éjCí`.˙íŐ@1jP@8`-ş'Ľ÷—†R…yCíô`hă_¬ůËnüKopއDÁ~=a0Q@ŕů0"8cž"( 5»  ýł® ‚´ű%6aQ1ŘÝěC„9kĚJŕ¨Ňęý›Ě!AŤ `f Ř#݉~,H d‹Ů# Á1v˘ä†x¸»c„ö›ÂŻ« ő†Bćgé0§Waíç5 ^›#x+«ťŃ‰ć}Q˘hÎŮg~ŽZřŮj“nŠ6v/î gčÍ•GLĚř3đ~9ő~ÔťĽś®žŹĆRé[W<(ü~Üíe¶CŇ;ډgDŻS$é3‘ŮXŕZpĄÎ\†‹÷lżÜ*şęDm?”ܸJNÉYÓĐq yť»ŘOĚYŮWŃCćŹČăo»[dziŹ]a?Ĺź)¶ÇŇ}÷Y·ĎZZz›Űß—!rT¨Ů[-ö"‚’ŽĘ÷kŢpňuRî&§˘č©RyZ"]±Kç2ŽŤřňŹ©Âţ¶¤ŹĄŕ[şŹß5zÔ!Egdňz–Ź­7rŚľ ‘ÜiNŽväŻÉ`W䨶Ă:Ę<¨ç÷âŇ0đę:ݵ§ĄegćZŘ Ť±řŹCE¬¶ĆďśŰÄe'„-Ódŕź+ŠéÁ™]‡íM.ď§(é9(ő4ptXťV=†ďň ~{Ţ«4cIAś|j~Ű>Ôyd˙ÂD=śhÖ‘˝űf'©ICôô=… ŻŠşVsŮeÍ“—0hꇫ×Ö©&ýP^rnś-ÁD„¬ŔbÖHk+S‡Đ\*\!hŠś”ŇůK9ÓË…*±wĎdBšeŇ$‚€ŹÇo(ëď%×®ßŇďů~Ó*ŃÖýPHŔJ3żóˇŁM©×ô˝DXănâĺ'EóÉŕCń™ĺ|ĹźĆÖ”eŹĺŰÇý˙¶}Ňpo¦PőťÚ5¸nýüSÇĂţxĆĚ×ă{˝\iŰŢę §¸‡”¶CjRlaĹđĘĆŃVĄĄ~ęhc‹~°VűI3{Ď;űĆ“ďÄ ‹3é{Á®Vźt\T¸)*n“qÍ…KЬżĐâ”ôĂ%Ž2 T&ů&q›<Ţ"<Är´o$Ú€Ëi.ĐîZ°?iގ¨»Ps=<íe\˘l­ez0ŕ 9Ă)Q•řá©'ňᣙ®Ř[dWí—ǻۖ¦n Ę!Ú-xQć÷VJŹ#š) ͦߚé©j] Ż[ ·ÜzŃRŽTOó#ŃzOŇQ îpuµ{Đů·!IÎO/LuX ˛URŹJöłZ¦°O~p¦®gÂYTŻijQ`8‚^2«ćŮ~-y1Ŕ 'Q:·”/öp„1zÚO#CůěÇîäjďîłÔśÁĺ!ĽËQl_^XTmYV¸Dlż‡•†iVčNĆłjÜŠ}5őęÇöťo?­ŃS¦ŇY]ďľfxČsß­@óľ+Ąśşeü,×ĎýŰ7ý°Č¦j'­óXÂ·Šżhť¬nŞPÖóbMşŽuÁdyü'‰RëU¨ ˛.cŃł5o/Y®§.•E:5·Vfř,X˙zieç#¶ĘďŤiŮ´ű7= ”ŇćŠqső•‰čH§ä­ůóh†sÉ:śoÓÄŮÚĂ·4Îő¬°+겼ćł)Kě4Ő}ťą!g"ˇŢ?™c÷ ‡Śő4ęěý4GËGPôáÄ_FĚ«Ű ö…ö<»Ć, Z~Ě17kqčČďf©‡F¤Üľż¬Ç˙ŕůđb gŇ4?{=›Łq©¶ÜIÝ®ÜjŠ+ďL¸'é,­Ě˘°®F–"_¤“,ju(’m´Y'aß ÷Ń/‰ mŃĺ «'©ŠOmMr††©]$ř>§<>¶˙ě9nEˇěřáäţFˇ_VÖšbÚđÎLŔĹëţů<”°=—ұĎňZŤőŔË©—ň–f‰”Z˝¸W(ÝÖ Í¨Ë{Îş2´ű?+ĺgŚÉeŕüKzH•'Ë´[ÎŘďłxIĹ Üp,XńöÎ.šFç>M=B¶…XͲ7qĆnYRHŔÓ6šP-śaaÝB‰kkV<٬F›o‚Ŕ$ÇŘ«U_ćÇëVi‚; Ů ¤>Ą]zXaF)e‰)ĘP,z"łŚÖ ^d%ÔŽµł…Oś•SZ áŤřEMôĘçOĄó=ă‘޸*‡€G]‹ëőS§ý*HtĘC°9Pß+>ć°ZfWuŠhB66«L6FB»ŔĺŮ–'źä¦ů‰±÷ŹlŃđ”LGr±¤kÝ(ĎëR<Ďďę$ V8zű¬ú®g„݉ g-îbgíÝŇĹuÓ?uőoxÎ1K:űPÄÓ4¨'ű¸JÓ+ήRśčöAąăR‡a–UK9¶ľjJrl!ţĐĄb/ÖOµé#bqĂĹzźŘ·šZ¤®;Ţó vīܝűTlÇUŐ»ŮĹ ĐŇHüVKˇŔń5> rľ‹!vî-±ËpxőĂKú7…Z¤cŻOćă ĂÇ cHŞyěŞ-őâ÷­šNŽóx2żá»ĺńÍ.BĚ}ŇúFÚŠósnQZkż‹˝˛ŻĂŢ6Á»bŕ:É«?-G– ‘ŮÉ-ŐšQăRr‡š‡†ż9sÖ1m0˝Ż:w˙“b@]úgçşĹ^ü}î…é1+á9r ¶ÂĺŐžKXVě(Ůg¸żK(ręí^ů=:ýÍVęa>O)ýS˙íéŻ+1jeUpńM{S*ße÷|ë}™jl~\÷†#Ě´%Ü]wzÓj#č|…>Ô5ÎűNjő> óo‰VľÁÜO€ěű*Peßµ1†ţˇáEó±ÂŔjdATÝŰUşąf…ŤÔ–î4ĽłvTýŞŔË(Ř5Ş]Č®Í[˙ -O(±/éÄňr^ĽĂ|®â'(K€±ĹŤ÷„°™ć~×WöšČÁşnߎö=Ţ–čďóď*–µ»vň1ĘŽ îm0qŘĘXĄs+}ç 4D—tśt0÷ş5ű†¤ďͶMŁ(Ąĺ@ˇ7čÇ­I}™7K‘LĽű’±ýîcÓO NŐĆűš§”ŢN­‚„üx#ç|¶ š™W_‰{5rŕĘZúqD‚ĎőČ“öŁ®űăć+xP=Đ9ilľxp,ŻŠčÝ »ČŻEČřt?KĄ Yöź8Ş„ľ¬ăQĽĎ‘­XS7ťbŢ čüŢ)y<’HčÓôŇwXŠsÍĺYQ’†ÎÄD=íŮ­%Ö2‰~|ňöúňÜ…„ %±ä Úd+±Il+·~©ßc ¤ßp}}ÚĎ<„ŹŹJĆő4 MŔaśyÉóu‹±Đ¨`«äÔ¤™_č\Yů.Ći)°˛€ôĄ­P{É´ĘâÝ”° .7Ő˙Ěá6uçÁ«–9ł"ú´†đMçsAÜ©»Ń})w‹B•謁Ivu­Vĺ­,űV»śéyŕ®;e7ŠGÜ*˘Ä±— ĺ­fŘ3“úÖą-;Đž-Ĺ;˛¬ĹdŹ=GÝ+™Ě Nv’ćcňŁnFňŚ/($;ôÖhňî›iö`/š4růÎ?<~§Ŕ´ŔCřr:v«nÚ¨=•˘7+qQkt…ôÁîÁŃg+eXŮ•EɡęţÓÍÂ=¬_©–Ť#/üs°Ňďâ}5 ۵ź0ŽŮqÓ 8»śô—ąŽÍĆüźéŐő×ëĹű„Ę–üZʰ±™ÂKÄÄçŕŞÄ_Ăß-ăďT),Jˇ4"žómš8ů ˝ş!cŽ‘' l4,Üş6OźG4ЇÄááe%Ls–ńZĹ3 $q]Bä±ČÖî\r6 úß_í+Ę8ëdž ßŻą}˝3_Á— !}Ôxżŕ±—Ëę~–ńç`IWVëNěRýö…o\%:9jő«73eI±űĘF^;YÖßF‹É>(đ•›WŢ’Ń9żŃa‹ aŠósٵ5ç–e›—ŕýô¤spÄąĚGäąsŽőt­ľŢC’ ěµÖrnYDÜÁH˝k÷ĚO%™z¨¸÷‰Wđ<Ýj… ;µÉę¶#=:÷Ô×™ÝŮ™ÝňŢn55î!Äľąŕ˘šĽM ×4]ţhřř‡ČÓÓ W¸~őłý­¬h\ŰŐ2j!×ă ÇĎŤRÜ:U'$p­N+P$w!v)őßă_şhĆűqúJßźîĘĂ v9Z·€‰żŁ©ßÍ}ţ•‹—ćĘÍ,Ččâ}źa:ÖůH@®\Ř…Ž'oxĚţ¤Ąz?mu­đÜç.÷zµ Ç‚_y)k»>s®µâÝrbż­XÉW5íţä@eĺŔ=±ŕ «É§˙śý‚ý• ýÇŮ\ą;yąĄH}:éÎ4ă4Żv€:c/}Öçâ-TzËŞ2m!=ýŠ‘x§ó§jšszŽuŹuę-šq5†¬w˘‚”Ťh|—'í · ďOĄ§Ć^ß°ą‡ůUVÍ<ŕjżZ]b· 0 Ä# Á_|TD±¦#ěl_>Fz<yHľSäąşÓu¨ąhę—«=µ,"7›W®}dů]Ę”NšŠÂ“%1ś<ó¦ŮšôÍ0E–dÂčR3ĘA˝U ią|VŁ˘(€ŕ­&ÍΩ±ĺĆËĐd™ łź·®’Eë_ÇąiŁe}dŞ#x×m•p:[‘t űÜk ŕ\Ťç}%i—Ç7ťśÍĺ2jcď†čĄpŠŁŃdاjľŇš÷Ž'⥛×I_|0LKďńě>Ľü¦ô¸N®ëAh›P˛*›±` Pvű„ď¦ţTŽmhŞrBf7ř+ęóň~¨7ňĺęlë;ŻK1Ý%Á€'yAčÝá@QŠĂB“µáň:ľ*Šâ¦ŞŻ/™ÄcęŚQ!Ů/gĘű}¶7‡Ţ¤ŕĺÇ*‰^Şą;¬ă˝!}Çž™Ëé_“ĐĐCđ8mI­bcN"/c‡¤ OŰss…ۉ]şľ ů:Vřşźc9j٧ŹýÎôN¸î\}” ©`ěóř‡„ť´ă™HťűNw·~r…lżi˝ ś#}-ŔBvţH;đ)d†[jšP+w±Nů0ëłf”C$nyß§˘žňm2JůŘ\ŁŞTŔ4ř”ŤŁ_ÓßF_3ŕcáŰő#ĺÜ”hŇ€cΠ«7’‚W3Ąm۶ôžŠľ@•.>9âAŃ’(N¸ä‰Y‹žě8Âá„PCu[J®ť:—gh¬; é'uVr±(ţX©+.ělzá\\XŢ=lVÍúę S M.uĎ}ăŇWł:‹ZH;§EÔ,©y¤,qÖ]úŻéh.ł4;jI>ńÚCť <‚,»X ż>ËŁX—–§B‘t·úż’çµÍĆSŰŃ{Ň=1ÇŽŔ3O?ýÉâ…tĄ<ůśĹšĄňF喝ŞňÎŘ'=2ɵŁl9Ý)Š1OcGűćőľÄźH+Zé'č–§|ďâUĽ%RęhĂaoZŃč'ݹηÖĹţ´yOÄ’ÉţzĹ&$@@’Z_čMń¦v4(On®{`pg˛¦á3ůžăŽeL‰íaáŐç¶ťJëáűç#éý|¸ä{hĆžŠ‹±ÜÚ(ş?Ëuĺ‹8´“4B–?“ Kć<ńB#¦Ń·Ů®Oôi›¨REŻGůś56…M%eíÓĘ›äăçoODĐ‘Ť•×­N%˝ţlĄő['_gň-¨§´bó±ăÍoS×ńĚ!EĹť©W~¦ÜĺÄWO~„Ĺ_ĺ=ꂪFyď«çÝWŐ¤Xßś»9˛ďXz«ĺˇŘřťp,ţĺ GCÓ‡·HqFÜájŞ9’)Űřॳů´ ŻŠf?×]ŃŰó굏Vưj.‹DŹłYmN|wpű) ¬µWéç–ve“ů9d™ĚqVCíO+ ďŻÇę~˙şks{ Ô59ÓŻyĄLCŚV)]óJ Gȫ㩠~ĺ‡!Ă÷ě/ő0O(iť'5Óxgz~ě,a Wm^ÎąÉIň-lC%Ev$ÂżQÚ—¬ŹŘóÇ9ËBµ‘Ĺ>dĎň Šæ–aLď·R‰ćsöôž–ň°ÓO˘ńxčcMőĘČŽ-Ąâą-ßv·n„ĺĽÚű#—×ŃşŮ+%ň.eMf]|şîHűny/Kű“¬á‹ťŔÇ»± Őďź™­ČD<«Öts<'«…oxů^l5/_ ç—¨lďžćܰČńőKžfÇ…‚Şť§E3ě öl¸űÂĺýenúĘvFmČ^$UoűČoő]·Ż^ü~ĄĐ«.=ńK?ĽďŁh+^gĺôNh=Ľ)_ůţ Ť@Ŕ®w±ĂccçVĎö[fŕ—Ç—!jVŮE‘Ŕú8ÚŢöçVÓ/SďđLg ř5é&´ÔčÎ\“”őÔ“yżý´KŔĄßGpâĄč0ž´Ö~exŐ–—Ă6[ϱ=<ő•n©ÍÔđ™~¤2{ł{x'ÚŐ˝ĚY›¸IOľĘůú™HZ&Ľw(mx¶ő†)xźç“«ÁŔůňüë ¶; D™*ĐdŃsľ7ó5¨Ň‡G\ôTµ-Ąß2?nŰF鿢?9¬1„ßÎwę;$ŇŃűâ{Ňa‘/­=ć¤Ôô}¤CU¶}ą~FŁ˛Ďż5ž¤Ń¦ERňP ?€ |,’š¤7žžh–EÍľMa#ëŇ7m}Ş{őm"鯮ďŹVAHó±$µŇśórĺĂÜÜeÂŢŽĚ®říTó;Yő§çowřDC+Ş1iBąr—ďb˛VI,Á(ÁzˇkŠÜ4ńą$¸ÎE•Ă®˙şŞžsúĽÚc# A;!çŤc¦Î"/ýŚx‹[ą._k¦pżďm•Sô¤đ őĄ/Xîć_ésůÎҨŚůq܋ƿe­v9š+‹ú°őôˇ–§lO;§řť©×Ż>d|#ĹŃ$}ś#ƊYđą‚#Ô!ZM>†żv Zópk{űźZňeز`nlÚŞY8üY4gŢ’ŁČÉšdzUëъ臯·so±2jěm'Ôżz©Şą÷-âŃ(¤i’É,3+ŕë(2·´dŮ3X-HV‰řAňŐµű&ŃŽg4Ü>’çQcL©”É«wúf…ÝČÔěł@Ŕ˝i–çTó1&Ç‘ |®ă>/gÍútC¶8ë× ËËÝDĚş5µśˇ×ßĘKk#5ű;bOźŻŘâwĹĘE5ĺ§ ¤Ă&¶=wNUYĆT¦ĹęÉ#Žť,Ů5ĆĄĂIŹüMę,(E|A$Ő6QĹĎA,›iÚŃŞ…˘Će†U-ÝĎłŐć©§żËai§ŹŐ« ÓŠUoʤň>Ë ű@\Ů€ľ%hzť|MřB×[Đ­i2—:÷:ŻsPý•Ó… endstream endobj 280 0 obj << /Type /ObjStm /N 100 /First 931 /Length 6790 /Filter /FlateDecode >> stream xÚí]moGrţÎ_1mží·ę—Ŕą@¶O>ăÎĂrrw„€–Ö2™Č•áüű 4"Ź4ŢŠ\¸‚‡”ŇPd0h‰ŕpĄdń`ńž!noÎ'> 2HŠyĹâŘDfHžµöqČ ĺ"¤¤ˇ : bQŚE+š„7ÔqüP‚+ &%F‡‡0”Ň…X4“aĹ\}˛hh4‰ .≑©°'ś­Í§„8Ń×ŢA[Dʶs‚ćŠčë ęekżě/"›9xËz2LLaŤń”ú…ý‡ę&T׊u|Ş=śËް#‘QÂ0¬;S°ËS‰î"±s°‰Ą¶‚T¶¸ÖD˙Ú˘gsâ)˘…­cZ•ÍÇľF]3-jÎ&Ĺ05]g]FŰń9ň)b,et•ĂČA÷ '‡ĎڇÎpÁËPĐÎ±Ś‚š:úІ݀2‹Ĺňńś 5A™ÖŁýAĽ˝pŚĘuhqd‡§ÂVˇ>RâŘî|*śČ)DasI¬!ÚË…ŚŘ–#9ä„îf‚âĂĹçź_¬ľ^: T3|?¬ţú·g‡ŽMVFˇ~ýáÝ»Wżű#«/oŢÝÜľxůzŤéPÓ|wąŮ¬oŻ1IęëďŰ|ýbsąYcň0ŕbőüćz3|ţů°zPă=ç\tsąĎ˝Żť:‰u$Ě_rf| «ďno^żXo†—(ř«çĂę‡őo›a!oőĂ˝_“˘·ë Pz˝Y_oîÎP$żX}żľ»ůpűz}WąL úvýćęň‹›ß†—äURd$żÂŕsy…Ň.o‘Em˙ýŮőő r|YŮI"ăď5ŢĹęŇ7őýOW×˙y±úâćöÍú¶–d_­ţ°úfőĺKfc^‘¶×¨¸ähQăhěh0ŐĽÉ#fË­ĄdÄ{V[ňŰúú懛ť÷É݇ďřęćzDâ1|ĘvşŹšűŠÇ#^–âÁDGk8î Š_Ë(ľp¤»ŃDyŐjT+´zöů組ճZüęĹę_ż˙†×'?o6ďďţqµzűÓÍíŰőxu}{u9ţt»úĺňęÝęźßŢŢ|x˙Woţ ă.|Ú©ýŞ6€‰q‰âĆ‚)©Gâ=‘§aëMŦ'¶Ç ÎŐs°k2’ůË4§?fŘ»?lËÇŰ4ŰüŔ°=b x7˘©Ń/ą¤Á»ŚňđăѸÓ ĆČŻW›ő¸;P®®ß¬ß˙üţÓł3ĹX(ń$ŤNBěh«Ř}Ę'“ůvóvŹĘť±[Ě cw;ňa–ű4‘%»1ɱ‘=¸ ÄŐQ‘âFŁăâ†8mŮ„±¤##ŽĹY?WŇ©{ddÁäŠţ)ůÉ–ä«X7,/±˘ËůĹUD·Çvă'ý6 «÷ozűöÇáe#pőŐú׫×ëďżţâŐ°5łH ’Y ô«?_ţ˛®”M5řörs{Eľ3K<ĎSĎŻ¦X_TŢ4|ćđPĐŢ Ż4'c;ěÖá›_Ŕż*U«çW·w›/ľĽ…đąXýér~±|űËŐ›ÍĎw~Wööűë×7o®®ßV^C—ŮßUDÎ äů2¸1Ě?ňç=&í|ŻJŚŚµkĆ Ćř<ĺµgěír¦ř:÷hÇä*ßk$Žž„nN_Á`هدiRr‰~Ä0h)0Q©6Ś€ŁKn€ţ`9÷ŐsˇË]Ď/őq˘P….$O_íHEĚÔÎ%m×× Ůą­\"˝@2çW‹5Łg÷÷‘¶tfÝŐO?­!¬8&^:»ş¤:äV#xü›őOHşş¬Ő¦ÂKpE\ WĆUV—РŶââ =ń„ŤŐB"rtʱ‡ ?čŤ1÷ä ľ•L I µ^JŞNŇż"`ęÔsHČuµN_Fęz!€™ÜsČČÂ:÷ B l‹ A~Ľ ´ńfysĽyŢoÔăzĹ  0°Ţ2oLl™Ř2±ĄŢŕ{lË,¦›đycb[•˝‘‡[ăĄěEoćąxY9\\^,Ůďň‚ˇVňň‚ gÜňÂŮV–` c–0{ßŇ@ĺöK4t˝K4ôşvy!,\^"Ë Ë ł–ĺĄ=Î/‰UXĺ„4Kˇ Y›ĄĐD…)]îíRD—·K}ĐíŢ. ťÁŰ…Č!o 2s[(ČĚmˇ€0Ë.f˝P€Ţ·0í t;ŰŢČI\{CYη7ćB{Cł8ioDu±˝ˇý\jo…oył,˝ŃbÉ -¨ľ÷ŤTZo{#m´ ŇŢ7ZPkď-–=ŢháĐňiáéÇJ/sŽô Uzˇ>Bzi᥿ ݰô_^aéĂ.ĽÂÜ‘UxŮQÜQ w'nČ‹@ŠeÜĎÄů±ö÷čĘ|ďˇŕč4uÔç%ăóîKJ˘,BSŕ,JŻB+Ô]J7±`Ú 5ʡ1E„řĹŔ‡Ř!o†AR;‚)ÇălŠ2×ôUÎâ dfŢś˙«ŢłŚuÄÍTSyˇQÓ:סćâă,Ű3DĄO[qćv›Â=ë6…Ô¦ź˘ččś>|óčsóϱ|oéyşO›˙ŁKí¦ß#PeĎĐÁÁ>pY4ČuÁé!ň<9r$äőŘ€şÓżd ;pˇdq=¸BB 3%Ý9pEJ \™Â"Ăě‚ \—"e ®ü8Ŕ…9î‡Ět ( [z ŇZ…w ®ü8Ŕŕ->ŞŕŤ‰ť©Śž7ÚTzbçŮ»´zŐżŢ3Đwř!‹¸˘ĽEzĐJ±EęErEx±±ĐžŢ‹ą#/N!‘ŽXĽřRB)ˇA!Ci¸#­A„Ę(}‡/ˇAŘn†hÖhš@„<ä‰ P|´ ˙Ä…0z˝CqÉ q>ŠBF1*d“BF1+dL©Á$P¬ÂLiˇ€&Ďä€JA¨$ @Ą¨TJ @Ą…®Ě¤…‚LŤÄ(h• 2ĘÉ …ZĎBAa×/`ŠpթñĽĐësĹf9jl–“Ćf9kl–‹ĆfĹhlV¬ĆfĄŁ8Ô¤xŤÔJĐH­Fj yW¤Ö wEj%k¤VŠBjÁ…Ô‚± ©ăR Ć+¤LGq\ůj´půËhşć, ^szű íŤ@>6$ĆĽ:ő…}Ô'&6Ô7?ď >‹ś/ÂgŁ>¶l®ĂľeztŘ·Ěűć™Âúzšvµx¬ďún†í8»);t7÷ä~8®ą7í}Ąš{ăl:o5p%%Á›Ä«·Ô%khÚ/˘„¦üF‚vŰ%khŞ/ú44Í—MńMýŇĄdhj/= |ęR24š „:B3 ŹC3@>…ŕş, ˇ 9VAş\ Aɵ”\ A˵´\ A˵Š’dAŚ’dA¬’dAś’]AĽ’]A‚’]ADÉ® QÉ® IË.ÉZvIѲ+-»˘Ő˛«!ˇ*­ŞŇŞaˇ*­f0t‚Böd‘3‹ŽŮź·e‘§4˘RΖDˇ(I$ŇQÚDi_e%Lµq?‚™NěđÚÔg.'^CŠ„Î ):7¤HčÜ"ˇsCŠ„Î ):§“MGîÓA0řűů]·@„i}' 6k}' >ë}'3H«¶ŁşŚĐöěEżśű×sÔeş?Ď<ň{Ě‹Ëj5÷ĂëűvöYĚmd?Q¶ŃmGƉQQĘőŔ|Xâ©ŮöÖ´šZM×µÁе~ š“gŃś\i/WJ{ÁÄRÚ f–Ň^0µ”ö‚â”ö‚NěÚ 9y×^ČÉ»öBN޵rrĄ˝ rJ{a YsëY{9abŰ3&¶ĂĽhŁ=ń‰ćµŤ}^/ęź×‹ @ÍkŰDĎKÇ*0ÉÇ$;Ołq·ĹyřOŇüys}.q»$ńŁétřD«-î6?W·ŚműÚUĆ/ţąi+ĐPoĄ-@UH[F7JS˝ŃŇTotž441ŘíľŇôđĚ4ą›zĄ©ŢčMiŞwˇô±íHS˝Ń}Ňť9÷ű˘łˇ,ŮâÇ}ŃüP|ŇÜŮgvÄv$ÍąU`G‚S`G‚W`GBĐ<>ćń]ő&ţIĐ@HşęÍŤr˛lČű˛Á6É`÷ĺ‚\ N /?‘ŹW·—Fż«¦Fż§¦ĆĐŐÔÇŠ @•úUß…î‡=íÝśńĺ±ÍŮežB±ů_kŁŹąźĺn6Ůxqóz.Rł> –_Żi'­ #v˝""ćT '®?l >~őW>aÍř4kńé«ČĽů“–Ž·üѤŔňĄŔńĄĐçŇ–Ág¤}ĺeéVcifÄꯢÚ$*‡6i&*Šâ¨Ú$)‡¶č”C[tʡ-6ˇ!˝Ň*bjұ 5îŘdšp;–ôµâč•;6Ć!جl‘@ą˝°ÝšÝ«ŻŁÚmˇ•Č )+¸de—¬¬ŕ’•\šI‚0ˇ™$šEĄK3H34{ő§fŽ €hÖîQkƢ‰f‹ šh¦ę\ă´h†B‹f‡ ´hf"Í R¤!2 -}I9Gb[?-;ľ/)Kł+Ł@‰ĘŰ*kᆠß!L4ÚzŤ¶ŢDŁ­7ŃhëM4ÚzŤ¶ŢDk”U>Z«Ö—ŁŐ6úhµŤ>ZmŁŹVŰčŁŐ6úh;h-6+č»7ŁĄöbô‰Ý›ŃŇË)č»7ŁĺĚ ĹîÍč¨EeżŹîT3°O{°ČL#»ŁĺyĎ~Ď˝CŐ‰Ĺ<Ť _Ű‹â‚Ó;8ZŔşGŇĎ‹Ąrřđýt˛Đ/Kü“°Î>»1Îş˛wË\ gW¬—,uěŹZUó~Ŕ»ű>‹ď¤×Ńܱ·¦YÍE]_s'Zv·V7bĂîdö ş“Ů·E32ű®¸aętĹ 3§)nŐ+Ri=±«ä AűýĆ m®1h›k ÚćĂ©3ĹĆęg ,%??ŤáL7,%żkXJ~ϰ”|7,Ůr‘7VKÝčdľ7eBGtB»‰ŻîŞÓ]…šşń¬>×D§ß¦ÄÓ˝mć¨x"VëkäH 'C,Ü7íHu? §jşš˘y$ňDČč„»ş“$pCů—8 /sóó䏋g»”2ZďiĄÂÝRľşE0ë1eĐ yë™nĆ^G™+<§yß B’Ś~ˇEçXŁ´ćŹK'čŻéÓó|Że˙={ĂNÝp–23ą˝Ň"„‹;vÔíĘr¬ű멪 .•Î{ýy*ÍC®°¸ěßąěéŞË¶×+ ĆmKź‰M›¨óqáőtooXžs·i čńŘ”ĎYíşr›ËDŕD)]ź‰ ­Úis×gb®±AW°“ä”Ń15ó$ZjšŽĐ¦[şK^mÝI]ÓŁęšđ]źI]ÓIx‘®ĎÄî®Ă𦮵ĤĽbcÓ?6=˘´é<“Łk:lŃҵ–Ř42¦é ;bÓtбk:hѮ适¬ü}bVţ>1+ź•żOlšN掎ćď ş¦ăx€HWnb×txĐJčĘMěš((j÷Q욏#ÉJźišEKÓ…QFŚ ‚¤®Qٮ¤îBŠ8Éh›l2Ú&›¶ÖČ’Ń6Ůd´M6)őcC©7 ÄęĹédőât˛zq:Y˝8ť¬JI©7 E©7 E©7 E©7 E©7 E©7ś+V©0Éi¤ä´ RrÚ)5ő†'D9YˇńgŘyAĺÓďĺMyW•IyO•IYůC9}ąÚĺ1OČlJĚ}Ç‚\¦ż”©ś@E©s>î;ŠąnVš˝LłąŹ %.‹~ŢĘ›—{p ÉSÇ!ܵí6 C8ĚR·Ĺů1şA-O™ fđRG ¤­˝ń“Š5}¤‡”©[Ś T+ośĎŰĽ{äzŕ€EŹ ÔŕZhÖ˛ÍňéŰCµCŔ´R¸ĺ#k+/Í˝&T˝fxl8Ľ1w €ŘőB8 LÔĹÁw禶F(FŐV•”´¸NZ\'-®ł×Y‹ë¬Ĺu|‘ý öদž˘GSÓN!mSSNéýÜtSvoPŰNRPŰNRÓŁŮ»MŹĹI”|LMŹÎÜŻíşLMŹF—¦¶J!Ö@)ÄšŰ)…X÷:Ąë^§bÝë”B¬{ťRuŻS ±îuJ!őÎŽőÎŽE ޵ ŠI ޵ ŠzgGJzgGJzgGJzgGJzgGJzgGJÚş–RŰŰŻt4Ű1ëű3<·Şáżł$˙¨,ŁţĘÖ’őa(ą)Ďŕ^Ů«EěŐ˘AjŃ µhZ4Čn±śĐX$ĽÄÄr? ĺôĂPAéŘ+ëĂP˛U ŻŮŞ…×l•9"[eŽČV™#rS±y¬> %÷ĂPĐnMż.<Ő(T–ŐY(Äôú,”ĽuJŢ: %«łPhŹĘ`ťvÍÍę,–PňĘ^K‰¬ÎBA ę,ÔTť…’xś«B^Yť…ÂŢ×»hóÉgˇ¸ýłPĚd除ËüĽż’ię©elĆsĹK”­•ĚŇĹË޶ؼż-6«m±Óńzť˙'z˛˘=Ć ‘%ŽńTă@‚6=yâVőÜ%AĂöˇ:e Ós#‚ĺY$tćתaCÁ§+DFäą\n ĹŹňFÚ÷„­&đ#Ľ_ĎôT=Âţ)Ž‹Ú†iŐĐmKçzd@]‘ŁĎtVl¦+rKzó}eL̢W:łÚCNč{9ăűBÎńľ‡Đ0ˤgĽŇćX‚Ć~Yí!¤'·UšWîÚg|×ć8ă»6ÇŻ´9”®´9¬“W]÷]úÍ´ËgšŐóóö¬Ăg $Ű çĎj4ł;«‹Ů›ŐĹŞY xV9ľŤžëv(©Ĺ|&¶%BâńŃQG€ŹŐ¸`ąä™*¦›ueá –“Rýâ ZV=G:Ž6(ç7:»ă…É łé0_]ÚK=ĺŽ9ěÄ´ŻÓ®+.oÓ·ís€T‘ů$˘i·Ŕö÷ąć-ËcřČ Kl˙o/; ™ń¬đ¤LW9)ÓUNĘ#÷Ĺ%tnRË嶸D&—ÔÁr9©ĺrŇX*+'¶ÜĎ+A[7áSł±±˝ű©$('+˛Ü—šjLţ©vő1QŃÜTíę­jWUg’€ u& čPg’ ě˛…¦¶Î$É[g’ä­3IrŃhŞŤ¦ŠŃhŞŤ¦ŠŃhŞŤ¦ŠŃhŞlťIRĚľűŐúîőíŐűÍÍíÄ@'®űőógůţëřňŰłDUď.ßŢ AłŘĎ?+±âN#žˇýěî5OgN‚$_^ľ˙ĂúęíĎ.b&ݧoźŮ‚lľŮ\ľ»zýěúí»5Bđbłţĺßf÷×9Uđvb¦äÓź¬~üđîÝzóéDÁó+¤+Ö%IÍ—wëzHí^˝¶ žZ_›Lťr·ěÔ.sçöKç9×w<čúĘŠí´ę˛¨ĽzĂc˝¦¤U:MżÓ‘Ő6ÍďóÉëvhŻÎ)Ă™ů8ě©FřťßÝ|şű¤ n‚ç•!s“đÜL˙rćţrů|řđCeŘÜÇĎNÂs9é{'ńż|ŘĽ»şfúÚSĂ<ĎŘQő? $qÍ:µ”WŚ»čPĎhn›[őćÉôÝíú×ú˙ čžR/ZSű­Ôâ»÷–¶pź?ó´ăV©rvŃçꉮŢgv§Ä™°DŮ)Q(÷P»p“gUÚJ+:mą/mk×’îM:UÍ4“áÓ;„ endstream endobj 936 0 obj << /Author(Roman Iakymchuk)/Title(EZTrace: A Generic Framework for Instrumenting Applications. User Manual)/Subject()/Creator(LaTeX, hyperref, KOMA-Script)/Producer(pdfTeX-1.40.16)/Keywords() /CreationDate (D:20160112093809+01'00') /ModDate (D:20160112093809+01'00') /Trapped /False /PTEX.Fullbanner (This is pdfTeX, Version 3.14159265-2.6-1.40.16 (TeX Live 2015/Debian) kpathsea version 6.2.1) >> endobj 915 0 obj << /Type /ObjStm /N 43 /First 346 /Length 1427 /Filter /FlateDecode >> stream xÚ…X[oŰ6~÷Żŕc[ ±x' @–¬@±®-ÚlVôAq4O›-–ÜËżß9”ÄJ”÷Ëßą}ç;$EÇkV0Ď™·ĚY& ÇśdÂf=“Ň2«™ôšYΔ–ĚX¦ gž¸gÚ3ă‹•łrLsć´aĘB:Ĺ”dŢa,ă R3ΖśqQx&,ă’;&$|ZĂ WĘ®8řéť7ŕnĆ)Č.VMó@pé=„ QćEÁ„’`:Př N+ed<˝ ؤŔMjŚBrť-“Ćmát2 ĎGgY0%4čô•ÔSĘđ•—…g( :kx~uuµZß×Ý®bŢ€ĆWë0öOĘcŐt¨{řú®úŢN¶˙öş>¶`óý··e‹¶!đöp‚¸ ±şľ¦ÄXŔůI5|?V_Q|RŽó¤śNĘŮsĺś‹ĺtRn,Şąžr©b$_Ž´”§ł™4ĹĆÚ$ŤMŇčy¤ŤŁ°2jZź‰ŚżL]kJ]R…-Ux¨° °‰›Tŕ1}¨e2›(°áˑږ&#°‰k›MÓGfč(°–Ë2IšĆ& QÓuoŇu('µâHÔd$´Y•éOE•>) KÍ3i˘ÚŠ/§‘Tí,›¨¶´Ů4}dFmŐ–yµ{ęš ,©ŔCWŁŔj’> ,Îť+śŇôÉ4%]ô.ť¦N‹‰8‘΄S1EFÇ řr$§c™18nłiúČ ÇŔĺ9ťčPd˘§CgW=ŹC97KŹúĚAřĽňI†w |Wî«–}~qwŘ\|ęĘc÷¸„ÎŮ‹7]µżäxKâ%čUP„# "0Č@"ZűzÔűş›ÝľL‰\A‚–Ô$,šA9yfśĆzŁĎŚĐćďň©«ŽŻ‚2ýŃĚžAhTx™€čhRő)RJ“!‹^gĘŹ–'žK4Q)?)ZńXľîŞË›íi·;ţĂ®l÷%t`5µžvĺ¶94\üüçý±ÜTî¨ĂO§ÍżEq÷ŁyÓ´0Ja,1ÂzßöĽxŞŽu»9<…p»ĐŇ]Ś›÷ŽweóOU6…~ýý‹;Rč~Şü ‚˛nvB$<çEĘ Gâ&ě4˛ój †·ĚÄŐÝĆ!´§ŇačŃe-J-ŇśćóRĐi<Ä&K‹@†Úe-ŔЬę\ť°„úĺźt5c9;ßZ§ťÓÔ˝Ä>o ÓgŮ ëdŮüR?BŚďo®áß*ý§>űťćű;qř—Ę™ Ůâą>TöŤ¶«ď/ěáź0ýçŔBŘ˙?s—×ÎXlha~_;?®Ľ@ĂíŐwV?wS!–ÓÝU-x{™ţzřńT±őmŮ•»Ăďŕ[X!~ü ńţ€& ăĄ<,!/ăť}[ýzx¬ÖżµŐčĽţ˝®ľUGř đW7úMŐ^]ÁoŚîŹşy<|cÝńT]_‡Č·ĺCµCë»Óľý\ŔçőÝő5ľÉőű§Şą Á1ţřdâü endstream endobj 937 0 obj << /Type /XRef /Index [0 938] /Size 938 /W [1 3 1] /Root 935 0 R /Info 936 0 R /ID [ ] /Length 2668 /Filter /FlateDecode >> stream xÚ%Řg|ŐĆáY;5„ -H(ˇ‘ŢCďˇÄŽJ¤˘ HW)ŇFDĘE®€˘˘(TŠŔĹޱpß˙öËó;łfÎě˛ÖŢ3çAÜr•ŹňPÁA$° X~ OˇZXŽ#M¬,‡QP€X,±2F  ±RÄJsX˘‰•'VŠĂÂP„X%b±…bÄŞ+Éaq(A¬*±=ś «ălÄ߀;‡iÄü×|ăô*L'Ćť#ľăŚ(Ě ć›ŚňÄ2‰Ń«źxb5ůîV„b5‰1˘H"T"V›j$«CŚŮT†*ÄęóÓTŞk@Ś™ŚT‡bť‰ů)N…4bąÄČB$2ő#ćÓ“ 5ő'F#5ˇ±<ň›ĎadBl8‡µˇ±ˇÄ†qXęqŔPs >‡a‡  !‡Ĺ ŹĂFĐš@s ‚ߡ¦ĐŚëzB7čí ?go–p;´‚ÖĐÚB;h #t‚ÎĐşB7Č…îĐzB/č } /ôß0üC ,Ďa=m-8ôs•gAd†?Ë4…>Ă-(ëců\ÜÄ‚ţi~Y‘ŐĐ/ę ôË… ťeRý%…řF ”…XđĺMņ~‘Păˇ_fXÄ‚¸Ăţ»~iPüˇ/~J>,Ç HTHµ‡”wČ: }ŤS±a‚ ü ą9)Ç0Ů‚¤'ü‰Ęś ,B_R)¨|ůD‰†ő Ë‚Ě>ć+Śô„9dĎň±úĐ( )°)wÎŞ8ô’ ,’°90Ů!µR!µR!µR!µR!µRaG ]ňŤű2#É!Ĺvµ ĺYÂ!驍کŤÚýDô° Ő.q_.. ĄÁOń  ÂtŠřës¶P ˇŠˇÇ"ߢŠň+* €O·˛?ô "…ˇřäE[pw¦?[ŠC%·`äfíŮŁ‹ŃçĹběťâˇb\2|"ž,ĆoJŠGű‰oŠÇ>“ö‹ÇO‹É}Ĺ”­âÉOĹÔt1m‚ľRĚ('f6łÚŠŮSĹśEbîŰbŢ_bAńLsńěÓb!—ńńhqt†ř„é<öř”ÖŽ/źÝ+>Ď'HíÉ*âT5q:Zś)+Îfs…ÄůŠâB|#ľřE|•%.ŇÉKŹ‹ËÓĹ•…âëÁâ*żö‘¸~FÜ`Dßpń·÷ďöű$A2ř­ Š?0¬ič'ýóń Óţk ń}ůť„ţ‘ nňéć—âO2ř×*ńwľř‡tßj•…Ő®ŁĘâE¤´(¨ś+Ć ÝŃ7EaĺČŠěE•_+v‡(^]”(—D —”TV-ö-Qj“(=W”Ńđ­lQN=°¸Î˘<ź*üűŕ«Ő!Ĺ,žţĹ+yVń‘đłHäö•4k–tÂ# Ň!Ă,ů]ť¨ü¨˘j·ŞĘ›UÓú°ę´‘’'Ria:?Ť†˝â8kđł®âóŞ G›ťĐ^l'§¨µÓĚäéíâŚYvV[¤ť›#ÎS*H÷TÝ—¬ý‹zJÚ%jň2'®°ń|MŻ®ľ!®‘řë¤űl7^ß°*ľ#ˇßkßµŕ'¦ógíčö ťü•ţŤŠřŠ˝I¦˙býÍ×ţŃ>i·Ô+¨ťiĂsî¤Ňu.˘Őă =í]!bŃz!p…—Š"Ę´+Şąb+DqµćJh†\Ś É•Ô^ěb56Wę}QZóçĘŞ]9=ž\śzęĘëéě*ĐdĽJŢU<"ËJÚĄ\’jÜ%ëAĺ*ďU“|fn–p»ąj÷ëDő É=”\šh.]łë2´G¸LU§«Á jNµT÷.KU粕1F/wn¬ŢÍÜ8ćyĽ67÷˝ź ťÁMÔěÓłÂMzG°sąÉڟݔ }Í=UOLUşiÚ‚ÜôŁâi˝(ą™d–v7;GĚŃ‹ś›§EçćëŃáh¸g´ąą…|zN‹Ř-*ěGŮş@Ws‹źÓ‰UŢn‰VŁ[ŞýŔ-Ó2uËéîJR¶ŠtŻÖˢ{EŻQîU˝ű¸5ĚĆZćyť–˝[żGl¨ 629›-$9LŻçřvsˇ;ô0·őwťŘFŐíĐCÄíäp7CŘŁç űďe±—něcDű(ůýWĹâ “ř˝:ĚŮ#z&»Źô$qG™ńcÚĄÜńÚâ3ŠćÓtjŠ8­=ÖťŃçÎ…âĽvwáCń%5~Qď»î25yE/ďî*szMďŢî:—Ü'ľ=ćÇŃ zCs?Äř˙uâ ¶¨ôˇţś8đ˝T€x¨ ţO$H†Ęŕ˙„ń˙şřżYŞC ¤‚˙›Ĺ˙Ż’aQ©oTV~đŠňň endstream endobj startxref 208739 %%EOF eztrace-1.1-2/doc/user_manual.tex000066400000000000000000000656651265506773700170150ustar00rootroot00000000000000%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % FOR PRINTING \documentclass[ 11pt, a4paper, openright, cleardoubleplain, appendixprefix, chapterprefix, numbers=noenddot, DIV11, BCOR15mm ]{report} \newcommand{\eztrace}{EZTrace} \newcommand{\reporttitle}{\eztrace} \newcommand{\reportsubtitle}{A Generic Framework for\\ Instrumenting Applications} \newcommand{\reportsubsubtitle}{User Manual} %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \usepackage{etex} \usepackage{savesym} \usepackage[utf8]{inputenc} \usepackage[T1]{fontenc} \usepackage[small,bf]{caption} % for plotting \usepackage{tikz} \usepackage{pgfplots} \usepackage{subfigure} \usepackage{graphicx} \usepackage{color} \usepackage{xcolor} \definecolor{ListingsKeywordColor}{rgb}{0,0,0.4} \definecolor{ListingsIdentifierColor}{rgb}{0,0.5,0} \definecolor{ListingsCommentColor}{rgb}{0.4,0.4,0.4} \definecolor{ListingsStringColor}{rgb}{0.6000,0.3333,0.7333}%{0.8,0,0} \definecolor{ListingsRuleSepColor}{rgb}{0,0,0} \definecolor{ListingsEmphColor}{rgb}{0,0.6667,0.6667} \definecolor{ListingsBreakSymbolColor}{rgb}{0.780,0.082,0.522} \definecolor{LinkColor}{rgb}{0,0,0.5} \definecolor{UnitColor}{rgb}{0,0,0} \definecolor{MathsVectorColor}{rgb}{0,0,0} \definecolor{MathsMatrixColor}{rgb}{0,0,0} \definecolor{MyGreen}{HTML}{228B22} % \definecolor{TikzGreen}{HTML}{} \definecolor{MyBlue}{HTML}{0000FF} \colorlet{MatrixElementsLight}{gray!20!white} \colorlet{MatrixElementsDark}{gray!40} % for listing \usepackage{listings} \lstset{ basicstyle=\scriptsize\ttfamily, tabsize=3, showtabs=false, showspaces=false, showstringspaces=false, tab=\rightarrowfill, keywordstyle=\color{ListingsKeywordColor}, identifierstyle=\color{ListingsIdentifierColor}, commentstyle=\color{ListingsCommentColor}, stringstyle=\color{ListingsStringColor}, emphstyle=\color{ListingsEmphColor}\bfseries\underbar, frame=none, rulesepcolor=\color{ListingsRuleSepColor}, numbers=left, numberstyle=\tiny, numbersep=5pt, captionpos=top, frame=tb, firstnumber=1, stepnumber=1, % numberfirstline=false, breaklines=true, breakatwhitespace=true, % prebreak=\mbox{\,$\color{ListingsBreakSymbolColor}\mathbf{\hookleftarrow}$}, mathescape=true, morekeywords={}, } \usepackage{url} \usepackage[final]{hyperref} \hypersetup{ % Farben fuer die Links colorlinks=false, % Links erhalten Farben statt Kaeten urlcolor=LinkColor, % \href{...}{...} external (URL) filecolor=LinkColor, % \href{...} local file linkcolor=LinkColor, %\ref{...} and \pageref{...} menucolor=LinkColor, citecolor=LinkColor, % Links raiselinks=true, % calculate real height of the link breaklinks, % Links berstehen Zeilenumbruch %backref=page, % Backlinks im Literaturverzeichnis (section, slide, page, none) %pagebackref=true, % Backlinks im Literaturverzeichnis mit Seitenangabe verbose, hyperindex=true, % backlinkex index linktocpage=true, % Inhaltsverzeichnis verlinkt Seiten hyperfootnotes=false, % Keine Links auf Fussnoten % Bookmarks bookmarks=true, % Erzeugung von Bookmarks fuer PDF-Viewer bookmarksopenlevel=1, % Gliederungstiefe der Bookmarks bookmarksopen=false, % Expandierte Untermenues in Bookmarks bookmarksnumbered=true, % Nummerierung der Bookmarks bookmarkstype=toc, % Art der Verzeichnisses % Anchors plainpages=false, % Anchors even on plain pages ? pageanchor=true, % Pages are linkable % PDF Informationen pdftitle={\reporttitle: \reportsubtitle. \reportsubsubtitle}, % Titel pdfauthor={Roman Iakymchuk}, % Autor pdfcreator={LaTeX, hyperref, KOMA-Script}, pdfstartview=Fit, % Dokument wird Fit Height geaefnet pdffitwindow=true, pdfpagemode=UseOutlines, % Bookmarks im Viewer anzeigen pdfpagelabels=true, % set PDF page labels } \usepackage{cleveref} \Crefname{algorithm}{Alg.}{Algs.} \Crefname{figure}{Fig.}{Figs.} \Crefname{table}{Tab.}{Tabs.} \Crefname{equation}{Eq.}{Eqs.} \Crefname{eqnarray}{Eq.}{Eqs.} \usepackage{float} \newfloat{algorithm}{htb}{lob} \floatname{algorithm}{Algorithm} \newlength{\figlength} \setlength{\figlength}{7.6cm} %8.2cm \newlength{\subfiglength} \setlength{\subfiglength}{7.3cm}%7.8 \newcommand{\becomes}{:=} \newcommand{\bytes}{b} \newcommand{\kb}{Kb} \newcommand{\mb}{Mb} \newcommand{\ghz}{GHz} \newcommand{\flop}{Flop} \newcommand{\flops}{Flops} \newcommand{\gflops}{G\flops} \newcommand{\svn}{SVN} \newcommand{\fxt}{FxT} \newcommand{\gtg}{GTG} \newcommand{\mpi}{MPI} % Title Page \title{ {\Huge\bf \reporttitle{}}\\[6mm] {\LARGE\bf \reportsubtitle}\\[12mm] {\Large\bf \reportsubsubtitle}} % \author{Roman Iakymchuk} \begin{document} \maketitle \tableofcontents \chapter{License of \eztrace} \eztrace{} is a computer program whose purpose is to analyze the performance of parallel applications. \eztrace{} is governed by the CeCILL-B license under French law and abiding by the rules of distribution of free software. You can use, modify and/ or redistribute the software under the terms of the CeCILL-B license as circulated by CEA, CNRS and INRIA at the following URL "http://www.cecill.info". As a counterpart to the access to the source code and rights to copy, modify and redistribute granted by the license, users are provided only with a limited warranty and the software's author, the holder of the economic rights, and the successive licensors have only limited liability. In this respect, the user's attention is drawn to the risks associated with loading, using, modifying and/or developing or reproducing the software by the user in light of its specific status of free software, that may mean that it is complicated to manipulate, and that also therefore means that it is reserved for developers and experienced professionals having in-depth computer knowledge. Users are therefore encouraged to load and test the software's suitability as regards their requirements in conditions enabling the security of their systems and/or data to be ensured and, more generally, to use and operate it in the same conditions as regards security. The fact that you are presently reading this means that you have had knowledge of the CeCILL-B license and that you accept its terms. \chapter{Overview of \eztrace{}} \eztrace{}~\cite{Aulagnon12EZTrace,TraRue11Ccgrid,Coulomb10periscope} is a tool that aims at generating automatically execution traces from High-Performance Computing (HPC) programs. It generates execution trace files that can be interpreted by visualization tools such as ViTE~\cite{vite}. \eztrace{} has been designed to provide a simple way to trace parallel applications. This framework relies on plugins in order to offer a generic way to analyze programs; depending on the application to analyze or on the point to focus on, several modules an be loaded. \eztrace{} provides pre-defined plugins that give the ability to the user to analyze applications that use \mpi{} libraries, OpenMP, or Pthreads. However, user-defined plugins can also be loaded in order to analyze application functions or custom libraries. \chapter{Installation} \section{Requirements} In order to run \eztrace{}, the following software needs to be installed: \begin{enumerate} \item autoconf of version 2.63; \item {[}Optional\,{]} Any \mpi{} implementation. Make sure your \mpi{} installation provides dynamic libraries. \end{enumerate} We use custom versions of the following software: \begin{enumerate} \item LiTL v.0.1 (\url{}); \item \fxt{} v.0.2.10 (\url{http://download.savannah.gnu.org/releases/fkt/}); \item \gtg{} v.0.2 (\url{http://gforge.inria.fr/projects/gtg/}). \end{enumerate} Those are already included in \eztrace{}, but you can also provide your own versions. \section{Getting \eztrace} \begin{enumerate} \item You can get the latest stable release from the \eztrace{} website, \url{http://eztrace.gforge.inria.fr/}; \item Current development version is available via \svn{}\\ \texttt{svn checkout svn+ssh://scm.gforge.inria.fr/svn/eztrace}. \end{enumerate} After getting the latest development version (from \svn{}), you need to run\\ \hspace*{0.9cm}\texttt{./bootstrap}\\ and only then build the tool. \section{Building \eztrace{}} At first, you need to configure \eztrace{} by invoking the configure script:\\ \hspace*{0.9cm}\texttt{./configure -\,-prefix=}\\ Options to configure. You can pass several options to the configure script for specifying where it should find the required libraries:\\ \begin{tabular}{@{\hskip .9cm}l} \texttt{-\,-with-fxt=\$FXT\_ROOT} -- specify where \fxt{} is installed;\\ \texttt{-\,-with-gtg=\$GTG\_ROOT} -- specify where \gtg{} is installed;\\ \texttt{-\,-with-mpi=\$MPI\_ROOT} -- specify where \mpi{} is installed. The \texttt{mpi.h}\\ \hspace*{0.4cm}file must be located in the \texttt{\$MPI\_ROOT/include/directory};\\ \texttt{-\,-with-mpi-include=} -- specify the directory that\\ \hspace*{0.4cm}contains the \texttt{mpi.h} file. \end{tabular} Once \eztrace{} is configured, just run\\ \hspace*{0.9cm}\texttt{make}\\ \hspace*{0.9cm}\texttt{make install} \chapter{How to Use \eztrace?} \section{Recording Events} \subsection{Selecting Functions to Instrument} First, you should select functions in your application that you want to instrument. For this, you can set the \texttt{EZTRACE\_TRACE} environment variable to the list of plugins that should be used. For instance, set\\ \hspace*{0.9cm}\texttt{export EZTRACE\_TRACE="pthread mpi"}\\ if you want to instrument the PThread and \mpi{} functions. You can get the list of available plugins using the \texttt{eztrace\_avail} command:\\ \hspace*{0.9cm}\texttt{eztrace\_avail}\\[1mm] \begin{tabular}{@{\hskip 1.3cm}lll} \tt 3 & \tt stdio & \tt Module for stdio functions (read, write,\\ & & \tt select, poll, etc.)\\ \tt 2 & \tt pthread & \tt Module for PThread synchronization functions\\ & & \tt (mutex, semaphore, spinlock, etc.)\\ \tt 6 & \tt papi & \tt Module for PAPI Performance counters\\ \tt 1 & \tt omp & \tt Module for OpenMP parallel regions\\ \tt 4 & \tt mpi & \tt Module for \mpi{} functions\\ \tt 5 & \tt memory & \tt Module for memory functions (malloc, free,\\ & & \tt etc.) \end{tabular} You can get the list of selected modules with the \texttt{eztrace\_loaded} command:\\ \hspace*{0.9cm}\texttt{export EZTRACE\_TRACE="pthread mpi"}\\ \hspace*{0.9cm}\texttt{eztrace\_loaded}\\[1mm] \begin{tabular}{@{\hskip 1.3cm}lll} \tt 2 & \tt pthread & \tt Module for PThread synchronization functions\\ & & \tt (mutex, semaphore, spinlock, etc.)\\ \tt 4 & \tt mpi & \tt Module for \mpi{} functions \end{tabular} \subsection{Generating Execution Traces} Once the list of plugins is selected, you can run your application with \eztrace{}. For example:\\ \hspace*{0.9cm}\texttt{eztrace ./my\_program my\_arg1 my\_arg2}\\ This command line executes your program and generates a trace file in the \texttt{/tmp} directory (usually the file is named as \texttt{/tmp/\_eztrace\_log\_\\rank\_}). \subsection{Using \eztrace{} for \mpi{} Applications} \eztrace{} needs to instrument each \mpi{} process. Thus, you can run the following command:\\ \hspace*{0.9cm}\texttt{mpirun -np nproc eztrace ./my\_program},\\ where {\tt npoc} is the number of \mpi{} processes. When your application ends. Each process writes a file named\\ \hspace*{0.9cm}\texttt{/tmp/\_eztrace\_log\_rank\_}. \subsection{Changing the Output Directory} \label{sec:changing_dir} By default, each process saves its trace in the local \texttt{/tmp} directory. You can change this by setting the \texttt{EZTRACE\_TRACE\_DIR} environment variable. \section{Post-Mortem Analysis} \subsection{Merging Execution Traces} Once the execution traces are recorded, you can merge and convert them into a file format that can be read by your visualization software:\\ \hspace*{0.9cm}\texttt{eztrace\_convert -o my\_paje.trace /tmp/\_eztrace\_}\\ \hspace*{1.3cm}\texttt{log\_rank\_0 /tmp/\_eztrace\_log\_rank\_1} This converts the trace files into the Paje format. If \gtg{} is installed with OTF support (this is enabled by default), you can choose to convert into the OTF file format with the \texttt{-t OTF} option:\\ \hspace*{0.9cm}\texttt{eztrace\_convert -t OTF /tmp/\_eztrace\_log\_rank\_0}\\ \hspace*{1.3cm}\texttt{/tmp/\_eztrace\_log\_rank\_1} \subsection{Filtering Events} You can select the plugins to use for the conversion phase by using the \texttt{EZTRACE\_TRACE} environment variable. For instance, if your traces contains \mpi{} and other events, then by setting \texttt{EZTRACE\_TRACE} to \texttt{mpi} and calling \texttt{eztrace\_convert} you will receive an output trace that contains only \mpi{} events. \subsection{Computing Statistics} Instead of creating a merged trace file, you can tell \eztrace{} to compute statistics on the recorded traces:\\ \hspace*{0.9cm}\texttt{eztrace\_stats /tmp/\_eztrace\_log\_rank\_0}\\ \hspace*{1.3cm}\texttt{/tmp/\_eztrace\_log\_rank\_1}\\[1mm] \begin{tabular}{@{\hskip 1.7cm}l} \tt [...]\\ \tt PThread:\\ \tt --------------\\ \tt 6 locks acquired\\ \\ \tt MPI:\\ \tt -----\\ \tt 27 messages sent\\ \tt MPI\_RECV: 10 calls\\ \tt MPI\_BARRIER: 11 calls\\ \tt 163 events handled \end{tabular} \section{User-defined Plugins} \subsection{Defining Custom Plugins} Since \eztrace{} works with plugins, you can create one and instrument the functions that you want. An example of a custom plugin is available in the \texttt{example} directory. Once your plugin is created, you should tell \eztrace{} where to find it. For this, just set the \texttt{EZTRACE\_LIBRARY\_PATH} variable to the appropriate directory(-ies):\\ \hspace*{0.9cm}\texttt{export EZTRACE\_LIBRARY\_PATH=plugin1:plugin2}\\ \hspace*{0.9cm}\texttt{eztrace\_avail}\\[1mm] \begin{tabular}{@{\hskip 1.3cm}lll} \tt 3 & \tt stdio & \tt Module for stdio functions (read, write,\\ & & \tt select, poll, etc.)\\ \tt 2 & \tt pthread & \tt Module for PThread synchronization func-\\ & & \tt tions (mutex, semaphore, spinlock, etc.)\\ \tt 6 & \tt papi & \tt Module for PAPI Performance counters\\ \tt 1 & \tt omp & \tt Module for OpenMP parallel regions\\ \tt 4 & \tt mpi & \tt Module for MPI functions\\ \tt 5 & \tt memory & \tt Module for memory functions (malloc, free,\\ & & \tt etc.)\\ \tt 99 & \tt plugin1 & \tt Example module for libplugin1\\ \tt 98 & \tt plugin2 & \tt Example module for the plugin2 library\\ \end{tabular} \subsection{Generating Custom Plugins} You can generate one plugin and instrument the functions you want. In order to generate your plugin, you need to create a file containing: \begin{enumerate} \item The name of the library you want to trace (\texttt{libNAME.so}); \item {[}Optional{]} A brief description of the library; \item An ID to identify the module. 0 is reserved for \eztrace{} internal use. Thus, you can use any between 10 and ff; \item The prototype of the functions you want to instrument. \end{enumerate} As a result, your file should look as follow \lstset{language=C, caption={\tt example.tpl}} \begin{lstlisting} BEGIN_MODULE NAME example_lib DESC "module for the example library" ID 99 int example_do_event(int n) double example_function1(double* array, int array_size) END_MODULE \end{lstlisting} Now use \texttt{eztrace\_create\_plugin} to generate the plugin source code:\\ \hspace*{0.9cm}\texttt{eztrace\_create\_plugin example.tpl}\\ \begin{tabular}{@{\hskip 1.3cm}l} \tt New Module\\ \tt Module name: 'example\_lib'\\ \tt Module description: '"module for the example library"'\\ \tt Module id: '99'\\ \tt \hspace*{0.8cm} emulate record\_state for 'example\_do\_event'\\ \tt Function 'example\_do\_event' done\\ \tt \hspace*{0.8cm} emulate record\_state for 'example\_function1'\\ \tt Function 'example\_function1' done\\ \tt End of Module example\_lib \end{tabular}\\ The source code is generated in the output directory. Just type:\\ \hspace*{0.9cm}\texttt{make}\\ Then, set the \texttt{EZTRACE\_LIBRARY\_PATH} to the appropriate directory. Now, your custom plugin is ready to be used. You can also determine (in the \texttt{example.tpl} file) the way a function is depicted in the output trace. For instance, \lstset{language=C, caption={}} \begin{lstlisting} int submit_job(int* array, int array_size) BEGIN ADD_VAR("job counter", 1) END \end{lstlisting} specifies that when the \texttt{submit\_job} function is called, the output trace should increment the "job counter" variable. You can now track the value of a variable. The \texttt{test/module\_generator} directory contains several scripts that demonstrate the various commands available. \section{Environment Variables} Here is a list of the environment variables that can be used for tuning \eztrace{}. \begin{itemize} \item General-purpose variables: \begin{itemize} \item \texttt{EZTRACE\_TRACE\_DIR} specifies the directory in which trace files are stored (by default it is \texttt{/tmp}); \item \texttt{EZTRACE\_LIBRARY\_PATH} specifies the directories in which \eztrace{} can find \eztrace{} modules (by default, it is none); \item \texttt{EZTRACE\_TRACE} specifies the list of \eztrace{} modules to load (by default, it is the list of all available modules); \item \texttt{EZTRACE\_BUFFER\_SIZE} specifies the size of the buffer in which \eztrace{} stores events (by default, the size is 32\,MB); \item \texttt{EZTRACE\_FLUSH} specifies the behavior of \eztrace{} when the event buffer is full. If it is set to one, the buffer is flushed. This permits to record traces that are larger than \texttt{EZTRACE\_BUFFER\_SIZE}, but this may impact the application performance. Otherwise, if it is set to zero, which is a default option, any additional event will be recorded. The trace is, thus, truncated and there is no impact on performance. \end{itemize} \item Error-handling variables: \begin{itemize} \item \texttt{EZTRACE\_NO\_SIGNAL\_HANDLER} disables \eztrace{} signal handling (by default, it is zero). \end{itemize} \item Hardware counters-related variables: \begin{itemize} \item \texttt{EZTRACE\_PAPI\_COUNTERS} selects hardware events to trace using the PAPI library, e.g. export \texttt{EZTRACE\_PAPI\_COUNTERS="PAPI\_L3\\\_TCM PAPI\_FP\_INS"}. Please note that the list of supported events as well as the number of events, which can be traced simultaneously, vary depending on the processor type. This information can be retrieved using \texttt{papi\_avail} and the processor documentation. \end{itemize} \item MPI-related variables: \begin{itemize} \item \texttt{EZTRACE\_MPI\_DUMP\_MESSAGES} tells \eztrace{} to dump the list of messages into a file. You can then compute your own statistics on MPI messages. \end{itemize} \end{itemize} \section{Known Limitations} \begin{itemize} \item If \eztrace{} is compiled with a particular \mpi{} implementation such as OpenMPI, it will not work if you run your application with another, e.g. MPICH2. So make sure your application uses the same \mpi{} implementation as \eztrace{}. \end{itemize} \chapter{\eztrace{} in Details} \eztrace{} uses a two-phases mechanism for analyzing performance. During the first phase that occurs while the application is executed, functions are intercepted and events are recorded. After the execution of the application, the post-mortem analysis phase is in charge of interpreting the recorded events. This two-phase mechanism permits the library to separate the recording of a function call from its interpretation. It thus allows the user to interpret a function call event in different ways depending on the point he/she wants to focus on. It also reduces the overhead of profiling a program; during the execution of the application, the analysis tool should avoid performing time-consuming tasks such as computing statistics or interpreting function calls. During the execution of the application, \eztrace{} intercepts calls to the functions specified by plugins and records events for each of them. Depending on the type of functions, \eztrace{} uses two different mechanisms for the interception. The functions defined in shared libraries can be overridden using \texttt{LD\_PRELOAD}: When the \eztrace{} library is loaded, it retrieves the addresses of the functions to instrument. When the application calls one of these functions, the version implemented in \eztrace{} is called. This function records events and calls the actual function. The \texttt{LD\_PRELOAD} mechanism cannot be used for functions defined in the application since there is no symbol resolution. In that case, \eztrace{} uses the DynInst~\cite{Buck00DynInst} tool for instrumenting the program on the fly. Using DynInst, \eztrace{} modifies the program to record events at the beginning and/or at the end of each function to instrument. \eztrace{} is structurally divided into two parts: the \eztrace{} core and the \eztrace{} modules. \section{\eztrace{} Core} The \eztrace{} core is composed of several libraries such as the Fast Kernel and User Trace (\fxt{})~\cite{Danjean05FxT} and the Generic Trace Generator (\gtg{})~\cite{Coulomb10periscope,gtg} libraries. \subsection{\fxt{}} For recording events, \eztrace{} relies on the \fxt{} library. Each process being instrumented by \eztrace{} generates a trace file using \fxt{}. In order to keep the trace size as compact as possible, \fxt{} records events in a binary format that contains only the minimum amount of information: a timestamp, an event code, and optional parameters. \subsection{\gtg{}} During the post-mortem analysis phase, \eztrace{} browses the recorded events and interprets them. It can then generate statistics -- such as the length of messages, the duration of critical sections, etc.-- or create a trace file for visualizing the application behavior. For generating trace files, \eztrace{} relies on the \gtg{} library. \gtg{} provides an abstract interface for recording traces. This permits the application to use a single interface for creating traces in multiple formats. Thus, an application can generate PAJ\'E traces or OTF files without any modification. Althought PAJ\'E and OTF are both traces format, they have some differences. Thus, adding a meaning to a raw \fxt{} event is the critical part and the event must be interpreted in a way that is conformed to the output format chosen by the user. Otherwise, the traces will not represent the data they should. \section{\eztrace{} Modules} Since \eztrace{} uses the two-phases mechanism, plugins are organized in two parts, accordingly: the description of the functions to instrument, and the interpretation of each function call. During the execution of the application, the first part of the plugin is in charge of recording calls to a set of functions. The second part of the plugin is in charge of adding semantic to the trace. \eztrace{} provides plugins for major parallel programming libraries (MPI, OpenMP, PThread, etc.), but also allows user-defined plugins designed for custom libraries or applications. For example, the PLASMA linear algebra library~\cite{Agullo09Plasma} is shipped with an EZTRACE plugin. \chapter{Frequently Asked Questions} \begin{itemize} \item[\bf Q.] When I run my \mpi{} application with \eztrace{}, all the processes generate the \texttt{/tmp/\_eztrace\_log\_rank\_1} file. What is going wrong? \item[\bf A.] This happens when \eztrace{} fails to intercept calls to \texttt{MPI\_Init} or \texttt{MPI\_Init\_thread}. There can be several reasons for that: \begin{itemize} \item The \eztrace{} \mpi{} module was not compiled. For intercepting calls to \mpi{} functions, you need the MPI module in your installation (look for the \texttt{EZTRACE\_ROOT/lib/libeztrace-autostart-\\mpi.so} file). If you do not see that file, it means that something went wrong during the configuration of \eztrace{}, so check for errors or warnings in the \texttt{config.log} file. \item You specified the list of modules to use and the \mpi{} module was not there. Check your \texttt{EZTRACE\_TRACE} variable or use \texttt{eztrace\_\\loaded}. \end{itemize} If you still experience problems, please contact the \eztrace{} development team and we will fix your problem.\\[1mm] \item[\bf Q.] What if I do not want to trace the whole application, but only a part of it? \item[\bf A.] Then, you can call \texttt{eztrace\_start()} and \texttt{eztrace\_stop()} specify in the code which part to trace. You will need to add \texttt{\#include } and to link with \texttt{libeztrace}. Afterwards, you can run your application as usual, i.e. \texttt{./my\_program my\_arg1}.\\[1mm] \item[\bf Q.] I need to trace my program while using GDB, how can I do that? \item[\bf A.] Just add the \texttt{-d} option to \eztrace{} to enable GDB:\\ \hspace*{0.9cm}\texttt{eztrace -d ./my\_program my\_arg1 my\_arg2}\\ Please note that this should be applied only when a bug occurs while using \eztrace{}.\\[1mm] \item[\bf Q.] I want my trace to be saved in a specific directory, how can I do that? \item[\bf A.] Please take a look in \Cref{sec:changing_dir}.\\[1mm] \item[\bf Q.] What if I do not care about OpenMP and I only want to see \mpi{} communication? \item[\bf A.] You can set \texttt{EZTRACE\_TRACE} to the list of modules you want to activate. By default, all the available modules are enabled, but you can tell \eztrace{} to trace only \mpi{}, OpenMP, or both \mpi{} and OpenMPI functions:\\[1mm] \begin{tabular}{@{\hskip 0.9cm}l} \tt export EZTRACE\_TRACE=mpi\\ \tt export EZTRACE\_TRACE=omp\\ \tt export EZTRACE\_TRACE="omp mpi" \end{tabular}\\[1mm] \item[\bf Q.] Can \eztrace{} generate an OTF trace file so that I can visualize it with Vampir? \item[\bf A.] Yes, since \eztrace{} relies on GTG for writing output traces, it can generate OTF trace files. When converting the trace with \texttt{eztrace\_con\\vert}, just add the \texttt{-t OTF} option:\\ \hspace*{0.9cm}\texttt{eztrace\_convert -t OTF /tmp/\_eztrace\_log\_\\} \hspace*{1.3cm}\texttt{rank\_0 /tmp/\_eztrace\_log\_rank\_1} \end{itemize} \section{Troubleshooting} In case you have not found an answer to your question in the FAQ section, you encounter a bug, or want some explanation about \eztrace{}, please contact and ask our development team: \begin{itemize} \item On the development mailing list\\ \url{https://gforge.inria.fr/mail/?group_id=2774} \item On our IRC channel: \begin{itemize} \item Server: \texttt{chat.freenode.net} \item Channel: \texttt{\#eztrace} \end{itemize} \end{itemize} \bibliographystyle{plain} \cleardoublepage \phantomsection \addcontentsline{toc}{chapter}{Bibliography} \small \bibliography{references} \normalsize \end{document} eztrace-1.1-2/example/000077500000000000000000000000001265506773700146245ustar00rootroot00000000000000eztrace-1.1-2/example/README000066400000000000000000000063061265506773700155110ustar00rootroot00000000000000 --- Writing a plugin module for eztrace --- I - Introduction ================ This is an example of plugin module for eztrace. This directory contains 2 sub-directories: libexample_orig --------------- This is an example library with functions that we want to trace using eztrace. This library implements two simple functions (example_function1 and example_function2). This directory also includes a simple program that uses this library. libexample_eztrace ------------------ This directory contains an example plugin for eztrace. This plugin allows to trace the libexample functions with eztrace. II - Files required for an eztrace module ========================================= Writing an eztrace module requires 2 steps: a. Recording events when a particular function is called. This step happens during the application execution. b. Interpreting the recorded events and generating a trace. This step happens after the application execution, when eztrace_convert is run. It is thus required to create two dynamic libraries that are loaded by eztrace and eztrace_convert. II.1 - Recording events ----------------------- (see libexample_eztrace/example.c) For recording events, eztrace relies on functions that redefines the functions that have to be traced (MPI_Send, pthread_create, etc.) Writing a plugin module for eztrace thus boils down to redefining all the needed functions (for example example_function1 and example_function2). Each redefined function f has to record an event and to call the original f function. Usually such a function looks like this: int f(int arg1, double arg2) { EZTRACE_EVENT2(F_START, arg1, arg2); int ret = f_orig(arg1, arg2); EZTRACE_EVENT1(F_STOP, ret); return ret; } This function records an event (which code is F_START), calls the original f function, and records another after f (which code is F_STOP). In order to call the original f function, the constructor of the library should invoke the INTERCEPT macro: INTERCEPT("f", f_orig); This macro replace the original f function with the one defined in the current module. It copies the address of the original function in the f_orig variable. II.2 - Interpreting the recorded events --------------------------------------- (see libexample_eztrace/eztrace_convert_example.c) The interpretation plugin has to register to eztrace at startup. This can be done by using a constructor (see the libinit function). During the registration, the plugin defines a set of callbacks as well as general information on the plugin: int (*init)(): The initialization function. This function is called once all the plugins are loaded and the trace is started. This function usually declared StateTypes, LinkTypes, etc. int (*handle)(eztrace_event_t* ev): The function that interprets events. It is called for each event in the Fxt trace. int (*handle_stats)(eztrace_event_t* ev): The function called for handling an event when eztrace_stats is called void (*print_stats)(): Print the results of statistics. uint8_t module_prefix: Plugin identifier. char* name: Name of the plugin. It is used for selecting the list of plugins to use (ie. EZTRACE_TRACE) char* description: Description of the plugin (printed by eztrace_avail) eztrace-1.1-2/example/libexample_eztrace/000077500000000000000000000000001265506773700204635ustar00rootroot00000000000000eztrace-1.1-2/example/libexample_eztrace/Makefile000066400000000000000000000014371265506773700221300ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. BIN = libeztrace-convert-example.so libeztrace-autostart-example.so libeztrace-example.so # LDFLAGS=-LPATH_TO_EZTRACE/lib # CFLAGS=-IPATH_TO_EZTRACE/include all: $(BIN) libeztrace-convert-example.so: eztrace_convert_example.c example_ev_codes.h $(CC) --shared -o libeztrace-convert-example.so eztrace_convert_example.c -fPIC $(CFLAGS) $(LDFLAGS) -ldl libeztrace-example.so: example.c example_ev_codes.h $(CC) --shared -o libeztrace-example.so example.c -fPIC $(CFLAGS) $(LDFLAGS) -ldl libeztrace-autostart-example.so: example.c example_ev_codes.h $(CC) --shared -o libeztrace-autostart-example.so example.c -fPIC $(CFLAGS) $(LDFLAGS) -ldl -DEZTRACE_AUTOSTART clean: rm -f $(BIN) eztrace-1.1-2/example/libexample_eztrace/example.c000066400000000000000000000056521265506773700222720ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ /* This file contains an alternative libexample.so * The functions defined in libexample (example_function1 and * example_function2) are redefined so that when the application * call one of these functions, the hereby version of it is actually * invoked. */ /* In order to compile this library, you need to add -ldl */ #include "eztrace.h" #include "example_ev_codes.h" /* pointers to the actual functions (located in the original * libexample.so) */ double (*libexample_function1)(double*, int); double (*libstatic_example_function)(double*, int); int (*libexample_function2)(int*, int); /* redefine example_function1. * This version of the function only record some events and calls * the original example_function1 function */ double example_function1(double *array, int array_size) { /* record an event with code EZTRACE_EXAMPLE_FUNCTION1_ENTRY * and two values */ EZTRACE_EVENT2(EZTRACE_EXAMPLE_FUNCTION1_ENTRY, array, array_size); /* call the actual function (located in the original libexample.so) */ double ret = libexample_function1(array, array_size); /* record another event with code EZTRACE_EXAMPLE_FUNCTION1_ENTRY * and two values */ EZTRACE_EVENT2(EZTRACE_EXAMPLE_FUNCTION1_EXIT, array, array_size); return ret; } double static_example_function(double*array, int array_size) { EZTRACE_EVENT2(EZTRACE_STATIC_EXAMPLE_FUNCTION_ENTRY, array, array_size); /* call the actual function (located in the original libexample.so) */ double ret = libstatic_example_function(array, array_size); /* record another event with code EZTRACE_EXAMPLE_FUNCTION1_ENTRY * and two values */ EZTRACE_EVENT2(EZTRACE_STATIC_EXAMPLE_FUNCTION_EXIT, array, array_size); return ret; } /* redefine example_function2. * This version of the function only record some events and calls * the original example_function2 function */ int example_function2(int *array, int array_size) { EZTRACE_EVENT2(EZTRACE_EXAMPLE_FUNCTION2_ENTRY, array, array_size); int ret = libexample_function2(array, array_size); EZTRACE_EVENT2(EZTRACE_EXAMPLE_FUNCTION2_EXIT, array, array_size); return ret; } void __example_init(void) __attribute__ ((constructor)); /* Initialize the current library */ void __example_init(void) { /* store the address of the example_function1 in libexample_function1 * so that the redefined version of this function can call the * original one */ INTERCEPT("example_function1", libexample_function1); INTERCEPT("example_function2", libexample_function2); INTERCEPT("static_example_function", libstatic_example_function); /* start event recording */ #ifdef EZTRACE_AUTOSTART eztrace_start (); #endif } void __example_conclude(void) __attribute__ ((destructor)); void __example_conclude(void) { /* stop event recording */ eztrace_stop(); } eztrace-1.1-2/example/libexample_eztrace/example_ev_codes.h000066400000000000000000000023151265506773700241370ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #ifndef __EXAMPLE_EV_CODES_H__ #define __EXAMPLE_EV_CODES_H__ /* This file defines the event codes that are used by the example * module. */ #include "ev_codes.h" /* Event codes prefix. This identifies the module and thus should be * unique. * The 0x0? prefix is reserved for eztrace internal use. Thus you can * use any prefix between 0x10 and 0xff. */ #define EXAMPLE_EVENTS_ID USER_MODULE_ID(0x11) #define EXAMPLE_PREFIX (EXAMPLE_EVENTS_ID << NB_BITS_EVENTS) /* Define various event codes used by the example module * The 2 most significant bytes should correspond to the module id, * as below: */ #define EZTRACE_EXAMPLE_FUNCTION1_ENTRY (EXAMPLE_PREFIX | 0x0001) #define EZTRACE_EXAMPLE_FUNCTION1_EXIT (EXAMPLE_PREFIX | 0x0002) #define EZTRACE_EXAMPLE_FUNCTION2_ENTRY (EXAMPLE_PREFIX | 0x0011) #define EZTRACE_EXAMPLE_FUNCTION2_EXIT (EXAMPLE_PREFIX | 0x0012) #define EZTRACE_STATIC_EXAMPLE_FUNCTION_ENTRY (EXAMPLE_PREFIX | 0x0101) #define EZTRACE_STATIC_EXAMPLE_FUNCTION_EXIT (EXAMPLE_PREFIX | 0x0102) #endif /* __EXAMPLE_EV_CODES_H__ */ eztrace-1.1-2/example/libexample_eztrace/eztrace_convert_example.c000066400000000000000000000160611265506773700255430ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ /* This file contains the methods invoked during the conversion of * the trace (ie. during eztrace_convert). * After compilation, this file is transformed into the plugin * libeztrace_convert_example.so * When this plugin is loaded by eztrace_convert, its constructor * (libinit() ) should register the plugin and specify various callbacks */ #include #include #include "example_ev_codes.h" #include "eztrace_convert.h" int eztrace_convert_example_init(); int handle_example_events(eztrace_event_t *ev); void handle_example_function1_entry(); void handle_example_function1_exit(); void handle_example_function2_entry(); void handle_example_function2_exit(); void print_example_stats(); int handle_example_stats(eztrace_event_t *ev); /* Constructor of the plugin. * This function registers the current module to eztrace_convert */ struct eztrace_convert_module example_module; void libinit(void) __attribute__ ((constructor)); void libinit(void) { /* Specify the initialization function. * This function will be called once all the plugins are loaded * and the trace is started. * This function usually declared StateTypes, LinkTypes, etc. */ example_module.init = eztrace_convert_example_init; /* Specify the function to call for handling an event */ example_module.handle = handle_example_events; /* Specify the function to call for handling an event when eztrace_stats is called */ example_module.handle_stats = handle_example_stats; /* Print the results of statistics */ example_module.print_stats = print_example_stats; /* Specify the module prefix */ example_module.module_prefix = EXAMPLE_EVENTS_ID; asprintf(&example_module.name, "example"); asprintf(&example_module.description, "Module for Example library"); example_module.token.data = &example_module; /* Register the module to eztrace_convert */ eztrace_convert_register_module(&example_module); printf("module Example loaded\n"); } void libfinalize(void) __attribute__ ((destructor)); void libfinalize(void) { printf("unloading module Example\n"); } /* * This function will be called once all the plugins are loaded * and the trace is started. * This function usually declared StateTypes, LinkTypes, etc. */ int eztrace_convert_example_init() { addEntityValue("function1_alias", "ST_Thread", "Doing function1", GTG_PINK); addEntityValue("function2_alias", "ST_Thread", "Doing function2", GTG_BLACK); return 0; } /* declare a few variable for computing statistics */ static int nb_function1 = 0; static int nb_function2 = 0; static float total_time_in_function1 = 0; static float total_time_in_function2 = 0; static float last_start_time_function1 = 0; static float last_start_time_function2 = 0; /* Function called for handling an event when eztrace_stats is called * It shall return 1 if the event was handled successfully or * 0 otherwise. */ int handle_example_stats(eztrace_event_t *ev) { /* depending on the event code, let's count the number of calls to function1 and function2 * for both function, compute the average duration of the function call */ switch (ev->code) { case EZTRACE_EXAMPLE_FUNCTION1_ENTRY: nb_function1++; last_start_time_function1 = CURRENT; break; case EZTRACE_EXAMPLE_FUNCTION1_EXIT: /* WARNING: this does not support support reentrant calls to function1. */ total_time_in_function1 += CURRENT - last_start_time_function1; break; case EZTRACE_EXAMPLE_FUNCTION2_ENTRY: nb_function2++; last_start_time_function2 = CURRENT; break; case EZTRACE_EXAMPLE_FUNCTION2_EXIT: /* WARNING: this does not support support reentrant calls to function2. */ total_time_in_function2 += CURRENT - last_start_time_function2; break; default: /* The event was not handled */ return 0; } return 1; } /* Print the results of statistics. */ void print_example_stats() { printf("\nLibExample:\n"); printf("-----------\n"); if (nb_function1) { /* Only print this when calls to function1 were detected */ printf("%d calls to Function1\n", nb_function1); printf("\taverage duration: %f us\n", total_time_in_function1 / nb_function1); } if (nb_function2) { /* Only print this when calls to function2 were detected */ printf("%d calls to Function2\n", nb_function2); printf("\taverage duration: %f us\n", total_time_in_function2 / nb_function2); } } /* * This function is called by eztrace_convert for each event to handle. * It shall return one if the event was handled successfully or zero otherwise. */ int handle_example_events(eztrace_event_t *ev) { switch (ev->code) { case EZTRACE_EXAMPLE_FUNCTION1_ENTRY: handle_example_function1_entry(); break; case EZTRACE_EXAMPLE_FUNCTION1_EXIT: handle_example_function1_exit(); break; case EZTRACE_EXAMPLE_FUNCTION2_ENTRY: handle_example_function2_entry(); break; case EZTRACE_EXAMPLE_FUNCTION2_EXIT: handle_example_function2_exit(); break; case EZTRACE_STATIC_EXAMPLE_FUNCTION_ENTRY: fprintf(stderr, "static exemple function entry\n"); break; case EZTRACE_STATIC_EXAMPLE_FUNCTION_EXIT: fprintf(stderr, "static exemple function exit\n"); break; default: /* The event was not handled */ return 0; } return 1; } /* This function is called by handle_example_events when reaching * the EZTRACE_EXAMPLE_FUNCTION1_ENTRY event. */ void handle_example_function1_entry() { /* FUNC_NAME is used for debugging. If -v is passed to eztrace_convert, * FUNC_NAME prints the name of the function */ FUNC_NAME; /* Initialize a char* thread_id and generate a string that * identifies the thread that issued the current event */ INIT_THREAD_ID(thread_id); /* Update the state of the thread in the output trace. */CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "function1_alias"); free(thread_id); } /* This function is called by handle_example_events when reaching * the EZTRACE_EXAMPLE_FUNCTION1_EXIT event. */ void handle_example_function1_exit() { FUNC_NAME; INIT_THREAD_ID(thread_id); /* Restore the state of the thread to its previous state in the * output trace. */CHANGE() popState(CURRENT, "ST_Thread", thread_id); free(thread_id); } /* This function is called by handle_example_events when reaching * the EZTRACE_EXAMPLE_FUNCTION2_ENTRY event. */ void handle_example_function2_entry() { FUNC_NAME; INIT_THREAD_ID(thread_id); /* Update the state of the thread in the output trace. */CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "function2_alias"); free(thread_id); } /* This function is called by handle_example_events when reaching * the EZTRACE_EXAMPLE_FUNCTION2_EXIT event. */ void handle_example_function2_exit() { FUNC_NAME; INIT_THREAD_ID(thread_id); /* Restore the state of the thread to its previous state in the * output trace. */CHANGE() popState(CURRENT, "ST_Thread", thread_id); free(thread_id); } eztrace-1.1-2/example/libexample_orig/000077500000000000000000000000001265506773700177665ustar00rootroot00000000000000eztrace-1.1-2/example/libexample_orig/Makefile000066400000000000000000000012751265506773700214330ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. BIN = libexample.so libstatic_example.a main main_mpi all: $(BIN) main_mpi: main.c example.h mpicc -o main_mpi main.c -L. -lexample main: main.c example.h libexample.so libstatic_example.a $(CC) -o main main.c -L. -lexample libstatic_example.a -O0 -g libexample.so: example.o $(CC) --shared -o libexample.so example.o -ldl libstatic_example.a: static_example.o ar rcs libstatic_example.a static_example.o static_example.o: static_example.c $(CC) -c static_example.c -O0 -g example.o: example.c example.h $(CC) -o example.o -c example.c -fPIC -O0 -g clean: rm -f $(BIN) *.oeztrace-1.1-2/example/libexample_orig/example.c000066400000000000000000000011441265506773700215650ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include "example.h" /* dummy function #1 */ double example_function1(double *array, int array_size) { int i; double sum = 0; for (i = 0; i < array_size; i++) { array[i] = array[i] * (i + 1); sum += array[i]; } return sum; } /* dummy function #2 */ int example_function2(int *array, int array_size) { int i; int sum = 0; for (i = 0; i < array_size; i++) { array[i] = array[i] * (i + 1); sum += array[i]; } return sum; } eztrace-1.1-2/example/libexample_orig/example.h000066400000000000000000000006351265506773700215760ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #ifndef __EXAMPLE_H__ #define __EXAMPLE_H__ /* dummy function #1 */ double example_function1(double*, int); /* dummy function #2 */ int example_function2(int*, int); double example_static_function(double *array, int array_size); #endif /* __EXAMPLE_H__ */ eztrace-1.1-2/example/libexample_orig/main.c000066400000000000000000000020701265506773700210550ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ /* simple program that calls the libexample library */ #include #include #include "example.h" #define SIZE (1024*1024) int main(int argc, char**argv) { double *double_array = malloc(sizeof(double) * SIZE); int *int_array = malloc(sizeof(int) * SIZE); int i; /* initialize the array with something */ for (i = 0; i < SIZE; i++) { double_array[i] = (i * i) / 31; } double sum_double = example_function1(double_array, SIZE); /* initialize the array with something */ for (i = 0; i < SIZE; i++) { double_array[i] = (i * i) / 31; } double static_sum_double = example_static_function(double_array, SIZE); for (i = 0; i < SIZE; i++) { int_array[i] = i % 17; } int sum_int = example_function2(int_array, SIZE); printf("sum double = %lf\n", sum_double); printf("static sum double = %lf\n", static_sum_double); printf("sum int = %d\n", sum_int); return 0; } eztrace-1.1-2/example/libexample_orig/static_example.c000066400000000000000000000006471265506773700231430ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include "example.h" /* dummy function #1 */ double example_static_function(double *array, int array_size) { int i; double sum = 0; for (i = 0; i < array_size; i++) { array[i] = array[i] * (i + 1); sum += array[i]; } return sum; } eztrace-1.1-2/eztrace.pc.in000066400000000000000000000005111265506773700155540ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. prefix=@prefix@ exec_prefix=@exec_prefix@ libdir=@libdir@ includedir=@includedir@ Name: EZTrace Description: EZTrace - easy to use trace generator Version: @VERSION@ Libs: -L${libdir} -leztrace Cflags: -I${includedir}eztrace-1.1-2/install-sh000077500000000000000000000354631265506773700152100ustar00rootroot00000000000000#!/bin/sh # install - install a program, script, or datafile scriptversion=2014-09-12.12; # UTC # This originates from X11R5 (mit/util/scripts/install.sh), which was # later released in X11R6 (xc/config/util/install.sh) with the # following copyright and license. # # Copyright (C) 1994 X Consortium # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to # deal in the Software without restriction, including without limitation the # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or # sell copies of the Software, and to permit persons to whom the Software is # furnished to do so, subject to the following conditions: # # The above copyright notice and this permission notice shall be included in # all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE # X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN # AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- # TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. # # Except as contained in this notice, the name of the X Consortium shall not # be used in advertising or otherwise to promote the sale, use or other deal- # ings in this Software without prior written authorization from the X Consor- # tium. # # # FSF changes to this file are in the public domain. # # Calling this script install-sh is preferred over install.sh, to prevent # 'make' implicit rules from creating a file called install from it # when there is no Makefile. # # This script is compatible with the BSD install script, but was written # from scratch. tab=' ' nl=' ' IFS=" $tab$nl" # Set DOITPROG to "echo" to test this script. doit=${DOITPROG-} doit_exec=${doit:-exec} # Put in absolute file names if you don't have them in your path; # or use environment vars. chgrpprog=${CHGRPPROG-chgrp} chmodprog=${CHMODPROG-chmod} chownprog=${CHOWNPROG-chown} cmpprog=${CMPPROG-cmp} cpprog=${CPPROG-cp} mkdirprog=${MKDIRPROG-mkdir} mvprog=${MVPROG-mv} rmprog=${RMPROG-rm} stripprog=${STRIPPROG-strip} posix_mkdir= # Desired mode of installed file. mode=0755 chgrpcmd= chmodcmd=$chmodprog chowncmd= mvcmd=$mvprog rmcmd="$rmprog -f" stripcmd= src= dst= dir_arg= dst_arg= copy_on_change=false is_target_a_directory=possibly usage="\ Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE or: $0 [OPTION]... SRCFILES... DIRECTORY or: $0 [OPTION]... -t DIRECTORY SRCFILES... or: $0 [OPTION]... -d DIRECTORIES... In the 1st form, copy SRCFILE to DSTFILE. In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. In the 4th, create DIRECTORIES. Options: --help display this help and exit. --version display version info and exit. -c (ignored) -C install only if different (preserve the last data modification time) -d create directories instead of installing files. -g GROUP $chgrpprog installed files to GROUP. -m MODE $chmodprog installed files to MODE. -o USER $chownprog installed files to USER. -s $stripprog installed files. -t DIRECTORY install into DIRECTORY. -T report an error if DSTFILE is a directory. Environment variables override the default commands: CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG " while test $# -ne 0; do case $1 in -c) ;; -C) copy_on_change=true;; -d) dir_arg=true;; -g) chgrpcmd="$chgrpprog $2" shift;; --help) echo "$usage"; exit $?;; -m) mode=$2 case $mode in *' '* | *"$tab"* | *"$nl"* | *'*'* | *'?'* | *'['*) echo "$0: invalid mode: $mode" >&2 exit 1;; esac shift;; -o) chowncmd="$chownprog $2" shift;; -s) stripcmd=$stripprog;; -t) is_target_a_directory=always dst_arg=$2 # Protect names problematic for 'test' and other utilities. case $dst_arg in -* | [=\(\)!]) dst_arg=./$dst_arg;; esac shift;; -T) is_target_a_directory=never;; --version) echo "$0 $scriptversion"; exit $?;; --) shift break;; -*) echo "$0: invalid option: $1" >&2 exit 1;; *) break;; esac shift done # We allow the use of options -d and -T together, by making -d # take the precedence; this is for compatibility with GNU install. if test -n "$dir_arg"; then if test -n "$dst_arg"; then echo "$0: target directory not allowed when installing a directory." >&2 exit 1 fi fi if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then # When -d is used, all remaining arguments are directories to create. # When -t is used, the destination is already specified. # Otherwise, the last argument is the destination. Remove it from $@. for arg do if test -n "$dst_arg"; then # $@ is not empty: it contains at least $arg. set fnord "$@" "$dst_arg" shift # fnord fi shift # arg dst_arg=$arg # Protect names problematic for 'test' and other utilities. case $dst_arg in -* | [=\(\)!]) dst_arg=./$dst_arg;; esac done fi if test $# -eq 0; then if test -z "$dir_arg"; then echo "$0: no input file specified." >&2 exit 1 fi # It's OK to call 'install-sh -d' without argument. # This can happen when creating conditional directories. exit 0 fi if test -z "$dir_arg"; then if test $# -gt 1 || test "$is_target_a_directory" = always; then if test ! -d "$dst_arg"; then echo "$0: $dst_arg: Is not a directory." >&2 exit 1 fi fi fi if test -z "$dir_arg"; then do_exit='(exit $ret); exit $ret' trap "ret=129; $do_exit" 1 trap "ret=130; $do_exit" 2 trap "ret=141; $do_exit" 13 trap "ret=143; $do_exit" 15 # Set umask so as not to create temps with too-generous modes. # However, 'strip' requires both read and write access to temps. case $mode in # Optimize common cases. *644) cp_umask=133;; *755) cp_umask=22;; *[0-7]) if test -z "$stripcmd"; then u_plus_rw= else u_plus_rw='% 200' fi cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;; *) if test -z "$stripcmd"; then u_plus_rw= else u_plus_rw=,u+rw fi cp_umask=$mode$u_plus_rw;; esac fi for src do # Protect names problematic for 'test' and other utilities. case $src in -* | [=\(\)!]) src=./$src;; esac if test -n "$dir_arg"; then dst=$src dstdir=$dst test -d "$dstdir" dstdir_status=$? else # Waiting for this to be detected by the "$cpprog $src $dsttmp" command # might cause directories to be created, which would be especially bad # if $src (and thus $dsttmp) contains '*'. if test ! -f "$src" && test ! -d "$src"; then echo "$0: $src does not exist." >&2 exit 1 fi if test -z "$dst_arg"; then echo "$0: no destination specified." >&2 exit 1 fi dst=$dst_arg # If destination is a directory, append the input filename; won't work # if double slashes aren't ignored. if test -d "$dst"; then if test "$is_target_a_directory" = never; then echo "$0: $dst_arg: Is a directory" >&2 exit 1 fi dstdir=$dst dst=$dstdir/`basename "$src"` dstdir_status=0 else dstdir=`dirname "$dst"` test -d "$dstdir" dstdir_status=$? fi fi obsolete_mkdir_used=false if test $dstdir_status != 0; then case $posix_mkdir in '') # Create intermediate dirs using mode 755 as modified by the umask. # This is like FreeBSD 'install' as of 1997-10-28. umask=`umask` case $stripcmd.$umask in # Optimize common cases. *[2367][2367]) mkdir_umask=$umask;; .*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;; *[0-7]) mkdir_umask=`expr $umask + 22 \ - $umask % 100 % 40 + $umask % 20 \ - $umask % 10 % 4 + $umask % 2 `;; *) mkdir_umask=$umask,go-w;; esac # With -d, create the new directory with the user-specified mode. # Otherwise, rely on $mkdir_umask. if test -n "$dir_arg"; then mkdir_mode=-m$mode else mkdir_mode= fi posix_mkdir=false case $umask in *[123567][0-7][0-7]) # POSIX mkdir -p sets u+wx bits regardless of umask, which # is incompatible with FreeBSD 'install' when (umask & 300) != 0. ;; *) # $RANDOM is not portable (e.g. dash); use it when possible to # lower collision chance tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$ trap 'ret=$?; rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null; exit $ret' 0 # As "mkdir -p" follows symlinks and we work in /tmp possibly; so # create the $tmpdir first (and fail if unsuccessful) to make sure # that nobody tries to guess the $tmpdir name. if (umask $mkdir_umask && $mkdirprog $mkdir_mode "$tmpdir" && exec $mkdirprog $mkdir_mode -p -- "$tmpdir/a/b") >/dev/null 2>&1 then if test -z "$dir_arg" || { # Check for POSIX incompatibilities with -m. # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or # other-writable bit of parent directory when it shouldn't. # FreeBSD 6.1 mkdir -m -p sets mode of existing directory. test_tmpdir="$tmpdir/a" ls_ld_tmpdir=`ls -ld "$test_tmpdir"` case $ls_ld_tmpdir in d????-?r-*) different_mode=700;; d????-?--*) different_mode=755;; *) false;; esac && $mkdirprog -m$different_mode -p -- "$test_tmpdir" && { ls_ld_tmpdir_1=`ls -ld "$test_tmpdir"` test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1" } } then posix_mkdir=: fi rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" else # Remove any dirs left behind by ancient mkdir implementations. rmdir ./$mkdir_mode ./-p ./-- "$tmpdir" 2>/dev/null fi trap '' 0;; esac;; esac if $posix_mkdir && ( umask $mkdir_umask && $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir" ) then : else # The umask is ridiculous, or mkdir does not conform to POSIX, # or it failed possibly due to a race condition. Create the # directory the slow way, step by step, checking for races as we go. case $dstdir in /*) prefix='/';; [-=\(\)!]*) prefix='./';; *) prefix='';; esac oIFS=$IFS IFS=/ set -f set fnord $dstdir shift set +f IFS=$oIFS prefixes= for d do test X"$d" = X && continue prefix=$prefix$d if test -d "$prefix"; then prefixes= else if $posix_mkdir; then (umask=$mkdir_umask && $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break # Don't fail if two instances are running concurrently. test -d "$prefix" || exit 1 else case $prefix in *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;; *) qprefix=$prefix;; esac prefixes="$prefixes '$qprefix'" fi fi prefix=$prefix/ done if test -n "$prefixes"; then # Don't fail if two instances are running concurrently. (umask $mkdir_umask && eval "\$doit_exec \$mkdirprog $prefixes") || test -d "$dstdir" || exit 1 obsolete_mkdir_used=true fi fi fi if test -n "$dir_arg"; then { test -z "$chowncmd" || $doit $chowncmd "$dst"; } && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } && { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false || test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1 else # Make a couple of temp file names in the proper directory. dsttmp=$dstdir/_inst.$$_ rmtmp=$dstdir/_rm.$$_ # Trap to clean up those temp files at exit. trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 # Copy the file name to the temp name. (umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") && # and set any options; do chmod last to preserve setuid bits. # # If any of these fail, we abort the whole thing. If we want to # ignore errors from any of these, just make sure not to ignore # errors from the above "$doit $cpprog $src $dsttmp" command. # { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } && { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } && { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } && # If -C, don't bother to copy if it wouldn't change the file. if $copy_on_change && old=`LC_ALL=C ls -dlL "$dst" 2>/dev/null` && new=`LC_ALL=C ls -dlL "$dsttmp" 2>/dev/null` && set -f && set X $old && old=:$2:$4:$5:$6 && set X $new && new=:$2:$4:$5:$6 && set +f && test "$old" = "$new" && $cmpprog "$dst" "$dsttmp" >/dev/null 2>&1 then rm -f "$dsttmp" else # Rename the file to the real destination. $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null || # The rename failed, perhaps because mv can't rename something else # to itself, or perhaps because mv is so ancient that it does not # support -f. { # Now remove or move aside any old file at destination location. # We try this two ways since rm can't unlink itself on some # systems and the destination file might be busy for other # reasons. In this case, the final cleanup might fail but the new # file should still install successfully. { test ! -f "$dst" || $doit $rmcmd -f "$dst" 2>/dev/null || { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null && { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; } } || { echo "$0: cannot unlink or rename $dst" >&2 (exit 1); exit 1 } } && # Now rename the file to the real destination. $doit $mvcmd "$dsttmp" "$dst" } fi || exit 1 trap '' 0 fi done # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC" # time-stamp-end: "; # UTC" # End: eztrace-1.1-2/ltmain.sh000066400000000000000000010520301265506773700150120ustar00rootroot00000000000000 # libtool (GNU libtool) 2.4.2 # Written by Gordon Matzigkeit , 1996 # Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, 2006, # 2007, 2008, 2009, 2010, 2011 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # GNU Libtool is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # As a special exception to the GNU General Public License, # if you distribute this file as part of a program or library that # is built using GNU Libtool, you may include this file under the # same distribution terms that you use for the rest of that program. # # GNU Libtool is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # General Public License for more details. # # You should have received a copy of the GNU General Public License # along with GNU Libtool; see the file COPYING. If not, a copy # can be downloaded from http://www.gnu.org/licenses/gpl.html, # or obtained by writing to the Free Software Foundation, Inc., # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. # Usage: $progname [OPTION]... [MODE-ARG]... # # Provide generalized library-building support services. # # --config show all configuration variables # --debug enable verbose shell tracing # -n, --dry-run display commands without modifying any files # --features display basic configuration information and exit # --mode=MODE use operation mode MODE # --preserve-dup-deps don't remove duplicate dependency libraries # --quiet, --silent don't print informational messages # --no-quiet, --no-silent # print informational messages (default) # --no-warn don't display warning messages # --tag=TAG use configuration variables from tag TAG # -v, --verbose print more informational messages than default # --no-verbose don't print the extra informational messages # --version print version information # -h, --help, --help-all print short, long, or detailed help message # # MODE must be one of the following: # # clean remove files from the build directory # compile compile a source file into a libtool object # execute automatically set library path, then run a program # finish complete the installation of libtool libraries # install install libraries or executables # link create a library or an executable # uninstall remove libraries from an installed directory # # MODE-ARGS vary depending on the MODE. When passed as first option, # `--mode=MODE' may be abbreviated as `MODE' or a unique abbreviation of that. # Try `$progname --help --mode=MODE' for a more detailed description of MODE. # # When reporting a bug, please describe a test case to reproduce it and # include the following information: # # host-triplet: $host # shell: $SHELL # compiler: $LTCC # compiler flags: $LTCFLAGS # linker: $LD (gnu? $with_gnu_ld) # $progname: (GNU libtool) 2.4.2 Debian-2.4.2-1.11 # automake: $automake_version # autoconf: $autoconf_version # # Report bugs to . # GNU libtool home page: . # General help using GNU software: . PROGRAM=libtool PACKAGE=libtool VERSION="2.4.2 Debian-2.4.2-1.11" TIMESTAMP="" package_revision=1.3337 # Be Bourne compatible if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then emulate sh NULLCMD=: # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in *posix*) set -o posix;; esac fi BIN_SH=xpg4; export BIN_SH # for Tru64 DUALCASE=1; export DUALCASE # for MKS sh # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $1 _LTECHO_EOF' } # NLS nuisances: We save the old values to restore during execute mode. lt_user_locale= lt_safe_locale= for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES do eval "if test \"\${$lt_var+set}\" = set; then save_$lt_var=\$$lt_var $lt_var=C export $lt_var lt_user_locale=\"$lt_var=\\\$save_\$lt_var; \$lt_user_locale\" lt_safe_locale=\"$lt_var=C; \$lt_safe_locale\" fi" done LC_ALL=C LANGUAGE=C export LANGUAGE LC_ALL $lt_unset CDPATH # Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh # is ksh but when the shell is invoked as "sh" and the current value of # the _XPG environment variable is not equal to 1 (one), the special # positional parameter $0, within a function call, is the name of the # function. progpath="$0" : ${CP="cp -f"} test "${ECHO+set}" = set || ECHO=${as_echo-'printf %s\n'} : ${MAKE="make"} : ${MKDIR="mkdir"} : ${MV="mv -f"} : ${RM="rm -f"} : ${SHELL="${CONFIG_SHELL-/bin/sh}"} : ${Xsed="$SED -e 1s/^X//"} # Global variables: EXIT_SUCCESS=0 EXIT_FAILURE=1 EXIT_MISMATCH=63 # $? = 63 is used to indicate version mismatch to missing. EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake. exit_status=$EXIT_SUCCESS # Make sure IFS has a sensible default lt_nl=' ' IFS=" $lt_nl" dirname="s,/[^/]*$,," basename="s,^.*/,," # func_dirname file append nondir_replacement # Compute the dirname of FILE. If nonempty, add APPEND to the result, # otherwise set result to NONDIR_REPLACEMENT. func_dirname () { func_dirname_result=`$ECHO "${1}" | $SED "$dirname"` if test "X$func_dirname_result" = "X${1}"; then func_dirname_result="${3}" else func_dirname_result="$func_dirname_result${2}" fi } # func_dirname may be replaced by extended shell implementation # func_basename file func_basename () { func_basename_result=`$ECHO "${1}" | $SED "$basename"` } # func_basename may be replaced by extended shell implementation # func_dirname_and_basename file append nondir_replacement # perform func_basename and func_dirname in a single function # call: # dirname: Compute the dirname of FILE. If nonempty, # add APPEND to the result, otherwise set result # to NONDIR_REPLACEMENT. # value returned in "$func_dirname_result" # basename: Compute filename of FILE. # value retuned in "$func_basename_result" # Implementation must be kept synchronized with func_dirname # and func_basename. For efficiency, we do not delegate to # those functions but instead duplicate the functionality here. func_dirname_and_basename () { # Extract subdirectory from the argument. func_dirname_result=`$ECHO "${1}" | $SED -e "$dirname"` if test "X$func_dirname_result" = "X${1}"; then func_dirname_result="${3}" else func_dirname_result="$func_dirname_result${2}" fi func_basename_result=`$ECHO "${1}" | $SED -e "$basename"` } # func_dirname_and_basename may be replaced by extended shell implementation # func_stripname prefix suffix name # strip PREFIX and SUFFIX off of NAME. # PREFIX and SUFFIX must not contain globbing or regex special # characters, hashes, percent signs, but SUFFIX may contain a leading # dot (in which case that matches only a dot). # func_strip_suffix prefix name func_stripname () { case ${2} in .*) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%\\\\${2}\$%%"`;; *) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%${2}\$%%"`;; esac } # func_stripname may be replaced by extended shell implementation # These SED scripts presuppose an absolute path with a trailing slash. pathcar='s,^/\([^/]*\).*$,\1,' pathcdr='s,^/[^/]*,,' removedotparts=':dotsl s@/\./@/@g t dotsl s,/\.$,/,' collapseslashes='s@/\{1,\}@/@g' finalslash='s,/*$,/,' # func_normal_abspath PATH # Remove doubled-up and trailing slashes, "." path components, # and cancel out any ".." path components in PATH after making # it an absolute path. # value returned in "$func_normal_abspath_result" func_normal_abspath () { # Start from root dir and reassemble the path. func_normal_abspath_result= func_normal_abspath_tpath=$1 func_normal_abspath_altnamespace= case $func_normal_abspath_tpath in "") # Empty path, that just means $cwd. func_stripname '' '/' "`pwd`" func_normal_abspath_result=$func_stripname_result return ;; # The next three entries are used to spot a run of precisely # two leading slashes without using negated character classes; # we take advantage of case's first-match behaviour. ///*) # Unusual form of absolute path, do nothing. ;; //*) # Not necessarily an ordinary path; POSIX reserves leading '//' # and for example Cygwin uses it to access remote file shares # over CIFS/SMB, so we conserve a leading double slash if found. func_normal_abspath_altnamespace=/ ;; /*) # Absolute path, do nothing. ;; *) # Relative path, prepend $cwd. func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath ;; esac # Cancel out all the simple stuff to save iterations. We also want # the path to end with a slash for ease of parsing, so make sure # there is one (and only one) here. func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$removedotparts" -e "$collapseslashes" -e "$finalslash"` while :; do # Processed it all yet? if test "$func_normal_abspath_tpath" = / ; then # If we ascended to the root using ".." the result may be empty now. if test -z "$func_normal_abspath_result" ; then func_normal_abspath_result=/ fi break fi func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$pathcar"` func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$pathcdr"` # Figure out what to do with it case $func_normal_abspath_tcomponent in "") # Trailing empty path component, ignore it. ;; ..) # Parent dir; strip last assembled component from result. func_dirname "$func_normal_abspath_result" func_normal_abspath_result=$func_dirname_result ;; *) # Actual path component, append it. func_normal_abspath_result=$func_normal_abspath_result/$func_normal_abspath_tcomponent ;; esac done # Restore leading double-slash if one was found on entry. func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result } # func_relative_path SRCDIR DSTDIR # generates a relative path from SRCDIR to DSTDIR, with a trailing # slash if non-empty, suitable for immediately appending a filename # without needing to append a separator. # value returned in "$func_relative_path_result" func_relative_path () { func_relative_path_result= func_normal_abspath "$1" func_relative_path_tlibdir=$func_normal_abspath_result func_normal_abspath "$2" func_relative_path_tbindir=$func_normal_abspath_result # Ascend the tree starting from libdir while :; do # check if we have found a prefix of bindir case $func_relative_path_tbindir in $func_relative_path_tlibdir) # found an exact match func_relative_path_tcancelled= break ;; $func_relative_path_tlibdir*) # found a matching prefix func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir" func_relative_path_tcancelled=$func_stripname_result if test -z "$func_relative_path_result"; then func_relative_path_result=. fi break ;; *) func_dirname $func_relative_path_tlibdir func_relative_path_tlibdir=${func_dirname_result} if test "x$func_relative_path_tlibdir" = x ; then # Have to descend all the way to the root! func_relative_path_result=../$func_relative_path_result func_relative_path_tcancelled=$func_relative_path_tbindir break fi func_relative_path_result=../$func_relative_path_result ;; esac done # Now calculate path; take care to avoid doubling-up slashes. func_stripname '' '/' "$func_relative_path_result" func_relative_path_result=$func_stripname_result func_stripname '/' '/' "$func_relative_path_tcancelled" if test "x$func_stripname_result" != x ; then func_relative_path_result=${func_relative_path_result}/${func_stripname_result} fi # Normalisation. If bindir is libdir, return empty string, # else relative path ending with a slash; either way, target # file name can be directly appended. if test ! -z "$func_relative_path_result"; then func_stripname './' '' "$func_relative_path_result/" func_relative_path_result=$func_stripname_result fi } # The name of this program: func_dirname_and_basename "$progpath" progname=$func_basename_result # Make sure we have an absolute path for reexecution: case $progpath in [\\/]*|[A-Za-z]:\\*) ;; *[\\/]*) progdir=$func_dirname_result progdir=`cd "$progdir" && pwd` progpath="$progdir/$progname" ;; *) save_IFS="$IFS" IFS=${PATH_SEPARATOR-:} for progdir in $PATH; do IFS="$save_IFS" test -x "$progdir/$progname" && break done IFS="$save_IFS" test -n "$progdir" || progdir=`pwd` progpath="$progdir/$progname" ;; esac # Sed substitution that helps us do robust quoting. It backslashifies # metacharacters that are still active within double-quoted strings. Xsed="${SED}"' -e 1s/^X//' sed_quote_subst='s/\([`"$\\]\)/\\\1/g' # Same as above, but do not quote variable references. double_quote_subst='s/\(["`\\]\)/\\\1/g' # Sed substitution that turns a string into a regex matching for the # string literally. sed_make_literal_regex='s,[].[^$\\*\/],\\&,g' # Sed substitution that converts a w32 file name or path # which contains forward slashes, into one that contains # (escaped) backslashes. A very naive implementation. lt_sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g' # Re-`\' parameter expansions in output of double_quote_subst that were # `\'-ed in input to the same. If an odd number of `\' preceded a '$' # in input to double_quote_subst, that '$' was protected from expansion. # Since each input `\' is now two `\'s, look for any number of runs of # four `\'s followed by two `\'s and then a '$'. `\' that '$'. bs='\\' bs2='\\\\' bs4='\\\\\\\\' dollar='\$' sed_double_backslash="\ s/$bs4/&\\ /g s/^$bs2$dollar/$bs&/ s/\\([^$bs]\\)$bs2$dollar/\\1$bs2$bs$dollar/g s/\n//g" # Standard options: opt_dry_run=false opt_help=false opt_quiet=false opt_verbose=false opt_warning=: # func_echo arg... # Echo program name prefixed message, along with the current mode # name if it has been set yet. func_echo () { $ECHO "$progname: ${opt_mode+$opt_mode: }$*" } # func_verbose arg... # Echo program name prefixed message in verbose mode only. func_verbose () { $opt_verbose && func_echo ${1+"$@"} # A bug in bash halts the script if the last line of a function # fails when set -e is in force, so we need another command to # work around that: : } # func_echo_all arg... # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "$*" } # func_error arg... # Echo program name prefixed message to standard error. func_error () { $ECHO "$progname: ${opt_mode+$opt_mode: }"${1+"$@"} 1>&2 } # func_warning arg... # Echo program name prefixed warning message to standard error. func_warning () { $opt_warning && $ECHO "$progname: ${opt_mode+$opt_mode: }warning: "${1+"$@"} 1>&2 # bash bug again: : } # func_fatal_error arg... # Echo program name prefixed message to standard error, and exit. func_fatal_error () { func_error ${1+"$@"} exit $EXIT_FAILURE } # func_fatal_help arg... # Echo program name prefixed message to standard error, followed by # a help hint, and exit. func_fatal_help () { func_error ${1+"$@"} func_fatal_error "$help" } help="Try \`$progname --help' for more information." ## default # func_grep expression filename # Check whether EXPRESSION matches any line of FILENAME, without output. func_grep () { $GREP "$1" "$2" >/dev/null 2>&1 } # func_mkdir_p directory-path # Make sure the entire path to DIRECTORY-PATH is available. func_mkdir_p () { my_directory_path="$1" my_dir_list= if test -n "$my_directory_path" && test "$opt_dry_run" != ":"; then # Protect directory names starting with `-' case $my_directory_path in -*) my_directory_path="./$my_directory_path" ;; esac # While some portion of DIR does not yet exist... while test ! -d "$my_directory_path"; do # ...make a list in topmost first order. Use a colon delimited # list incase some portion of path contains whitespace. my_dir_list="$my_directory_path:$my_dir_list" # If the last portion added has no slash in it, the list is done case $my_directory_path in */*) ;; *) break ;; esac # ...otherwise throw away the child directory and loop my_directory_path=`$ECHO "$my_directory_path" | $SED -e "$dirname"` done my_dir_list=`$ECHO "$my_dir_list" | $SED 's,:*$,,'` save_mkdir_p_IFS="$IFS"; IFS=':' for my_dir in $my_dir_list; do IFS="$save_mkdir_p_IFS" # mkdir can fail with a `File exist' error if two processes # try to create one of the directories concurrently. Don't # stop in that case! $MKDIR "$my_dir" 2>/dev/null || : done IFS="$save_mkdir_p_IFS" # Bail out if we (or some other process) failed to create a directory. test -d "$my_directory_path" || \ func_fatal_error "Failed to create \`$1'" fi } # func_mktempdir [string] # Make a temporary directory that won't clash with other running # libtool processes, and avoids race conditions if possible. If # given, STRING is the basename for that directory. func_mktempdir () { my_template="${TMPDIR-/tmp}/${1-$progname}" if test "$opt_dry_run" = ":"; then # Return a directory name, but don't create it in dry-run mode my_tmpdir="${my_template}-$$" else # If mktemp works, use that first and foremost my_tmpdir=`mktemp -d "${my_template}-XXXXXXXX" 2>/dev/null` if test ! -d "$my_tmpdir"; then # Failing that, at least try and use $RANDOM to avoid a race my_tmpdir="${my_template}-${RANDOM-0}$$" save_mktempdir_umask=`umask` umask 0077 $MKDIR "$my_tmpdir" umask $save_mktempdir_umask fi # If we're not in dry-run mode, bomb out on failure test -d "$my_tmpdir" || \ func_fatal_error "cannot create temporary directory \`$my_tmpdir'" fi $ECHO "$my_tmpdir" } # func_quote_for_eval arg # Aesthetically quote ARG to be evaled later. # This function returns two values: FUNC_QUOTE_FOR_EVAL_RESULT # is double-quoted, suitable for a subsequent eval, whereas # FUNC_QUOTE_FOR_EVAL_UNQUOTED_RESULT has merely all characters # which are still active within double quotes backslashified. func_quote_for_eval () { case $1 in *[\\\`\"\$]*) func_quote_for_eval_unquoted_result=`$ECHO "$1" | $SED "$sed_quote_subst"` ;; *) func_quote_for_eval_unquoted_result="$1" ;; esac case $func_quote_for_eval_unquoted_result in # Double-quote args containing shell metacharacters to delay # word splitting, command substitution and and variable # expansion for a subsequent eval. # Many Bourne shells cannot handle close brackets correctly # in scan sets, so we specify it separately. *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") func_quote_for_eval_result="\"$func_quote_for_eval_unquoted_result\"" ;; *) func_quote_for_eval_result="$func_quote_for_eval_unquoted_result" esac } # func_quote_for_expand arg # Aesthetically quote ARG to be evaled later; same as above, # but do not quote variable references. func_quote_for_expand () { case $1 in *[\\\`\"]*) my_arg=`$ECHO "$1" | $SED \ -e "$double_quote_subst" -e "$sed_double_backslash"` ;; *) my_arg="$1" ;; esac case $my_arg in # Double-quote args containing shell metacharacters to delay # word splitting and command substitution for a subsequent eval. # Many Bourne shells cannot handle close brackets correctly # in scan sets, so we specify it separately. *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") my_arg="\"$my_arg\"" ;; esac func_quote_for_expand_result="$my_arg" } # func_show_eval cmd [fail_exp] # Unless opt_silent is true, then output CMD. Then, if opt_dryrun is # not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP # is given, then evaluate it. func_show_eval () { my_cmd="$1" my_fail_exp="${2-:}" ${opt_silent-false} || { func_quote_for_expand "$my_cmd" eval "func_echo $func_quote_for_expand_result" } if ${opt_dry_run-false}; then :; else eval "$my_cmd" my_status=$? if test "$my_status" -eq 0; then :; else eval "(exit $my_status); $my_fail_exp" fi fi } # func_show_eval_locale cmd [fail_exp] # Unless opt_silent is true, then output CMD. Then, if opt_dryrun is # not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP # is given, then evaluate it. Use the saved locale for evaluation. func_show_eval_locale () { my_cmd="$1" my_fail_exp="${2-:}" ${opt_silent-false} || { func_quote_for_expand "$my_cmd" eval "func_echo $func_quote_for_expand_result" } if ${opt_dry_run-false}; then :; else eval "$lt_user_locale $my_cmd" my_status=$? eval "$lt_safe_locale" if test "$my_status" -eq 0; then :; else eval "(exit $my_status); $my_fail_exp" fi fi } # func_tr_sh # Turn $1 into a string suitable for a shell variable name. # Result is stored in $func_tr_sh_result. All characters # not in the set a-zA-Z0-9_ are replaced with '_'. Further, # if $1 begins with a digit, a '_' is prepended as well. func_tr_sh () { case $1 in [0-9]* | *[!a-zA-Z0-9_]*) func_tr_sh_result=`$ECHO "$1" | $SED 's/^\([0-9]\)/_\1/; s/[^a-zA-Z0-9_]/_/g'` ;; * ) func_tr_sh_result=$1 ;; esac } # func_version # Echo version message to standard output and exit. func_version () { $opt_debug $SED -n '/(C)/!b go :more /\./!{ N s/\n# / / b more } :go /^# '$PROGRAM' (GNU /,/# warranty; / { s/^# // s/^# *$// s/\((C)\)[ 0-9,-]*\( [1-9][0-9]*\)/\1\2/ p }' < "$progpath" exit $? } # func_usage # Echo short help message to standard output and exit. func_usage () { $opt_debug $SED -n '/^# Usage:/,/^# *.*--help/ { s/^# // s/^# *$// s/\$progname/'$progname'/ p }' < "$progpath" echo $ECHO "run \`$progname --help | more' for full usage" exit $? } # func_help [NOEXIT] # Echo long help message to standard output and exit, # unless 'noexit' is passed as argument. func_help () { $opt_debug $SED -n '/^# Usage:/,/# Report bugs to/ { :print s/^# // s/^# *$// s*\$progname*'$progname'* s*\$host*'"$host"'* s*\$SHELL*'"$SHELL"'* s*\$LTCC*'"$LTCC"'* s*\$LTCFLAGS*'"$LTCFLAGS"'* s*\$LD*'"$LD"'* s/\$with_gnu_ld/'"$with_gnu_ld"'/ s/\$automake_version/'"`(${AUTOMAKE-automake} --version) 2>/dev/null |$SED 1q`"'/ s/\$autoconf_version/'"`(${AUTOCONF-autoconf} --version) 2>/dev/null |$SED 1q`"'/ p d } /^# .* home page:/b print /^# General help using/b print ' < "$progpath" ret=$? if test -z "$1"; then exit $ret fi } # func_missing_arg argname # Echo program name prefixed message to standard error and set global # exit_cmd. func_missing_arg () { $opt_debug func_error "missing argument for $1." exit_cmd=exit } # func_split_short_opt shortopt # Set func_split_short_opt_name and func_split_short_opt_arg shell # variables after splitting SHORTOPT after the 2nd character. func_split_short_opt () { my_sed_short_opt='1s/^\(..\).*$/\1/;q' my_sed_short_rest='1s/^..\(.*\)$/\1/;q' func_split_short_opt_name=`$ECHO "$1" | $SED "$my_sed_short_opt"` func_split_short_opt_arg=`$ECHO "$1" | $SED "$my_sed_short_rest"` } # func_split_short_opt may be replaced by extended shell implementation # func_split_long_opt longopt # Set func_split_long_opt_name and func_split_long_opt_arg shell # variables after splitting LONGOPT at the `=' sign. func_split_long_opt () { my_sed_long_opt='1s/^\(--[^=]*\)=.*/\1/;q' my_sed_long_arg='1s/^--[^=]*=//' func_split_long_opt_name=`$ECHO "$1" | $SED "$my_sed_long_opt"` func_split_long_opt_arg=`$ECHO "$1" | $SED "$my_sed_long_arg"` } # func_split_long_opt may be replaced by extended shell implementation exit_cmd=: magic="%%%MAGIC variable%%%" magic_exe="%%%MAGIC EXE variable%%%" # Global variables. nonopt= preserve_args= lo2o="s/\\.lo\$/.${objext}/" o2lo="s/\\.${objext}\$/.lo/" extracted_archives= extracted_serial=0 # If this variable is set in any of the actions, the command in it # will be execed at the end. This prevents here-documents from being # left over by shells. exec_cmd= # func_append var value # Append VALUE to the end of shell variable VAR. func_append () { eval "${1}=\$${1}\${2}" } # func_append may be replaced by extended shell implementation # func_append_quoted var value # Quote VALUE and append to the end of shell variable VAR, separated # by a space. func_append_quoted () { func_quote_for_eval "${2}" eval "${1}=\$${1}\\ \$func_quote_for_eval_result" } # func_append_quoted may be replaced by extended shell implementation # func_arith arithmetic-term... func_arith () { func_arith_result=`expr "${@}"` } # func_arith may be replaced by extended shell implementation # func_len string # STRING may not start with a hyphen. func_len () { func_len_result=`expr "${1}" : ".*" 2>/dev/null || echo $max_cmd_len` } # func_len may be replaced by extended shell implementation # func_lo2o object func_lo2o () { func_lo2o_result=`$ECHO "${1}" | $SED "$lo2o"` } # func_lo2o may be replaced by extended shell implementation # func_xform libobj-or-source func_xform () { func_xform_result=`$ECHO "${1}" | $SED 's/\.[^.]*$/.lo/'` } # func_xform may be replaced by extended shell implementation # func_fatal_configuration arg... # Echo program name prefixed message to standard error, followed by # a configuration failure hint, and exit. func_fatal_configuration () { func_error ${1+"$@"} func_error "See the $PACKAGE documentation for more information." func_fatal_error "Fatal configuration error." } # func_config # Display the configuration for all the tags in this script. func_config () { re_begincf='^# ### BEGIN LIBTOOL' re_endcf='^# ### END LIBTOOL' # Default configuration. $SED "1,/$re_begincf CONFIG/d;/$re_endcf CONFIG/,\$d" < "$progpath" # Now print the configurations for the tags. for tagname in $taglist; do $SED -n "/$re_begincf TAG CONFIG: $tagname\$/,/$re_endcf TAG CONFIG: $tagname\$/p" < "$progpath" done exit $? } # func_features # Display the features supported by this script. func_features () { echo "host: $host" if test "$build_libtool_libs" = yes; then echo "enable shared libraries" else echo "disable shared libraries" fi if test "$build_old_libs" = yes; then echo "enable static libraries" else echo "disable static libraries" fi exit $? } # func_enable_tag tagname # Verify that TAGNAME is valid, and either flag an error and exit, or # enable the TAGNAME tag. We also add TAGNAME to the global $taglist # variable here. func_enable_tag () { # Global variable: tagname="$1" re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$" re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$" sed_extractcf="/$re_begincf/,/$re_endcf/p" # Validate tagname. case $tagname in *[!-_A-Za-z0-9,/]*) func_fatal_error "invalid tag name: $tagname" ;; esac # Don't test for the "default" C tag, as we know it's # there but not specially marked. case $tagname in CC) ;; *) if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then taglist="$taglist $tagname" # Evaluate the configuration. Be careful to quote the path # and the sed script, to avoid splitting on whitespace, but # also don't use non-portable quotes within backquotes within # quotes we have to do it in 2 steps: extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"` eval "$extractedcf" else func_error "ignoring unknown tag $tagname" fi ;; esac } # func_check_version_match # Ensure that we are using m4 macros, and libtool script from the same # release of libtool. func_check_version_match () { if test "$package_revision" != "$macro_revision"; then if test "$VERSION" != "$macro_version"; then if test -z "$macro_version"; then cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, but the $progname: definition of this LT_INIT comes from an older release. $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION $progname: and run autoconf again. _LT_EOF else cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, but the $progname: definition of this LT_INIT comes from $PACKAGE $macro_version. $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION $progname: and run autoconf again. _LT_EOF fi else cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package_revision, $progname: but the definition of this LT_INIT comes from revision $macro_revision. $progname: You should recreate aclocal.m4 with macros from revision $package_revision $progname: of $PACKAGE $VERSION and run autoconf again. _LT_EOF fi exit $EXIT_MISMATCH fi } # Shorthand for --mode=foo, only valid as the first argument case $1 in clean|clea|cle|cl) shift; set dummy --mode clean ${1+"$@"}; shift ;; compile|compil|compi|comp|com|co|c) shift; set dummy --mode compile ${1+"$@"}; shift ;; execute|execut|execu|exec|exe|ex|e) shift; set dummy --mode execute ${1+"$@"}; shift ;; finish|finis|fini|fin|fi|f) shift; set dummy --mode finish ${1+"$@"}; shift ;; install|instal|insta|inst|ins|in|i) shift; set dummy --mode install ${1+"$@"}; shift ;; link|lin|li|l) shift; set dummy --mode link ${1+"$@"}; shift ;; uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u) shift; set dummy --mode uninstall ${1+"$@"}; shift ;; esac # Option defaults: opt_debug=: opt_dry_run=false opt_config=false opt_preserve_dup_deps=false opt_features=false opt_finish=false opt_help=false opt_help_all=false opt_silent=: opt_warning=: opt_verbose=: opt_silent=false opt_verbose=false # Parse options once, thoroughly. This comes as soon as possible in the # script to make things like `--version' happen as quickly as we can. { # this just eases exit handling while test $# -gt 0; do opt="$1" shift case $opt in --debug|-x) opt_debug='set -x' func_echo "enabling shell trace mode" $opt_debug ;; --dry-run|--dryrun|-n) opt_dry_run=: ;; --config) opt_config=: func_config ;; --dlopen|-dlopen) optarg="$1" opt_dlopen="${opt_dlopen+$opt_dlopen }$optarg" shift ;; --preserve-dup-deps) opt_preserve_dup_deps=: ;; --features) opt_features=: func_features ;; --finish) opt_finish=: set dummy --mode finish ${1+"$@"}; shift ;; --help) opt_help=: ;; --help-all) opt_help_all=: opt_help=': help-all' ;; --mode) test $# = 0 && func_missing_arg $opt && break optarg="$1" opt_mode="$optarg" case $optarg in # Valid mode arguments: clean|compile|execute|finish|install|link|relink|uninstall) ;; # Catch anything else as an error *) func_error "invalid argument for $opt" exit_cmd=exit break ;; esac shift ;; --no-silent|--no-quiet) opt_silent=false func_append preserve_args " $opt" ;; --no-warning|--no-warn) opt_warning=false func_append preserve_args " $opt" ;; --no-verbose) opt_verbose=false func_append preserve_args " $opt" ;; --silent|--quiet) opt_silent=: func_append preserve_args " $opt" opt_verbose=false ;; --verbose|-v) opt_verbose=: func_append preserve_args " $opt" opt_silent=false ;; --tag) test $# = 0 && func_missing_arg $opt && break optarg="$1" opt_tag="$optarg" func_append preserve_args " $opt $optarg" func_enable_tag "$optarg" shift ;; -\?|-h) func_usage ;; --help) func_help ;; --version) func_version ;; # Separate optargs to long options: --*=*) func_split_long_opt "$opt" set dummy "$func_split_long_opt_name" "$func_split_long_opt_arg" ${1+"$@"} shift ;; # Separate non-argument short options: -\?*|-h*|-n*|-v*) func_split_short_opt "$opt" set dummy "$func_split_short_opt_name" "-$func_split_short_opt_arg" ${1+"$@"} shift ;; --) break ;; -*) func_fatal_help "unrecognized option \`$opt'" ;; *) set dummy "$opt" ${1+"$@"}; shift; break ;; esac done # Validate options: # save first non-option argument if test "$#" -gt 0; then nonopt="$opt" shift fi # preserve --debug test "$opt_debug" = : || func_append preserve_args " --debug" case $host in *cygwin* | *mingw* | *pw32* | *cegcc*) # don't eliminate duplications in $postdeps and $predeps opt_duplicate_compiler_generated_deps=: ;; *) opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps ;; esac $opt_help || { # Sanity checks first: func_check_version_match if test "$build_libtool_libs" != yes && test "$build_old_libs" != yes; then func_fatal_configuration "not configured to build any kind of library" fi # Darwin sucks eval std_shrext=\"$shrext_cmds\" # Only execute mode is allowed to have -dlopen flags. if test -n "$opt_dlopen" && test "$opt_mode" != execute; then func_error "unrecognized option \`-dlopen'" $ECHO "$help" 1>&2 exit $EXIT_FAILURE fi # Change the help message to a mode-specific one. generic_help="$help" help="Try \`$progname --help --mode=$opt_mode' for more information." } # Bail if the options were screwed $exit_cmd $EXIT_FAILURE } ## ----------- ## ## Main. ## ## ----------- ## # func_lalib_p file # True iff FILE is a libtool `.la' library or `.lo' object file. # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_lalib_p () { test -f "$1" && $SED -e 4q "$1" 2>/dev/null \ | $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1 } # func_lalib_unsafe_p file # True iff FILE is a libtool `.la' library or `.lo' object file. # This function implements the same check as func_lalib_p without # resorting to external programs. To this end, it redirects stdin and # closes it afterwards, without saving the original file descriptor. # As a safety measure, use it only where a negative result would be # fatal anyway. Works if `file' does not exist. func_lalib_unsafe_p () { lalib_p=no if test -f "$1" && test -r "$1" && exec 5<&0 <"$1"; then for lalib_p_l in 1 2 3 4 do read lalib_p_line case "$lalib_p_line" in \#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;; esac done exec 0<&5 5<&- fi test "$lalib_p" = yes } # func_ltwrapper_script_p file # True iff FILE is a libtool wrapper script # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_script_p () { func_lalib_p "$1" } # func_ltwrapper_executable_p file # True iff FILE is a libtool wrapper executable # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_executable_p () { func_ltwrapper_exec_suffix= case $1 in *.exe) ;; *) func_ltwrapper_exec_suffix=.exe ;; esac $GREP "$magic_exe" "$1$func_ltwrapper_exec_suffix" >/dev/null 2>&1 } # func_ltwrapper_scriptname file # Assumes file is an ltwrapper_executable # uses $file to determine the appropriate filename for a # temporary ltwrapper_script. func_ltwrapper_scriptname () { func_dirname_and_basename "$1" "" "." func_stripname '' '.exe' "$func_basename_result" func_ltwrapper_scriptname_result="$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper" } # func_ltwrapper_p file # True iff FILE is a libtool wrapper script or wrapper executable # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_p () { func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1" } # func_execute_cmds commands fail_cmd # Execute tilde-delimited COMMANDS. # If FAIL_CMD is given, eval that upon failure. # FAIL_CMD may read-access the current command in variable CMD! func_execute_cmds () { $opt_debug save_ifs=$IFS; IFS='~' for cmd in $1; do IFS=$save_ifs eval cmd=\"$cmd\" func_show_eval "$cmd" "${2-:}" done IFS=$save_ifs } # func_source file # Source FILE, adding directory component if necessary. # Note that it is not necessary on cygwin/mingw to append a dot to # FILE even if both FILE and FILE.exe exist: automatic-append-.exe # behavior happens only for exec(3), not for open(2)! Also, sourcing # `FILE.' does not work on cygwin managed mounts. func_source () { $opt_debug case $1 in */* | *\\*) . "$1" ;; *) . "./$1" ;; esac } # func_resolve_sysroot PATH # Replace a leading = in PATH with a sysroot. Store the result into # func_resolve_sysroot_result func_resolve_sysroot () { func_resolve_sysroot_result=$1 case $func_resolve_sysroot_result in =*) func_stripname '=' '' "$func_resolve_sysroot_result" func_resolve_sysroot_result=$lt_sysroot$func_stripname_result ;; esac } # func_replace_sysroot PATH # If PATH begins with the sysroot, replace it with = and # store the result into func_replace_sysroot_result. func_replace_sysroot () { case "$lt_sysroot:$1" in ?*:"$lt_sysroot"*) func_stripname "$lt_sysroot" '' "$1" func_replace_sysroot_result="=$func_stripname_result" ;; *) # Including no sysroot. func_replace_sysroot_result=$1 ;; esac } # func_infer_tag arg # Infer tagged configuration to use if any are available and # if one wasn't chosen via the "--tag" command line option. # Only attempt this if the compiler in the base compile # command doesn't match the default compiler. # arg is usually of the form 'gcc ...' func_infer_tag () { $opt_debug if test -n "$available_tags" && test -z "$tagname"; then CC_quoted= for arg in $CC; do func_append_quoted CC_quoted "$arg" done CC_expanded=`func_echo_all $CC` CC_quoted_expanded=`func_echo_all $CC_quoted` case $@ in # Blanks in the command may have been stripped by the calling shell, # but not from the CC environment variable when configure was run. " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) ;; # Blanks at the start of $base_compile will cause this to fail # if we don't check for them as well. *) for z in $available_tags; do if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then # Evaluate the configuration. eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`" CC_quoted= for arg in $CC; do # Double-quote args containing other shell metacharacters. func_append_quoted CC_quoted "$arg" done CC_expanded=`func_echo_all $CC` CC_quoted_expanded=`func_echo_all $CC_quoted` case "$@ " in " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) # The compiler in the base compile command matches # the one in the tagged configuration. # Assume this is the tagged configuration we want. tagname=$z break ;; esac fi done # If $tagname still isn't set, then no tagged configuration # was found and let the user know that the "--tag" command # line option must be used. if test -z "$tagname"; then func_echo "unable to infer tagged configuration" func_fatal_error "specify a tag with \`--tag'" # else # func_verbose "using $tagname tagged configuration" fi ;; esac fi } # func_write_libtool_object output_name pic_name nonpic_name # Create a libtool object file (analogous to a ".la" file), # but don't create it if we're doing a dry run. func_write_libtool_object () { write_libobj=${1} if test "$build_libtool_libs" = yes; then write_lobj=\'${2}\' else write_lobj=none fi if test "$build_old_libs" = yes; then write_oldobj=\'${3}\' else write_oldobj=none fi $opt_dry_run || { cat >${write_libobj}T </dev/null` if test "$?" -eq 0 && test -n "${func_convert_core_file_wine_to_w32_tmp}"; then func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_wine_to_w32_tmp" | $SED -e "$lt_sed_naive_backslashify"` else func_convert_core_file_wine_to_w32_result= fi fi } # end: func_convert_core_file_wine_to_w32 # func_convert_core_path_wine_to_w32 ARG # Helper function used by path conversion functions when $build is *nix, and # $host is mingw, cygwin, or some other w32 environment. Relies on a correctly # configured wine environment available, with the winepath program in $build's # $PATH. Assumes ARG has no leading or trailing path separator characters. # # ARG is path to be converted from $build format to win32. # Result is available in $func_convert_core_path_wine_to_w32_result. # Unconvertible file (directory) names in ARG are skipped; if no directory names # are convertible, then the result may be empty. func_convert_core_path_wine_to_w32 () { $opt_debug # unfortunately, winepath doesn't convert paths, only file names func_convert_core_path_wine_to_w32_result="" if test -n "$1"; then oldIFS=$IFS IFS=: for func_convert_core_path_wine_to_w32_f in $1; do IFS=$oldIFS func_convert_core_file_wine_to_w32 "$func_convert_core_path_wine_to_w32_f" if test -n "$func_convert_core_file_wine_to_w32_result" ; then if test -z "$func_convert_core_path_wine_to_w32_result"; then func_convert_core_path_wine_to_w32_result="$func_convert_core_file_wine_to_w32_result" else func_append func_convert_core_path_wine_to_w32_result ";$func_convert_core_file_wine_to_w32_result" fi fi done IFS=$oldIFS fi } # end: func_convert_core_path_wine_to_w32 # func_cygpath ARGS... # Wrapper around calling the cygpath program via LT_CYGPATH. This is used when # when (1) $build is *nix and Cygwin is hosted via a wine environment; or (2) # $build is MSYS and $host is Cygwin, or (3) $build is Cygwin. In case (1) or # (2), returns the Cygwin file name or path in func_cygpath_result (input # file name or path is assumed to be in w32 format, as previously converted # from $build's *nix or MSYS format). In case (3), returns the w32 file name # or path in func_cygpath_result (input file name or path is assumed to be in # Cygwin format). Returns an empty string on error. # # ARGS are passed to cygpath, with the last one being the file name or path to # be converted. # # Specify the absolute *nix (or w32) name to cygpath in the LT_CYGPATH # environment variable; do not put it in $PATH. func_cygpath () { $opt_debug if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null` if test "$?" -ne 0; then # on failure, ensure result is empty func_cygpath_result= fi else func_cygpath_result= func_error "LT_CYGPATH is empty or specifies non-existent file: \`$LT_CYGPATH'" fi } #end: func_cygpath # func_convert_core_msys_to_w32 ARG # Convert file name or path ARG from MSYS format to w32 format. Return # result in func_convert_core_msys_to_w32_result. func_convert_core_msys_to_w32 () { $opt_debug # awkward: cmd appends spaces to result func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null | $SED -e 's/[ ]*$//' -e "$lt_sed_naive_backslashify"` } #end: func_convert_core_msys_to_w32 # func_convert_file_check ARG1 ARG2 # Verify that ARG1 (a file name in $build format) was converted to $host # format in ARG2. Otherwise, emit an error message, but continue (resetting # func_to_host_file_result to ARG1). func_convert_file_check () { $opt_debug if test -z "$2" && test -n "$1" ; then func_error "Could not determine host file name corresponding to" func_error " \`$1'" func_error "Continuing, but uninstalled executables may not work." # Fallback: func_to_host_file_result="$1" fi } # end func_convert_file_check # func_convert_path_check FROM_PATHSEP TO_PATHSEP FROM_PATH TO_PATH # Verify that FROM_PATH (a path in $build format) was converted to $host # format in TO_PATH. Otherwise, emit an error message, but continue, resetting # func_to_host_file_result to a simplistic fallback value (see below). func_convert_path_check () { $opt_debug if test -z "$4" && test -n "$3"; then func_error "Could not determine the host path corresponding to" func_error " \`$3'" func_error "Continuing, but uninstalled executables may not work." # Fallback. This is a deliberately simplistic "conversion" and # should not be "improved". See libtool.info. if test "x$1" != "x$2"; then lt_replace_pathsep_chars="s|$1|$2|g" func_to_host_path_result=`echo "$3" | $SED -e "$lt_replace_pathsep_chars"` else func_to_host_path_result="$3" fi fi } # end func_convert_path_check # func_convert_path_front_back_pathsep FRONTPAT BACKPAT REPL ORIG # Modifies func_to_host_path_result by prepending REPL if ORIG matches FRONTPAT # and appending REPL if ORIG matches BACKPAT. func_convert_path_front_back_pathsep () { $opt_debug case $4 in $1 ) func_to_host_path_result="$3$func_to_host_path_result" ;; esac case $4 in $2 ) func_append func_to_host_path_result "$3" ;; esac } # end func_convert_path_front_back_pathsep ################################################## # $build to $host FILE NAME CONVERSION FUNCTIONS # ################################################## # invoked via `$to_host_file_cmd ARG' # # In each case, ARG is the path to be converted from $build to $host format. # Result will be available in $func_to_host_file_result. # func_to_host_file ARG # Converts the file name ARG from $build format to $host format. Return result # in func_to_host_file_result. func_to_host_file () { $opt_debug $to_host_file_cmd "$1" } # end func_to_host_file # func_to_tool_file ARG LAZY # converts the file name ARG from $build format to toolchain format. Return # result in func_to_tool_file_result. If the conversion in use is listed # in (the comma separated) LAZY, no conversion takes place. func_to_tool_file () { $opt_debug case ,$2, in *,"$to_tool_file_cmd",*) func_to_tool_file_result=$1 ;; *) $to_tool_file_cmd "$1" func_to_tool_file_result=$func_to_host_file_result ;; esac } # end func_to_tool_file # func_convert_file_noop ARG # Copy ARG to func_to_host_file_result. func_convert_file_noop () { func_to_host_file_result="$1" } # end func_convert_file_noop # func_convert_file_msys_to_w32 ARG # Convert file name ARG from (mingw) MSYS to (mingw) w32 format; automatic # conversion to w32 is not available inside the cwrapper. Returns result in # func_to_host_file_result. func_convert_file_msys_to_w32 () { $opt_debug func_to_host_file_result="$1" if test -n "$1"; then func_convert_core_msys_to_w32 "$1" func_to_host_file_result="$func_convert_core_msys_to_w32_result" fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_msys_to_w32 # func_convert_file_cygwin_to_w32 ARG # Convert file name ARG from Cygwin to w32 format. Returns result in # func_to_host_file_result. func_convert_file_cygwin_to_w32 () { $opt_debug func_to_host_file_result="$1" if test -n "$1"; then # because $build is cygwin, we call "the" cygpath in $PATH; no need to use # LT_CYGPATH in this case. func_to_host_file_result=`cygpath -m "$1"` fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_cygwin_to_w32 # func_convert_file_nix_to_w32 ARG # Convert file name ARG from *nix to w32 format. Requires a wine environment # and a working winepath. Returns result in func_to_host_file_result. func_convert_file_nix_to_w32 () { $opt_debug func_to_host_file_result="$1" if test -n "$1"; then func_convert_core_file_wine_to_w32 "$1" func_to_host_file_result="$func_convert_core_file_wine_to_w32_result" fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_nix_to_w32 # func_convert_file_msys_to_cygwin ARG # Convert file name ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. # Returns result in func_to_host_file_result. func_convert_file_msys_to_cygwin () { $opt_debug func_to_host_file_result="$1" if test -n "$1"; then func_convert_core_msys_to_w32 "$1" func_cygpath -u "$func_convert_core_msys_to_w32_result" func_to_host_file_result="$func_cygpath_result" fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_msys_to_cygwin # func_convert_file_nix_to_cygwin ARG # Convert file name ARG from *nix to Cygwin format. Requires Cygwin installed # in a wine environment, working winepath, and LT_CYGPATH set. Returns result # in func_to_host_file_result. func_convert_file_nix_to_cygwin () { $opt_debug func_to_host_file_result="$1" if test -n "$1"; then # convert from *nix to w32, then use cygpath to convert from w32 to cygwin. func_convert_core_file_wine_to_w32 "$1" func_cygpath -u "$func_convert_core_file_wine_to_w32_result" func_to_host_file_result="$func_cygpath_result" fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_nix_to_cygwin ############################################# # $build to $host PATH CONVERSION FUNCTIONS # ############################################# # invoked via `$to_host_path_cmd ARG' # # In each case, ARG is the path to be converted from $build to $host format. # The result will be available in $func_to_host_path_result. # # Path separators are also converted from $build format to $host format. If # ARG begins or ends with a path separator character, it is preserved (but # converted to $host format) on output. # # All path conversion functions are named using the following convention: # file name conversion function : func_convert_file_X_to_Y () # path conversion function : func_convert_path_X_to_Y () # where, for any given $build/$host combination the 'X_to_Y' value is the # same. If conversion functions are added for new $build/$host combinations, # the two new functions must follow this pattern, or func_init_to_host_path_cmd # will break. # func_init_to_host_path_cmd # Ensures that function "pointer" variable $to_host_path_cmd is set to the # appropriate value, based on the value of $to_host_file_cmd. to_host_path_cmd= func_init_to_host_path_cmd () { $opt_debug if test -z "$to_host_path_cmd"; then func_stripname 'func_convert_file_' '' "$to_host_file_cmd" to_host_path_cmd="func_convert_path_${func_stripname_result}" fi } # func_to_host_path ARG # Converts the path ARG from $build format to $host format. Return result # in func_to_host_path_result. func_to_host_path () { $opt_debug func_init_to_host_path_cmd $to_host_path_cmd "$1" } # end func_to_host_path # func_convert_path_noop ARG # Copy ARG to func_to_host_path_result. func_convert_path_noop () { func_to_host_path_result="$1" } # end func_convert_path_noop # func_convert_path_msys_to_w32 ARG # Convert path ARG from (mingw) MSYS to (mingw) w32 format; automatic # conversion to w32 is not available inside the cwrapper. Returns result in # func_to_host_path_result. func_convert_path_msys_to_w32 () { $opt_debug func_to_host_path_result="$1" if test -n "$1"; then # Remove leading and trailing path separator characters from ARG. MSYS # behavior is inconsistent here; cygpath turns them into '.;' and ';.'; # and winepath ignores them completely. func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" func_to_host_path_result="$func_convert_core_msys_to_w32_result" func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_msys_to_w32 # func_convert_path_cygwin_to_w32 ARG # Convert path ARG from Cygwin to w32 format. Returns result in # func_to_host_file_result. func_convert_path_cygwin_to_w32 () { $opt_debug func_to_host_path_result="$1" if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_to_host_path_result=`cygpath -m -p "$func_to_host_path_tmp1"` func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_cygwin_to_w32 # func_convert_path_nix_to_w32 ARG # Convert path ARG from *nix to w32 format. Requires a wine environment and # a working winepath. Returns result in func_to_host_file_result. func_convert_path_nix_to_w32 () { $opt_debug func_to_host_path_result="$1" if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" func_to_host_path_result="$func_convert_core_path_wine_to_w32_result" func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_nix_to_w32 # func_convert_path_msys_to_cygwin ARG # Convert path ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. # Returns result in func_to_host_file_result. func_convert_path_msys_to_cygwin () { $opt_debug func_to_host_path_result="$1" if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" func_cygpath -u -p "$func_convert_core_msys_to_w32_result" func_to_host_path_result="$func_cygpath_result" func_convert_path_check : : \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" : "$1" fi } # end func_convert_path_msys_to_cygwin # func_convert_path_nix_to_cygwin ARG # Convert path ARG from *nix to Cygwin format. Requires Cygwin installed in a # a wine environment, working winepath, and LT_CYGPATH set. Returns result in # func_to_host_file_result. func_convert_path_nix_to_cygwin () { $opt_debug func_to_host_path_result="$1" if test -n "$1"; then # Remove leading and trailing path separator characters from # ARG. msys behavior is inconsistent here, cygpath turns them # into '.;' and ';.', and winepath ignores them completely. func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" func_cygpath -u -p "$func_convert_core_path_wine_to_w32_result" func_to_host_path_result="$func_cygpath_result" func_convert_path_check : : \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" : "$1" fi } # end func_convert_path_nix_to_cygwin # func_mode_compile arg... func_mode_compile () { $opt_debug # Get the compilation command and the source file. base_compile= srcfile="$nonopt" # always keep a non-empty value in "srcfile" suppress_opt=yes suppress_output= arg_mode=normal libobj= later= pie_flag= for arg do case $arg_mode in arg ) # do not "continue". Instead, add this to base_compile lastarg="$arg" arg_mode=normal ;; target ) libobj="$arg" arg_mode=normal continue ;; normal ) # Accept any command-line options. case $arg in -o) test -n "$libobj" && \ func_fatal_error "you cannot specify \`-o' more than once" arg_mode=target continue ;; -pie | -fpie | -fPIE) func_append pie_flag " $arg" continue ;; -shared | -static | -prefer-pic | -prefer-non-pic) func_append later " $arg" continue ;; -no-suppress) suppress_opt=no continue ;; -Xcompiler) arg_mode=arg # the next one goes into the "base_compile" arg list continue # The current "srcfile" will either be retained or ;; # replaced later. I would guess that would be a bug. -Wc,*) func_stripname '-Wc,' '' "$arg" args=$func_stripname_result lastarg= save_ifs="$IFS"; IFS=',' for arg in $args; do IFS="$save_ifs" func_append_quoted lastarg "$arg" done IFS="$save_ifs" func_stripname ' ' '' "$lastarg" lastarg=$func_stripname_result # Add the arguments to base_compile. func_append base_compile " $lastarg" continue ;; *) # Accept the current argument as the source file. # The previous "srcfile" becomes the current argument. # lastarg="$srcfile" srcfile="$arg" ;; esac # case $arg ;; esac # case $arg_mode # Aesthetically quote the previous argument. func_append_quoted base_compile "$lastarg" done # for arg case $arg_mode in arg) func_fatal_error "you must specify an argument for -Xcompile" ;; target) func_fatal_error "you must specify a target with \`-o'" ;; *) # Get the name of the library object. test -z "$libobj" && { func_basename "$srcfile" libobj="$func_basename_result" } ;; esac # Recognize several different file suffixes. # If the user specifies -o file.o, it is replaced with file.lo case $libobj in *.[cCFSifmso] | \ *.ada | *.adb | *.ads | *.asm | \ *.c++ | *.cc | *.ii | *.class | *.cpp | *.cxx | \ *.[fF][09]? | *.for | *.java | *.go | *.obj | *.sx | *.cu | *.cup) func_xform "$libobj" libobj=$func_xform_result ;; esac case $libobj in *.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;; *) func_fatal_error "cannot determine name of library object from \`$libobj'" ;; esac func_infer_tag $base_compile for arg in $later; do case $arg in -shared) test "$build_libtool_libs" != yes && \ func_fatal_configuration "can not build a shared library" build_old_libs=no continue ;; -static) build_libtool_libs=no build_old_libs=yes continue ;; -prefer-pic) pic_mode=yes continue ;; -prefer-non-pic) pic_mode=no continue ;; esac done func_quote_for_eval "$libobj" test "X$libobj" != "X$func_quote_for_eval_result" \ && $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"' &()|`$[]' \ && func_warning "libobj name \`$libobj' may not contain shell special characters." func_dirname_and_basename "$obj" "/" "" objname="$func_basename_result" xdir="$func_dirname_result" lobj=${xdir}$objdir/$objname test -z "$base_compile" && \ func_fatal_help "you must specify a compilation command" # Delete any leftover library objects. if test "$build_old_libs" = yes; then removelist="$obj $lobj $libobj ${libobj}T" else removelist="$lobj $libobj ${libobj}T" fi # On Cygwin there's no "real" PIC flag so we must build both object types case $host_os in cygwin* | mingw* | pw32* | os2* | cegcc*) pic_mode=default ;; esac if test "$pic_mode" = no && test "$deplibs_check_method" != pass_all; then # non-PIC code in shared libraries is not supported pic_mode=default fi # Calculate the filename of the output object if compiler does # not support -o with -c if test "$compiler_c_o" = no; then output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.${objext} lockfile="$output_obj.lock" else output_obj= need_locks=no lockfile= fi # Lock this critical section if it is needed # We use this script file to make the link, it avoids creating a new file if test "$need_locks" = yes; then until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do func_echo "Waiting for $lockfile to be removed" sleep 2 done elif test "$need_locks" = warn; then if test -f "$lockfile"; then $ECHO "\ *** ERROR, $lockfile exists and contains: `cat $lockfile 2>/dev/null` This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support \`-c' and \`-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi func_append removelist " $output_obj" $ECHO "$srcfile" > "$lockfile" fi $opt_dry_run || $RM $removelist func_append removelist " $lockfile" trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15 func_to_tool_file "$srcfile" func_convert_file_msys_to_w32 srcfile=$func_to_tool_file_result func_quote_for_eval "$srcfile" qsrcfile=$func_quote_for_eval_result # Only build a PIC object if we are building libtool libraries. if test "$build_libtool_libs" = yes; then # Without this assignment, base_compile gets emptied. fbsd_hideous_sh_bug=$base_compile if test "$pic_mode" != no; then command="$base_compile $qsrcfile $pic_flag" else # Don't build PIC code command="$base_compile $qsrcfile" fi func_mkdir_p "$xdir$objdir" if test -z "$output_obj"; then # Place PIC objects in $objdir func_append command " -o $lobj" fi func_show_eval_locale "$command" \ 'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE' if test "$need_locks" = warn && test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then $ECHO "\ *** ERROR, $lockfile contains: `cat $lockfile 2>/dev/null` but it should contain: $srcfile This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support \`-c' and \`-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi # Just move the object if needed, then go on to compile the next one if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then func_show_eval '$MV "$output_obj" "$lobj"' \ 'error=$?; $opt_dry_run || $RM $removelist; exit $error' fi # Allow error messages only from the first compilation. if test "$suppress_opt" = yes; then suppress_output=' >/dev/null 2>&1' fi fi # Only build a position-dependent object if we build old libraries. if test "$build_old_libs" = yes; then if test "$pic_mode" != yes; then # Don't build PIC code command="$base_compile $qsrcfile$pie_flag" else command="$base_compile $qsrcfile $pic_flag" fi if test "$compiler_c_o" = yes; then func_append command " -o $obj" fi # Suppress compiler output if we already did a PIC compilation. func_append command "$suppress_output" func_show_eval_locale "$command" \ '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' if test "$need_locks" = warn && test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then $ECHO "\ *** ERROR, $lockfile contains: `cat $lockfile 2>/dev/null` but it should contain: $srcfile This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support \`-c' and \`-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi # Just move the object if needed if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then func_show_eval '$MV "$output_obj" "$obj"' \ 'error=$?; $opt_dry_run || $RM $removelist; exit $error' fi fi $opt_dry_run || { func_write_libtool_object "$libobj" "$objdir/$objname" "$objname" # Unlock the critical section if it was locked if test "$need_locks" != no; then removelist=$lockfile $RM "$lockfile" fi } exit $EXIT_SUCCESS } $opt_help || { test "$opt_mode" = compile && func_mode_compile ${1+"$@"} } func_mode_help () { # We need to display help for each of the modes. case $opt_mode in "") # Generic help is extracted from the usage comments # at the start of this file. func_help ;; clean) $ECHO \ "Usage: $progname [OPTION]... --mode=clean RM [RM-OPTION]... FILE... Remove files from the build directory. RM is the name of the program to use to delete files associated with each FILE (typically \`/bin/rm'). RM-OPTIONS are options (such as \`-f') to be passed to RM. If FILE is a libtool library, object or program, all the files associated with it are deleted. Otherwise, only FILE itself is deleted using RM." ;; compile) $ECHO \ "Usage: $progname [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE Compile a source file into a libtool library object. This mode accepts the following additional options: -o OUTPUT-FILE set the output file name to OUTPUT-FILE -no-suppress do not suppress compiler output for multiple passes -prefer-pic try to build PIC objects only -prefer-non-pic try to build non-PIC objects only -shared do not build a \`.o' file suitable for static linking -static only build a \`.o' file suitable for static linking -Wc,FLAG pass FLAG directly to the compiler COMPILE-COMMAND is a command to be used in creating a \`standard' object file from the given SOURCEFILE. The output file name is determined by removing the directory component from SOURCEFILE, then substituting the C source code suffix \`.c' with the library object suffix, \`.lo'." ;; execute) $ECHO \ "Usage: $progname [OPTION]... --mode=execute COMMAND [ARGS]... Automatically set library path, then run a program. This mode accepts the following additional options: -dlopen FILE add the directory containing FILE to the library path This mode sets the library path environment variable according to \`-dlopen' flags. If any of the ARGS are libtool executable wrappers, then they are translated into their corresponding uninstalled binary, and any of their required library directories are added to the library path. Then, COMMAND is executed, with ARGS as arguments." ;; finish) $ECHO \ "Usage: $progname [OPTION]... --mode=finish [LIBDIR]... Complete the installation of libtool libraries. Each LIBDIR is a directory that contains libtool libraries. The commands that this mode executes may require superuser privileges. Use the \`--dry-run' option if you just want to see what would be executed." ;; install) $ECHO \ "Usage: $progname [OPTION]... --mode=install INSTALL-COMMAND... Install executables or libraries. INSTALL-COMMAND is the installation command. The first component should be either the \`install' or \`cp' program. The following components of INSTALL-COMMAND are treated specially: -inst-prefix-dir PREFIX-DIR Use PREFIX-DIR as a staging area for installation The rest of the components are interpreted as arguments to that command (only BSD-compatible install options are recognized)." ;; link) $ECHO \ "Usage: $progname [OPTION]... --mode=link LINK-COMMAND... Link object files or libraries together to form another library, or to create an executable program. LINK-COMMAND is a command using the C compiler that you would use to create a program from several object files. The following components of LINK-COMMAND are treated specially: -all-static do not do any dynamic linking at all -avoid-version do not add a version suffix if possible -bindir BINDIR specify path to binaries directory (for systems where libraries must be found in the PATH setting at runtime) -dlopen FILE \`-dlpreopen' FILE if it cannot be dlopened at runtime -dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3) -export-symbols SYMFILE try to export only the symbols listed in SYMFILE -export-symbols-regex REGEX try to export only the symbols matching REGEX -LLIBDIR search LIBDIR for required installed libraries -lNAME OUTPUT-FILE requires the installed library libNAME -module build a library that can dlopened -no-fast-install disable the fast-install mode -no-install link a not-installable executable -no-undefined declare that a library does not refer to external symbols -o OUTPUT-FILE create OUTPUT-FILE from the specified objects -objectlist FILE Use a list of object files found in FILE to specify objects -precious-files-regex REGEX don't remove output files matching REGEX -release RELEASE specify package release information -rpath LIBDIR the created library will eventually be installed in LIBDIR -R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries -shared only do dynamic linking of libtool libraries -shrext SUFFIX override the standard shared library file extension -static do not do any dynamic linking of uninstalled libtool libraries -static-libtool-libs do not do any dynamic linking of libtool libraries -version-info CURRENT[:REVISION[:AGE]] specify library version info [each variable defaults to 0] -weak LIBNAME declare that the target provides the LIBNAME interface -Wc,FLAG -Xcompiler FLAG pass linker-specific FLAG directly to the compiler -Wl,FLAG -Xlinker FLAG pass linker-specific FLAG directly to the linker -XCClinker FLAG pass link-specific FLAG to the compiler driver (CC) All other options (arguments beginning with \`-') are ignored. Every other argument is treated as a filename. Files ending in \`.la' are treated as uninstalled libtool libraries, other files are standard or library object files. If the OUTPUT-FILE ends in \`.la', then a libtool library is created, only library objects (\`.lo' files) may be specified, and \`-rpath' is required, except when creating a convenience library. If OUTPUT-FILE ends in \`.a' or \`.lib', then a standard library is created using \`ar' and \`ranlib', or on Windows using \`lib'. If OUTPUT-FILE ends in \`.lo' or \`.${objext}', then a reloadable object file is created, otherwise an executable program is created." ;; uninstall) $ECHO \ "Usage: $progname [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE... Remove libraries from an installation directory. RM is the name of the program to use to delete files associated with each FILE (typically \`/bin/rm'). RM-OPTIONS are options (such as \`-f') to be passed to RM. If FILE is a libtool library, all the files associated with it are deleted. Otherwise, only FILE itself is deleted using RM." ;; *) func_fatal_help "invalid operation mode \`$opt_mode'" ;; esac echo $ECHO "Try \`$progname --help' for more information about other modes." } # Now that we've collected a possible --mode arg, show help if necessary if $opt_help; then if test "$opt_help" = :; then func_mode_help else { func_help noexit for opt_mode in compile link execute install finish uninstall clean; do func_mode_help done } | sed -n '1p; 2,$s/^Usage:/ or: /p' { func_help noexit for opt_mode in compile link execute install finish uninstall clean; do echo func_mode_help done } | sed '1d /^When reporting/,/^Report/{ H d } $x /information about other modes/d /more detailed .*MODE/d s/^Usage:.*--mode=\([^ ]*\) .*/Description of \1 mode:/' fi exit $? fi # func_mode_execute arg... func_mode_execute () { $opt_debug # The first argument is the command name. cmd="$nonopt" test -z "$cmd" && \ func_fatal_help "you must specify a COMMAND" # Handle -dlopen flags immediately. for file in $opt_dlopen; do test -f "$file" \ || func_fatal_help "\`$file' is not a file" dir= case $file in *.la) func_resolve_sysroot "$file" file=$func_resolve_sysroot_result # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$file" \ || func_fatal_help "\`$lib' is not a valid libtool archive" # Read the libtool library. dlname= library_names= func_source "$file" # Skip this library if it cannot be dlopened. if test -z "$dlname"; then # Warn if it was a shared library. test -n "$library_names" && \ func_warning "\`$file' was not linked with \`-export-dynamic'" continue fi func_dirname "$file" "" "." dir="$func_dirname_result" if test -f "$dir/$objdir/$dlname"; then func_append dir "/$objdir" else if test ! -f "$dir/$dlname"; then func_fatal_error "cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'" fi fi ;; *.lo) # Just add the directory containing the .lo file. func_dirname "$file" "" "." dir="$func_dirname_result" ;; *) func_warning "\`-dlopen' is ignored for non-libtool libraries and objects" continue ;; esac # Get the absolute pathname. absdir=`cd "$dir" && pwd` test -n "$absdir" && dir="$absdir" # Now add the directory to shlibpath_var. if eval "test -z \"\$$shlibpath_var\""; then eval "$shlibpath_var=\"\$dir\"" else eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\"" fi done # This variable tells wrapper scripts just to set shlibpath_var # rather than running their programs. libtool_execute_magic="$magic" # Check if any of the arguments is a wrapper script. args= for file do case $file in -* | *.la | *.lo ) ;; *) # Do a test to see if this is really a libtool program. if func_ltwrapper_script_p "$file"; then func_source "$file" # Transform arg to wrapped name. file="$progdir/$program" elif func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" func_source "$func_ltwrapper_scriptname_result" # Transform arg to wrapped name. file="$progdir/$program" fi ;; esac # Quote arguments (to preserve shell metacharacters). func_append_quoted args "$file" done if test "X$opt_dry_run" = Xfalse; then if test -n "$shlibpath_var"; then # Export the shlibpath_var. eval "export $shlibpath_var" fi # Restore saved environment variables for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES do eval "if test \"\${save_$lt_var+set}\" = set; then $lt_var=\$save_$lt_var; export $lt_var else $lt_unset $lt_var fi" done # Now prepare to actually exec the command. exec_cmd="\$cmd$args" else # Display what would be done. if test -n "$shlibpath_var"; then eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\"" echo "export $shlibpath_var" fi $ECHO "$cmd$args" exit $EXIT_SUCCESS fi } test "$opt_mode" = execute && func_mode_execute ${1+"$@"} # func_mode_finish arg... func_mode_finish () { $opt_debug libs= libdirs= admincmds= for opt in "$nonopt" ${1+"$@"} do if test -d "$opt"; then func_append libdirs " $opt" elif test -f "$opt"; then if func_lalib_unsafe_p "$opt"; then func_append libs " $opt" else func_warning "\`$opt' is not a valid libtool archive" fi else func_fatal_error "invalid argument \`$opt'" fi done if test -n "$libs"; then if test -n "$lt_sysroot"; then sysroot_regex=`$ECHO "$lt_sysroot" | $SED "$sed_make_literal_regex"` sysroot_cmd="s/\([ ']\)$sysroot_regex/\1/g;" else sysroot_cmd= fi # Remove sysroot references if $opt_dry_run; then for lib in $libs; do echo "removing references to $lt_sysroot and \`=' prefixes from $lib" done else tmpdir=`func_mktempdir` for lib in $libs; do sed -e "${sysroot_cmd} s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \ > $tmpdir/tmp-la mv -f $tmpdir/tmp-la $lib done ${RM}r "$tmpdir" fi fi if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then for libdir in $libdirs; do if test -n "$finish_cmds"; then # Do each command in the finish commands. func_execute_cmds "$finish_cmds" 'admincmds="$admincmds '"$cmd"'"' fi if test -n "$finish_eval"; then # Do the single finish_eval. eval cmds=\"$finish_eval\" $opt_dry_run || eval "$cmds" || func_append admincmds " $cmds" fi done fi # Exit here if they wanted silent mode. $opt_silent && exit $EXIT_SUCCESS if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then echo "----------------------------------------------------------------------" echo "Libraries have been installed in:" for libdir in $libdirs; do $ECHO " $libdir" done echo echo "If you ever happen to want to link against installed libraries" echo "in a given directory, LIBDIR, you must either use libtool, and" echo "specify the full pathname of the library, or use the \`-LLIBDIR'" echo "flag during linking and do at least one of the following:" if test -n "$shlibpath_var"; then echo " - add LIBDIR to the \`$shlibpath_var' environment variable" echo " during execution" fi if test -n "$runpath_var"; then echo " - add LIBDIR to the \`$runpath_var' environment variable" echo " during linking" fi if test -n "$hardcode_libdir_flag_spec"; then libdir=LIBDIR eval flag=\"$hardcode_libdir_flag_spec\" $ECHO " - use the \`$flag' linker flag" fi if test -n "$admincmds"; then $ECHO " - have your system administrator run these commands:$admincmds" fi if test -f /etc/ld.so.conf; then echo " - have your system administrator add LIBDIR to \`/etc/ld.so.conf'" fi echo echo "See any operating system documentation about shared libraries for" case $host in solaris2.[6789]|solaris2.1[0-9]) echo "more information, such as the ld(1), crle(1) and ld.so(8) manual" echo "pages." ;; *) echo "more information, such as the ld(1) and ld.so(8) manual pages." ;; esac echo "----------------------------------------------------------------------" fi exit $EXIT_SUCCESS } test "$opt_mode" = finish && func_mode_finish ${1+"$@"} # func_mode_install arg... func_mode_install () { $opt_debug # There may be an optional sh(1) argument at the beginning of # install_prog (especially on Windows NT). if test "$nonopt" = "$SHELL" || test "$nonopt" = /bin/sh || # Allow the use of GNU shtool's install command. case $nonopt in *shtool*) :;; *) false;; esac; then # Aesthetically quote it. func_quote_for_eval "$nonopt" install_prog="$func_quote_for_eval_result " arg=$1 shift else install_prog= arg=$nonopt fi # The real first argument should be the name of the installation program. # Aesthetically quote it. func_quote_for_eval "$arg" func_append install_prog "$func_quote_for_eval_result" install_shared_prog=$install_prog case " $install_prog " in *[\\\ /]cp\ *) install_cp=: ;; *) install_cp=false ;; esac # We need to accept at least all the BSD install flags. dest= files= opts= prev= install_type= isdir=no stripme= no_mode=: for arg do arg2= if test -n "$dest"; then func_append files " $dest" dest=$arg continue fi case $arg in -d) isdir=yes ;; -f) if $install_cp; then :; else prev=$arg fi ;; -g | -m | -o) prev=$arg ;; -s) stripme=" -s" continue ;; -*) ;; *) # If the previous option needed an argument, then skip it. if test -n "$prev"; then if test "x$prev" = x-m && test -n "$install_override_mode"; then arg2=$install_override_mode no_mode=false fi prev= else dest=$arg continue fi ;; esac # Aesthetically quote the argument. func_quote_for_eval "$arg" func_append install_prog " $func_quote_for_eval_result" if test -n "$arg2"; then func_quote_for_eval "$arg2" fi func_append install_shared_prog " $func_quote_for_eval_result" done test -z "$install_prog" && \ func_fatal_help "you must specify an install program" test -n "$prev" && \ func_fatal_help "the \`$prev' option requires an argument" if test -n "$install_override_mode" && $no_mode; then if $install_cp; then :; else func_quote_for_eval "$install_override_mode" func_append install_shared_prog " -m $func_quote_for_eval_result" fi fi if test -z "$files"; then if test -z "$dest"; then func_fatal_help "no file or destination specified" else func_fatal_help "you must specify a destination" fi fi # Strip any trailing slash from the destination. func_stripname '' '/' "$dest" dest=$func_stripname_result # Check to see that the destination is a directory. test -d "$dest" && isdir=yes if test "$isdir" = yes; then destdir="$dest" destname= else func_dirname_and_basename "$dest" "" "." destdir="$func_dirname_result" destname="$func_basename_result" # Not a directory, so check to see that there is only one file specified. set dummy $files; shift test "$#" -gt 1 && \ func_fatal_help "\`$dest' is not a directory" fi case $destdir in [\\/]* | [A-Za-z]:[\\/]*) ;; *) for file in $files; do case $file in *.lo) ;; *) func_fatal_help "\`$destdir' must be an absolute directory name" ;; esac done ;; esac # This variable tells wrapper scripts just to set variables rather # than running their programs. libtool_install_magic="$magic" staticlibs= future_libdirs= current_libdirs= for file in $files; do # Do each installation. case $file in *.$libext) # Do the static libraries later. func_append staticlibs " $file" ;; *.la) func_resolve_sysroot "$file" file=$func_resolve_sysroot_result # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$file" \ || func_fatal_help "\`$file' is not a valid libtool archive" library_names= old_library= relink_command= func_source "$file" # Add the libdir to current_libdirs if it is the destination. if test "X$destdir" = "X$libdir"; then case "$current_libdirs " in *" $libdir "*) ;; *) func_append current_libdirs " $libdir" ;; esac else # Note the libdir as a future libdir. case "$future_libdirs " in *" $libdir "*) ;; *) func_append future_libdirs " $libdir" ;; esac fi func_dirname "$file" "/" "" dir="$func_dirname_result" func_append dir "$objdir" if test -n "$relink_command"; then # Determine the prefix the user has applied to our future dir. inst_prefix_dir=`$ECHO "$destdir" | $SED -e "s%$libdir\$%%"` # Don't allow the user to place us outside of our expected # location b/c this prevents finding dependent libraries that # are installed to the same prefix. # At present, this check doesn't affect windows .dll's that # are installed into $libdir/../bin (currently, that works fine) # but it's something to keep an eye on. test "$inst_prefix_dir" = "$destdir" && \ func_fatal_error "error: cannot install \`$file' to a directory not ending in $libdir" if test -n "$inst_prefix_dir"; then # Stick the inst_prefix_dir data into the link command. relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"` else relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%%"` fi func_warning "relinking \`$file'" func_show_eval "$relink_command" \ 'func_fatal_error "error: relink \`$file'\'' with the above command before installing it"' fi # See the names of the shared library. set dummy $library_names; shift if test -n "$1"; then realname="$1" shift srcname="$realname" test -n "$relink_command" && srcname="$realname"T # Install the shared library and build the symlinks. func_show_eval "$install_shared_prog $dir/$srcname $destdir/$realname" \ 'exit $?' tstripme="$stripme" case $host_os in cygwin* | mingw* | pw32* | cegcc*) case $realname in *.dll.a) tstripme="" ;; esac ;; esac if test -n "$tstripme" && test -n "$striplib"; then func_show_eval "$striplib $destdir/$realname" 'exit $?' fi if test "$#" -gt 0; then # Delete the old symlinks, and create new ones. # Try `ln -sf' first, because the `ln' binary might depend on # the symlink we replace! Solaris /bin/ln does not understand -f, # so we also need to try rm && ln -s. for linkname do test "$linkname" != "$realname" \ && func_show_eval "(cd $destdir && { $LN_S -f $realname $linkname || { $RM $linkname && $LN_S $realname $linkname; }; })" done fi # Do each command in the postinstall commands. lib="$destdir/$realname" func_execute_cmds "$postinstall_cmds" 'exit $?' fi # Install the pseudo-library for information purposes. func_basename "$file" name="$func_basename_result" instname="$dir/$name"i func_show_eval "$install_prog $instname $destdir/$name" 'exit $?' # Maybe install the static library, too. test -n "$old_library" && func_append staticlibs " $dir/$old_library" ;; *.lo) # Install (i.e. copy) a libtool object. # Figure out destination file name, if it wasn't already specified. if test -n "$destname"; then destfile="$destdir/$destname" else func_basename "$file" destfile="$func_basename_result" destfile="$destdir/$destfile" fi # Deduce the name of the destination old-style object file. case $destfile in *.lo) func_lo2o "$destfile" staticdest=$func_lo2o_result ;; *.$objext) staticdest="$destfile" destfile= ;; *) func_fatal_help "cannot copy a libtool object to \`$destfile'" ;; esac # Install the libtool object if requested. test -n "$destfile" && \ func_show_eval "$install_prog $file $destfile" 'exit $?' # Install the old object if enabled. if test "$build_old_libs" = yes; then # Deduce the name of the old-style object file. func_lo2o "$file" staticobj=$func_lo2o_result func_show_eval "$install_prog \$staticobj \$staticdest" 'exit $?' fi exit $EXIT_SUCCESS ;; *) # Figure out destination file name, if it wasn't already specified. if test -n "$destname"; then destfile="$destdir/$destname" else func_basename "$file" destfile="$func_basename_result" destfile="$destdir/$destfile" fi # If the file is missing, and there is a .exe on the end, strip it # because it is most likely a libtool script we actually want to # install stripped_ext="" case $file in *.exe) if test ! -f "$file"; then func_stripname '' '.exe' "$file" file=$func_stripname_result stripped_ext=".exe" fi ;; esac # Do a test to see if this is really a libtool program. case $host in *cygwin* | *mingw*) if func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" wrapper=$func_ltwrapper_scriptname_result else func_stripname '' '.exe' "$file" wrapper=$func_stripname_result fi ;; *) wrapper=$file ;; esac if func_ltwrapper_script_p "$wrapper"; then notinst_deplibs= relink_command= func_source "$wrapper" # Check the variables that should have been set. test -z "$generated_by_libtool_version" && \ func_fatal_error "invalid libtool wrapper script \`$wrapper'" finalize=yes for lib in $notinst_deplibs; do # Check to see that each library is installed. libdir= if test -f "$lib"; then func_source "$lib" fi libfile="$libdir/"`$ECHO "$lib" | $SED 's%^.*/%%g'` ### testsuite: skip nested quoting test if test -n "$libdir" && test ! -f "$libfile"; then func_warning "\`$lib' has not been installed in \`$libdir'" finalize=no fi done relink_command= func_source "$wrapper" outputname= if test "$fast_install" = no && test -n "$relink_command"; then $opt_dry_run || { if test "$finalize" = yes; then tmpdir=`func_mktempdir` func_basename "$file$stripped_ext" file="$func_basename_result" outputname="$tmpdir/$file" # Replace the output file specification. relink_command=`$ECHO "$relink_command" | $SED 's%@OUTPUT@%'"$outputname"'%g'` $opt_silent || { func_quote_for_expand "$relink_command" eval "func_echo $func_quote_for_expand_result" } if eval "$relink_command"; then : else func_error "error: relink \`$file' with the above command before installing it" $opt_dry_run || ${RM}r "$tmpdir" continue fi file="$outputname" else func_warning "cannot relink \`$file'" fi } else # Install the binary that we compiled earlier. file=`$ECHO "$file$stripped_ext" | $SED "s%\([^/]*\)$%$objdir/\1%"` fi fi # remove .exe since cygwin /usr/bin/install will append another # one anyway case $install_prog,$host in */usr/bin/install*,*cygwin*) case $file:$destfile in *.exe:*.exe) # this is ok ;; *.exe:*) destfile=$destfile.exe ;; *:*.exe) func_stripname '' '.exe' "$destfile" destfile=$func_stripname_result ;; esac ;; esac func_show_eval "$install_prog\$stripme \$file \$destfile" 'exit $?' $opt_dry_run || if test -n "$outputname"; then ${RM}r "$tmpdir" fi ;; esac done for file in $staticlibs; do func_basename "$file" name="$func_basename_result" # Set up the ranlib parameters. oldlib="$destdir/$name" func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 tool_oldlib=$func_to_tool_file_result func_show_eval "$install_prog \$file \$oldlib" 'exit $?' if test -n "$stripme" && test -n "$old_striplib"; then func_show_eval "$old_striplib $tool_oldlib" 'exit $?' fi # Do each command in the postinstall commands. func_execute_cmds "$old_postinstall_cmds" 'exit $?' done test -n "$future_libdirs" && \ func_warning "remember to run \`$progname --finish$future_libdirs'" if test -n "$current_libdirs"; then # Maybe just do a dry run. $opt_dry_run && current_libdirs=" -n$current_libdirs" exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs' else exit $EXIT_SUCCESS fi } test "$opt_mode" = install && func_mode_install ${1+"$@"} # func_generate_dlsyms outputname originator pic_p # Extract symbols from dlprefiles and create ${outputname}S.o with # a dlpreopen symbol table. func_generate_dlsyms () { $opt_debug my_outputname="$1" my_originator="$2" my_pic_p="${3-no}" my_prefix=`$ECHO "$my_originator" | sed 's%[^a-zA-Z0-9]%_%g'` my_dlsyms= if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then if test -n "$NM" && test -n "$global_symbol_pipe"; then my_dlsyms="${my_outputname}S.c" else func_error "not configured to extract global symbols from dlpreopened files" fi fi if test -n "$my_dlsyms"; then case $my_dlsyms in "") ;; *.c) # Discover the nlist of each of the dlfiles. nlist="$output_objdir/${my_outputname}.nm" func_show_eval "$RM $nlist ${nlist}S ${nlist}T" # Parse the name list into a source file. func_verbose "creating $output_objdir/$my_dlsyms" $opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\ /* $my_dlsyms - symbol resolution table for \`$my_outputname' dlsym emulation. */ /* Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION */ #ifdef __cplusplus extern \"C\" { #endif #if defined(__GNUC__) && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4)) #pragma GCC diagnostic ignored \"-Wstrict-prototypes\" #endif /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined(_WIN32) || defined(__CYGWIN__) || defined(_WIN32_WCE) /* DATA imports from DLLs on WIN32 con't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT_DLSYM_CONST #elif defined(__osf__) /* This system does not cope well with relocations in const data. */ # define LT_DLSYM_CONST #else # define LT_DLSYM_CONST const #endif /* External symbol declarations for the compiler. */\ " if test "$dlself" = yes; then func_verbose "generating symbol list for \`$output'" $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist" # Add our own program objects to the symbol list. progfiles=`$ECHO "$objs$old_deplibs" | $SP2NL | $SED "$lo2o" | $NL2SP` for progfile in $progfiles; do func_to_tool_file "$progfile" func_convert_file_msys_to_w32 func_verbose "extracting global C symbols from \`$func_to_tool_file_result'" $opt_dry_run || eval "$NM $func_to_tool_file_result | $global_symbol_pipe >> '$nlist'" done if test -n "$exclude_expsyms"; then $opt_dry_run || { eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' } fi if test -n "$export_symbols_regex"; then $opt_dry_run || { eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' } fi # Prepare the list of exported symbols if test -z "$export_symbols"; then export_symbols="$output_objdir/$outputname.exp" $opt_dry_run || { $RM $export_symbols eval "${SED} -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"' case $host in *cygwin* | *mingw* | *cegcc* ) eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"' ;; esac } else $opt_dry_run || { eval "${SED} -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"' eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' case $host in *cygwin* | *mingw* | *cegcc* ) eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' eval 'cat "$nlist" >> "$output_objdir/$outputname.def"' ;; esac } fi fi for dlprefile in $dlprefiles; do func_verbose "extracting global C symbols from \`$dlprefile'" func_basename "$dlprefile" name="$func_basename_result" case $host in *cygwin* | *mingw* | *cegcc* ) # if an import library, we need to obtain dlname if func_win32_import_lib_p "$dlprefile"; then func_tr_sh "$dlprefile" eval "curr_lafile=\$libfile_$func_tr_sh_result" dlprefile_dlbasename="" if test -n "$curr_lafile" && func_lalib_p "$curr_lafile"; then # Use subshell, to avoid clobbering current variable values dlprefile_dlname=`source "$curr_lafile" && echo "$dlname"` if test -n "$dlprefile_dlname" ; then func_basename "$dlprefile_dlname" dlprefile_dlbasename="$func_basename_result" else # no lafile. user explicitly requested -dlpreopen . $sharedlib_from_linklib_cmd "$dlprefile" dlprefile_dlbasename=$sharedlib_from_linklib_result fi fi $opt_dry_run || { if test -n "$dlprefile_dlbasename" ; then eval '$ECHO ": $dlprefile_dlbasename" >> "$nlist"' else func_warning "Could not compute DLL name from $name" eval '$ECHO ": $name " >> "$nlist"' fi func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe | $SED -e '/I __imp/d' -e 's/I __nm_/D /;s/_nm__//' >> '$nlist'" } else # not an import lib $opt_dry_run || { eval '$ECHO ": $name " >> "$nlist"' func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'" } fi ;; *) $opt_dry_run || { eval '$ECHO ": $name " >> "$nlist"' func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'" } ;; esac done $opt_dry_run || { # Make sure we have at least an empty file. test -f "$nlist" || : > "$nlist" if test -n "$exclude_expsyms"; then $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T $MV "$nlist"T "$nlist" fi # Try sorting and uniquifying the output. if $GREP -v "^: " < "$nlist" | if sort -k 3 /dev/null 2>&1; then sort -k 3 else sort +2 fi | uniq > "$nlist"S; then : else $GREP -v "^: " < "$nlist" > "$nlist"S fi if test -f "$nlist"S; then eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dlsyms"' else echo '/* NONE */' >> "$output_objdir/$my_dlsyms" fi echo >> "$output_objdir/$my_dlsyms" "\ /* The mapping between symbol names and symbols. */ typedef struct { const char *name; void *address; } lt_dlsymlist; extern LT_DLSYM_CONST lt_dlsymlist lt_${my_prefix}_LTX_preloaded_symbols[]; LT_DLSYM_CONST lt_dlsymlist lt_${my_prefix}_LTX_preloaded_symbols[] = {\ { \"$my_originator\", (void *) 0 }," case $need_lib_prefix in no) eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$my_dlsyms" ;; *) eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$output_objdir/$my_dlsyms" ;; esac echo >> "$output_objdir/$my_dlsyms" "\ {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt_${my_prefix}_LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif\ " } # !$opt_dry_run pic_flag_for_symtable= case "$compile_command " in *" -static "*) ;; *) case $host in # compiling the symbol table file with pic_flag works around # a FreeBSD bug that causes programs to crash when -lm is # linked before any other PIC object. But we must not use # pic_flag when linking with -static. The problem exists in # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1. *-*-freebsd2.*|*-*-freebsd3.0*|*-*-freebsdelf3.0*) pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND" ;; *-*-hpux*) pic_flag_for_symtable=" $pic_flag" ;; *) if test "X$my_pic_p" != Xno; then pic_flag_for_symtable=" $pic_flag" fi ;; esac ;; esac symtab_cflags= for arg in $LTCFLAGS; do case $arg in -pie | -fpie | -fPIE) ;; *) func_append symtab_cflags " $arg" ;; esac done # Now compile the dynamic symbol file. func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_flag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?' # Clean up the generated files. func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T"' # Transform the symbol file into the correct name. symfileobj="$output_objdir/${my_outputname}S.$objext" case $host in *cygwin* | *mingw* | *cegcc* ) if test -f "$output_objdir/$my_outputname.def"; then compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` else compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"` fi ;; *) compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"` ;; esac ;; *) func_fatal_error "unknown suffix for \`$my_dlsyms'" ;; esac else # We keep going just in case the user didn't refer to # lt_preloaded_symbols. The linker will fail if global_symbol_pipe # really was required. # Nullify the symbol file. compile_command=`$ECHO "$compile_command" | $SED "s% @SYMFILE@%%"` finalize_command=`$ECHO "$finalize_command" | $SED "s% @SYMFILE@%%"` fi } # func_win32_libid arg # return the library type of file 'arg' # # Need a lot of goo to handle *both* DLLs and import libs # Has to be a shell function in order to 'eat' the argument # that is supplied when $file_magic_command is called. # Despite the name, also deal with 64 bit binaries. func_win32_libid () { $opt_debug win32_libid_type="unknown" win32_fileres=`file -L $1 2>/dev/null` case $win32_fileres in *ar\ archive\ import\ library*) # definitely import win32_libid_type="x86 archive import" ;; *ar\ archive*) # could be an import, or static # Keep the egrep pattern in sync with the one in _LT_CHECK_MAGIC_METHOD. if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | $EGREP 'file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' >/dev/null; then func_to_tool_file "$1" func_convert_file_msys_to_w32 win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" | $SED -n -e ' 1,100{ / I /{ s,.*,import, p q } }'` case $win32_nmres in import*) win32_libid_type="x86 archive import";; *) win32_libid_type="x86 archive static";; esac fi ;; *DLL*) win32_libid_type="x86 DLL" ;; *executable*) # but shell scripts are "executable" too... case $win32_fileres in *MS\ Windows\ PE\ Intel*) win32_libid_type="x86 DLL" ;; esac ;; esac $ECHO "$win32_libid_type" } # func_cygming_dll_for_implib ARG # # Platform-specific function to extract the # name of the DLL associated with the specified # import library ARG. # Invoked by eval'ing the libtool variable # $sharedlib_from_linklib_cmd # Result is available in the variable # $sharedlib_from_linklib_result func_cygming_dll_for_implib () { $opt_debug sharedlib_from_linklib_result=`$DLLTOOL --identify-strict --identify "$1"` } # func_cygming_dll_for_implib_fallback_core SECTION_NAME LIBNAMEs # # The is the core of a fallback implementation of a # platform-specific function to extract the name of the # DLL associated with the specified import library LIBNAME. # # SECTION_NAME is either .idata$6 or .idata$7, depending # on the platform and compiler that created the implib. # # Echos the name of the DLL associated with the # specified import library. func_cygming_dll_for_implib_fallback_core () { $opt_debug match_literal=`$ECHO "$1" | $SED "$sed_make_literal_regex"` $OBJDUMP -s --section "$1" "$2" 2>/dev/null | $SED '/^Contents of section '"$match_literal"':/{ # Place marker at beginning of archive member dllname section s/.*/====MARK====/ p d } # These lines can sometimes be longer than 43 characters, but # are always uninteresting /:[ ]*file format pe[i]\{,1\}-/d /^In archive [^:]*:/d # Ensure marker is printed /^====MARK====/p # Remove all lines with less than 43 characters /^.\{43\}/!d # From remaining lines, remove first 43 characters s/^.\{43\}//' | $SED -n ' # Join marker and all lines until next marker into a single line /^====MARK====/ b para H $ b para b :para x s/\n//g # Remove the marker s/^====MARK====// # Remove trailing dots and whitespace s/[\. \t]*$// # Print /./p' | # we now have a list, one entry per line, of the stringified # contents of the appropriate section of all members of the # archive which possess that section. Heuristic: eliminate # all those which have a first or second character that is # a '.' (that is, objdump's representation of an unprintable # character.) This should work for all archives with less than # 0x302f exports -- but will fail for DLLs whose name actually # begins with a literal '.' or a single character followed by # a '.'. # # Of those that remain, print the first one. $SED -e '/^\./d;/^.\./d;q' } # func_cygming_gnu_implib_p ARG # This predicate returns with zero status (TRUE) if # ARG is a GNU/binutils-style import library. Returns # with nonzero status (FALSE) otherwise. func_cygming_gnu_implib_p () { $opt_debug func_to_tool_file "$1" func_convert_file_msys_to_w32 func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $EGREP ' (_head_[A-Za-z0-9_]+_[ad]l*|[A-Za-z0-9_]+_[ad]l*_iname)$'` test -n "$func_cygming_gnu_implib_tmp" } # func_cygming_ms_implib_p ARG # This predicate returns with zero status (TRUE) if # ARG is an MS-style import library. Returns # with nonzero status (FALSE) otherwise. func_cygming_ms_implib_p () { $opt_debug func_to_tool_file "$1" func_convert_file_msys_to_w32 func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'` test -n "$func_cygming_ms_implib_tmp" } # func_cygming_dll_for_implib_fallback ARG # Platform-specific function to extract the # name of the DLL associated with the specified # import library ARG. # # This fallback implementation is for use when $DLLTOOL # does not support the --identify-strict option. # Invoked by eval'ing the libtool variable # $sharedlib_from_linklib_cmd # Result is available in the variable # $sharedlib_from_linklib_result func_cygming_dll_for_implib_fallback () { $opt_debug if func_cygming_gnu_implib_p "$1" ; then # binutils import library sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$7' "$1"` elif func_cygming_ms_implib_p "$1" ; then # ms-generated import library sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$6' "$1"` else # unknown sharedlib_from_linklib_result="" fi } # func_extract_an_archive dir oldlib func_extract_an_archive () { $opt_debug f_ex_an_ar_dir="$1"; shift f_ex_an_ar_oldlib="$1" if test "$lock_old_archive_extraction" = yes; then lockfile=$f_ex_an_ar_oldlib.lock until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do func_echo "Waiting for $lockfile to be removed" sleep 2 done fi func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" \ 'stat=$?; rm -f "$lockfile"; exit $stat' if test "$lock_old_archive_extraction" = yes; then $opt_dry_run || rm -f "$lockfile" fi if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then : else func_fatal_error "object name conflicts in archive: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib" fi } # func_extract_archives gentop oldlib ... func_extract_archives () { $opt_debug my_gentop="$1"; shift my_oldlibs=${1+"$@"} my_oldobjs="" my_xlib="" my_xabs="" my_xdir="" for my_xlib in $my_oldlibs; do # Extract the objects. case $my_xlib in [\\/]* | [A-Za-z]:[\\/]*) my_xabs="$my_xlib" ;; *) my_xabs=`pwd`"/$my_xlib" ;; esac func_basename "$my_xlib" my_xlib="$func_basename_result" my_xlib_u=$my_xlib while :; do case " $extracted_archives " in *" $my_xlib_u "*) func_arith $extracted_serial + 1 extracted_serial=$func_arith_result my_xlib_u=lt$extracted_serial-$my_xlib ;; *) break ;; esac done extracted_archives="$extracted_archives $my_xlib_u" my_xdir="$my_gentop/$my_xlib_u" func_mkdir_p "$my_xdir" case $host in *-darwin*) func_verbose "Extracting $my_xabs" # Do not bother doing anything if just a dry run $opt_dry_run || { darwin_orig_dir=`pwd` cd $my_xdir || exit $? darwin_archive=$my_xabs darwin_curdir=`pwd` darwin_base_archive=`basename "$darwin_archive"` darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Architectures 2>/dev/null || true` if test -n "$darwin_arches"; then darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'` darwin_arch= func_verbose "$darwin_base_archive has multiple architectures $darwin_arches" for darwin_arch in $darwin_arches ; do func_mkdir_p "unfat-$$/${darwin_base_archive}-${darwin_arch}" $LIPO -thin $darwin_arch -output "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}" "${darwin_archive}" cd "unfat-$$/${darwin_base_archive}-${darwin_arch}" func_extract_an_archive "`pwd`" "${darwin_base_archive}" cd "$darwin_curdir" $RM "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}" done # $darwin_arches ## Okay now we've a bunch of thin objects, gotta fatten them up :) darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$basename" | sort -u` darwin_file= darwin_files= for darwin_file in $darwin_filelist; do darwin_files=`find unfat-$$ -name $darwin_file -print | sort | $NL2SP` $LIPO -create -output "$darwin_file" $darwin_files done # $darwin_filelist $RM -rf unfat-$$ cd "$darwin_orig_dir" else cd $darwin_orig_dir func_extract_an_archive "$my_xdir" "$my_xabs" fi # $darwin_arches } # !$opt_dry_run ;; *) func_extract_an_archive "$my_xdir" "$my_xabs" ;; esac my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | sort | $NL2SP` done func_extract_archives_result="$my_oldobjs" } # func_emit_wrapper [arg=no] # # Emit a libtool wrapper script on stdout. # Don't directly open a file because we may want to # incorporate the script contents within a cygwin/mingw # wrapper executable. Must ONLY be called from within # func_mode_link because it depends on a number of variables # set therein. # # ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR # variable will take. If 'yes', then the emitted script # will assume that the directory in which it is stored is # the $objdir directory. This is a cygwin/mingw-specific # behavior. func_emit_wrapper () { func_emit_wrapper_arg1=${1-no} $ECHO "\ #! $SHELL # $output - temporary wrapper script for $objdir/$outputname # Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION # # The $output program cannot be directly executed until all the libtool # libraries that it depends on are installed. # # This wrapper script should never be moved out of the build directory. # If it is, it will not operate correctly. # Sed substitution that helps us do robust quoting. It backslashifies # metacharacters that are still active within double-quoted strings. sed_quote_subst='$sed_quote_subst' # Be Bourne compatible if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then emulate sh NULLCMD=: # Zsh 3.x and 4.x performs word splitting on \${1+\"\$@\"}, which # is contrary to our usage. Disable this feature. alias -g '\${1+\"\$@\"}'='\"\$@\"' setopt NO_GLOB_SUBST else case \`(set -o) 2>/dev/null\` in *posix*) set -o posix;; esac fi BIN_SH=xpg4; export BIN_SH # for Tru64 DUALCASE=1; export DUALCASE # for MKS sh # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH relink_command=\"$relink_command\" # This environment variable determines our operation mode. if test \"\$libtool_install_magic\" = \"$magic\"; then # install mode needs the following variables: generated_by_libtool_version='$macro_version' notinst_deplibs='$notinst_deplibs' else # When we are sourced in execute mode, \$file and \$ECHO are already set. if test \"\$libtool_execute_magic\" != \"$magic\"; then file=\"\$0\"" qECHO=`$ECHO "$ECHO" | $SED "$sed_quote_subst"` $ECHO "\ # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$1 _LTECHO_EOF' } ECHO=\"$qECHO\" fi # Very basic option parsing. These options are (a) specific to # the libtool wrapper, (b) are identical between the wrapper # /script/ and the wrapper /executable/ which is used only on # windows platforms, and (c) all begin with the string "--lt-" # (application programs are unlikely to have options which match # this pattern). # # There are only two supported options: --lt-debug and # --lt-dump-script. There is, deliberately, no --lt-help. # # The first argument to this parsing function should be the # script's $0 value, followed by "$@". lt_option_debug= func_parse_lt_options () { lt_script_arg0=\$0 shift for lt_opt do case \"\$lt_opt\" in --lt-debug) lt_option_debug=1 ;; --lt-dump-script) lt_dump_D=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%/[^/]*$%%'\` test \"X\$lt_dump_D\" = \"X\$lt_script_arg0\" && lt_dump_D=. lt_dump_F=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%^.*/%%'\` cat \"\$lt_dump_D/\$lt_dump_F\" exit 0 ;; --lt-*) \$ECHO \"Unrecognized --lt- option: '\$lt_opt'\" 1>&2 exit 1 ;; esac done # Print the debug banner immediately: if test -n \"\$lt_option_debug\"; then echo \"${outputname}:${output}:\${LINENO}: libtool wrapper (GNU $PACKAGE$TIMESTAMP) $VERSION\" 1>&2 fi } # Used when --lt-debug. Prints its arguments to stdout # (redirection is the responsibility of the caller) func_lt_dump_args () { lt_dump_args_N=1; for lt_arg do \$ECHO \"${outputname}:${output}:\${LINENO}: newargv[\$lt_dump_args_N]: \$lt_arg\" lt_dump_args_N=\`expr \$lt_dump_args_N + 1\` done } # Core function for launching the target application func_exec_program_core () { " case $host in # Backslashes separate directories on plain windows *-*-mingw | *-*-os2* | *-cegcc*) $ECHO "\ if test -n \"\$lt_option_debug\"; then \$ECHO \"${outputname}:${output}:\${LINENO}: newargv[0]: \$progdir\\\\\$program\" 1>&2 func_lt_dump_args \${1+\"\$@\"} 1>&2 fi exec \"\$progdir\\\\\$program\" \${1+\"\$@\"} " ;; *) $ECHO "\ if test -n \"\$lt_option_debug\"; then \$ECHO \"${outputname}:${output}:\${LINENO}: newargv[0]: \$progdir/\$program\" 1>&2 func_lt_dump_args \${1+\"\$@\"} 1>&2 fi exec \"\$progdir/\$program\" \${1+\"\$@\"} " ;; esac $ECHO "\ \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2 exit 1 } # A function to encapsulate launching the target application # Strips options in the --lt-* namespace from \$@ and # launches target application with the remaining arguments. func_exec_program () { case \" \$* \" in *\\ --lt-*) for lt_wr_arg do case \$lt_wr_arg in --lt-*) ;; *) set x \"\$@\" \"\$lt_wr_arg\"; shift;; esac shift done ;; esac func_exec_program_core \${1+\"\$@\"} } # Parse options func_parse_lt_options \"\$0\" \${1+\"\$@\"} # Find the directory that this script lives in. thisdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*$%%'\` test \"x\$thisdir\" = \"x\$file\" && thisdir=. # Follow symbolic links until we get to the real thisdir. file=\`ls -ld \"\$file\" | $SED -n 's/.*-> //p'\` while test -n \"\$file\"; do destdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*\$%%'\` # If there was a directory component, then change thisdir. if test \"x\$destdir\" != \"x\$file\"; then case \"\$destdir\" in [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;; *) thisdir=\"\$thisdir/\$destdir\" ;; esac fi file=\`\$ECHO \"\$file\" | $SED 's%^.*/%%'\` file=\`ls -ld \"\$thisdir/\$file\" | $SED -n 's/.*-> //p'\` done # Usually 'no', except on cygwin/mingw when embedded into # the cwrapper. WRAPPER_SCRIPT_BELONGS_IN_OBJDIR=$func_emit_wrapper_arg1 if test \"\$WRAPPER_SCRIPT_BELONGS_IN_OBJDIR\" = \"yes\"; then # special case for '.' if test \"\$thisdir\" = \".\"; then thisdir=\`pwd\` fi # remove .libs from thisdir case \"\$thisdir\" in *[\\\\/]$objdir ) thisdir=\`\$ECHO \"\$thisdir\" | $SED 's%[\\\\/][^\\\\/]*$%%'\` ;; $objdir ) thisdir=. ;; esac fi # Try to get the absolute directory name. absdir=\`cd \"\$thisdir\" && pwd\` test -n \"\$absdir\" && thisdir=\"\$absdir\" " if test "$fast_install" = yes; then $ECHO "\ program=lt-'$outputname'$exeext progdir=\"\$thisdir/$objdir\" if test ! -f \"\$progdir/\$program\" || { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | ${SED} 1q\`; \\ test \"X\$file\" != \"X\$progdir/\$program\"; }; then file=\"\$\$-\$program\" if test ! -d \"\$progdir\"; then $MKDIR \"\$progdir\" else $RM \"\$progdir/\$file\" fi" $ECHO "\ # relink executable if necessary if test -n \"\$relink_command\"; then if relink_command_output=\`eval \$relink_command 2>&1\`; then : else $ECHO \"\$relink_command_output\" >&2 $RM \"\$progdir/\$file\" exit 1 fi fi $MV \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null || { $RM \"\$progdir/\$program\"; $MV \"\$progdir/\$file\" \"\$progdir/\$program\"; } $RM \"\$progdir/\$file\" fi" else $ECHO "\ program='$outputname' progdir=\"\$thisdir/$objdir\" " fi $ECHO "\ if test -f \"\$progdir/\$program\"; then" # fixup the dll searchpath if we need to. # # Fix the DLL searchpath if we need to. Do this before prepending # to shlibpath, because on Windows, both are PATH and uninstalled # libraries must come first. if test -n "$dllsearchpath"; then $ECHO "\ # Add the dll search path components to the executable PATH PATH=$dllsearchpath:\$PATH " fi # Export our shlibpath_var if we have one. if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then $ECHO "\ # Add our own library path to $shlibpath_var $shlibpath_var=\"$temp_rpath\$$shlibpath_var\" # Some systems cannot cope with colon-terminated $shlibpath_var # The second colon is a workaround for a bug in BeOS R4 sed $shlibpath_var=\`\$ECHO \"\$$shlibpath_var\" | $SED 's/::*\$//'\` export $shlibpath_var " fi $ECHO "\ if test \"\$libtool_execute_magic\" != \"$magic\"; then # Run the actual program with our arguments. func_exec_program \${1+\"\$@\"} fi else # The program doesn't exist. \$ECHO \"\$0: error: \\\`\$progdir/\$program' does not exist\" 1>&2 \$ECHO \"This script is just a wrapper for \$program.\" 1>&2 \$ECHO \"See the $PACKAGE documentation for more information.\" 1>&2 exit 1 fi fi\ " } # func_emit_cwrapperexe_src # emit the source code for a wrapper executable on stdout # Must ONLY be called from within func_mode_link because # it depends on a number of variable set therein. func_emit_cwrapperexe_src () { cat < #include #ifdef _MSC_VER # include # include # include #else # include # include # ifdef __CYGWIN__ # include # endif #endif #include #include #include #include #include #include #include #include /* declarations of non-ANSI functions */ #if defined(__MINGW32__) # ifdef __STRICT_ANSI__ int _putenv (const char *); # endif #elif defined(__CYGWIN__) # ifdef __STRICT_ANSI__ char *realpath (const char *, char *); int putenv (char *); int setenv (const char *, const char *, int); # endif /* #elif defined (other platforms) ... */ #endif /* portability defines, excluding path handling macros */ #if defined(_MSC_VER) # define setmode _setmode # define stat _stat # define chmod _chmod # define getcwd _getcwd # define putenv _putenv # define S_IXUSR _S_IEXEC # ifndef _INTPTR_T_DEFINED # define _INTPTR_T_DEFINED # define intptr_t int # endif #elif defined(__MINGW32__) # define setmode _setmode # define stat _stat # define chmod _chmod # define getcwd _getcwd # define putenv _putenv #elif defined(__CYGWIN__) # define HAVE_SETENV # define FOPEN_WB "wb" /* #elif defined (other platforms) ... */ #endif #if defined(PATH_MAX) # define LT_PATHMAX PATH_MAX #elif defined(MAXPATHLEN) # define LT_PATHMAX MAXPATHLEN #else # define LT_PATHMAX 1024 #endif #ifndef S_IXOTH # define S_IXOTH 0 #endif #ifndef S_IXGRP # define S_IXGRP 0 #endif /* path handling portability macros */ #ifndef DIR_SEPARATOR # define DIR_SEPARATOR '/' # define PATH_SEPARATOR ':' #endif #if defined (_WIN32) || defined (__MSDOS__) || defined (__DJGPP__) || \ defined (__OS2__) # define HAVE_DOS_BASED_FILE_SYSTEM # define FOPEN_WB "wb" # ifndef DIR_SEPARATOR_2 # define DIR_SEPARATOR_2 '\\' # endif # ifndef PATH_SEPARATOR_2 # define PATH_SEPARATOR_2 ';' # endif #endif #ifndef DIR_SEPARATOR_2 # define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR) #else /* DIR_SEPARATOR_2 */ # define IS_DIR_SEPARATOR(ch) \ (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2)) #endif /* DIR_SEPARATOR_2 */ #ifndef PATH_SEPARATOR_2 # define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR) #else /* PATH_SEPARATOR_2 */ # define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR_2) #endif /* PATH_SEPARATOR_2 */ #ifndef FOPEN_WB # define FOPEN_WB "w" #endif #ifndef _O_BINARY # define _O_BINARY 0 #endif #define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type))) #define XFREE(stale) do { \ if (stale) { free ((void *) stale); stale = 0; } \ } while (0) #if defined(LT_DEBUGWRAPPER) static int lt_debug = 1; #else static int lt_debug = 0; #endif const char *program_name = "libtool-wrapper"; /* in case xstrdup fails */ void *xmalloc (size_t num); char *xstrdup (const char *string); const char *base_name (const char *name); char *find_executable (const char *wrapper); char *chase_symlinks (const char *pathspec); int make_executable (const char *path); int check_executable (const char *path); char *strendzap (char *str, const char *pat); void lt_debugprintf (const char *file, int line, const char *fmt, ...); void lt_fatal (const char *file, int line, const char *message, ...); static const char *nonnull (const char *s); static const char *nonempty (const char *s); void lt_setenv (const char *name, const char *value); char *lt_extend_str (const char *orig_value, const char *add, int to_end); void lt_update_exe_path (const char *name, const char *value); void lt_update_lib_path (const char *name, const char *value); char **prepare_spawn (char **argv); void lt_dump_script (FILE *f); EOF cat <= 0) && (st.st_mode & (S_IXUSR | S_IXGRP | S_IXOTH))) return 1; else return 0; } int make_executable (const char *path) { int rval = 0; struct stat st; lt_debugprintf (__FILE__, __LINE__, "(make_executable): %s\n", nonempty (path)); if ((!path) || (!*path)) return 0; if (stat (path, &st) >= 0) { rval = chmod (path, st.st_mode | S_IXOTH | S_IXGRP | S_IXUSR); } return rval; } /* Searches for the full path of the wrapper. Returns newly allocated full path name if found, NULL otherwise Does not chase symlinks, even on platforms that support them. */ char * find_executable (const char *wrapper) { int has_slash = 0; const char *p; const char *p_next; /* static buffer for getcwd */ char tmp[LT_PATHMAX + 1]; int tmp_len; char *concat_name; lt_debugprintf (__FILE__, __LINE__, "(find_executable): %s\n", nonempty (wrapper)); if ((wrapper == NULL) || (*wrapper == '\0')) return NULL; /* Absolute path? */ #if defined (HAVE_DOS_BASED_FILE_SYSTEM) if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':') { concat_name = xstrdup (wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } else { #endif if (IS_DIR_SEPARATOR (wrapper[0])) { concat_name = xstrdup (wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } #if defined (HAVE_DOS_BASED_FILE_SYSTEM) } #endif for (p = wrapper; *p; p++) if (*p == '/') { has_slash = 1; break; } if (!has_slash) { /* no slashes; search PATH */ const char *path = getenv ("PATH"); if (path != NULL) { for (p = path; *p; p = p_next) { const char *q; size_t p_len; for (q = p; *q; q++) if (IS_PATH_SEPARATOR (*q)) break; p_len = q - p; p_next = (*q == '\0' ? q : q + 1); if (p_len == 0) { /* empty path: current directory */ if (getcwd (tmp, LT_PATHMAX) == NULL) lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", nonnull (strerror (errno))); tmp_len = strlen (tmp); concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, tmp, tmp_len); concat_name[tmp_len] = '/'; strcpy (concat_name + tmp_len + 1, wrapper); } else { concat_name = XMALLOC (char, p_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, p, p_len); concat_name[p_len] = '/'; strcpy (concat_name + p_len + 1, wrapper); } if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } } /* not found in PATH; assume curdir */ } /* Relative path | not found in path: prepend cwd */ if (getcwd (tmp, LT_PATHMAX) == NULL) lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", nonnull (strerror (errno))); tmp_len = strlen (tmp); concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, tmp, tmp_len); concat_name[tmp_len] = '/'; strcpy (concat_name + tmp_len + 1, wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); return NULL; } char * chase_symlinks (const char *pathspec) { #ifndef S_ISLNK return xstrdup (pathspec); #else char buf[LT_PATHMAX]; struct stat s; char *tmp_pathspec = xstrdup (pathspec); char *p; int has_symlinks = 0; while (strlen (tmp_pathspec) && !has_symlinks) { lt_debugprintf (__FILE__, __LINE__, "checking path component for symlinks: %s\n", tmp_pathspec); if (lstat (tmp_pathspec, &s) == 0) { if (S_ISLNK (s.st_mode) != 0) { has_symlinks = 1; break; } /* search backwards for last DIR_SEPARATOR */ p = tmp_pathspec + strlen (tmp_pathspec) - 1; while ((p > tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) p--; if ((p == tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) { /* no more DIR_SEPARATORS left */ break; } *p = '\0'; } else { lt_fatal (__FILE__, __LINE__, "error accessing file \"%s\": %s", tmp_pathspec, nonnull (strerror (errno))); } } XFREE (tmp_pathspec); if (!has_symlinks) { return xstrdup (pathspec); } tmp_pathspec = realpath (pathspec, buf); if (tmp_pathspec == 0) { lt_fatal (__FILE__, __LINE__, "could not follow symlinks for %s", pathspec); } return xstrdup (tmp_pathspec); #endif } char * strendzap (char *str, const char *pat) { size_t len, patlen; assert (str != NULL); assert (pat != NULL); len = strlen (str); patlen = strlen (pat); if (patlen <= len) { str += len - patlen; if (strcmp (str, pat) == 0) *str = '\0'; } return str; } void lt_debugprintf (const char *file, int line, const char *fmt, ...) { va_list args; if (lt_debug) { (void) fprintf (stderr, "%s:%s:%d: ", program_name, file, line); va_start (args, fmt); (void) vfprintf (stderr, fmt, args); va_end (args); } } static void lt_error_core (int exit_status, const char *file, int line, const char *mode, const char *message, va_list ap) { fprintf (stderr, "%s:%s:%d: %s: ", program_name, file, line, mode); vfprintf (stderr, message, ap); fprintf (stderr, ".\n"); if (exit_status >= 0) exit (exit_status); } void lt_fatal (const char *file, int line, const char *message, ...) { va_list ap; va_start (ap, message); lt_error_core (EXIT_FAILURE, file, line, "FATAL", message, ap); va_end (ap); } static const char * nonnull (const char *s) { return s ? s : "(null)"; } static const char * nonempty (const char *s) { return (s && !*s) ? "(empty)" : nonnull (s); } void lt_setenv (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_setenv) setting '%s' to '%s'\n", nonnull (name), nonnull (value)); { #ifdef HAVE_SETENV /* always make a copy, for consistency with !HAVE_SETENV */ char *str = xstrdup (value); setenv (name, str, 1); #else int len = strlen (name) + 1 + strlen (value) + 1; char *str = XMALLOC (char, len); sprintf (str, "%s=%s", name, value); if (putenv (str) != EXIT_SUCCESS) { XFREE (str); } #endif } } char * lt_extend_str (const char *orig_value, const char *add, int to_end) { char *new_value; if (orig_value && *orig_value) { int orig_value_len = strlen (orig_value); int add_len = strlen (add); new_value = XMALLOC (char, add_len + orig_value_len + 1); if (to_end) { strcpy (new_value, orig_value); strcpy (new_value + orig_value_len, add); } else { strcpy (new_value, add); strcpy (new_value + add_len, orig_value); } } else { new_value = xstrdup (add); } return new_value; } void lt_update_exe_path (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_update_exe_path) modifying '%s' by prepending '%s'\n", nonnull (name), nonnull (value)); if (name && *name && value && *value) { char *new_value = lt_extend_str (getenv (name), value, 0); /* some systems can't cope with a ':'-terminated path #' */ int len = strlen (new_value); while (((len = strlen (new_value)) > 0) && IS_PATH_SEPARATOR (new_value[len-1])) { new_value[len-1] = '\0'; } lt_setenv (name, new_value); XFREE (new_value); } } void lt_update_lib_path (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_update_lib_path) modifying '%s' by prepending '%s'\n", nonnull (name), nonnull (value)); if (name && *name && value && *value) { char *new_value = lt_extend_str (getenv (name), value, 0); lt_setenv (name, new_value); XFREE (new_value); } } EOF case $host_os in mingw*) cat <<"EOF" /* Prepares an argument vector before calling spawn(). Note that spawn() does not by itself call the command interpreter (getenv ("COMSPEC") != NULL ? getenv ("COMSPEC") : ({ OSVERSIONINFO v; v.dwOSVersionInfoSize = sizeof(OSVERSIONINFO); GetVersionEx(&v); v.dwPlatformId == VER_PLATFORM_WIN32_NT; }) ? "cmd.exe" : "command.com"). Instead it simply concatenates the arguments, separated by ' ', and calls CreateProcess(). We must quote the arguments since Win32 CreateProcess() interprets characters like ' ', '\t', '\\', '"' (but not '<' and '>') in a special way: - Space and tab are interpreted as delimiters. They are not treated as delimiters if they are surrounded by double quotes: "...". - Unescaped double quotes are removed from the input. Their only effect is that within double quotes, space and tab are treated like normal characters. - Backslashes not followed by double quotes are not special. - But 2*n+1 backslashes followed by a double quote become n backslashes followed by a double quote (n >= 0): \" -> " \\\" -> \" \\\\\" -> \\" */ #define SHELL_SPECIAL_CHARS "\"\\ \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037" #define SHELL_SPACE_CHARS " \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037" char ** prepare_spawn (char **argv) { size_t argc; char **new_argv; size_t i; /* Count number of arguments. */ for (argc = 0; argv[argc] != NULL; argc++) ; /* Allocate new argument vector. */ new_argv = XMALLOC (char *, argc + 1); /* Put quoted arguments into the new argument vector. */ for (i = 0; i < argc; i++) { const char *string = argv[i]; if (string[0] == '\0') new_argv[i] = xstrdup ("\"\""); else if (strpbrk (string, SHELL_SPECIAL_CHARS) != NULL) { int quote_around = (strpbrk (string, SHELL_SPACE_CHARS) != NULL); size_t length; unsigned int backslashes; const char *s; char *quoted_string; char *p; length = 0; backslashes = 0; if (quote_around) length++; for (s = string; *s != '\0'; s++) { char c = *s; if (c == '"') length += backslashes + 1; length++; if (c == '\\') backslashes++; else backslashes = 0; } if (quote_around) length += backslashes + 1; quoted_string = XMALLOC (char, length + 1); p = quoted_string; backslashes = 0; if (quote_around) *p++ = '"'; for (s = string; *s != '\0'; s++) { char c = *s; if (c == '"') { unsigned int j; for (j = backslashes + 1; j > 0; j--) *p++ = '\\'; } *p++ = c; if (c == '\\') backslashes++; else backslashes = 0; } if (quote_around) { unsigned int j; for (j = backslashes; j > 0; j--) *p++ = '\\'; *p++ = '"'; } *p = '\0'; new_argv[i] = quoted_string; } else new_argv[i] = (char *) string; } new_argv[argc] = NULL; return new_argv; } EOF ;; esac cat <<"EOF" void lt_dump_script (FILE* f) { EOF func_emit_wrapper yes | $SED -n -e ' s/^\(.\{79\}\)\(..*\)/\1\ \2/ h s/\([\\"]\)/\\\1/g s/$/\\n/ s/\([^\n]*\).*/ fputs ("\1", f);/p g D' cat <<"EOF" } EOF } # end: func_emit_cwrapperexe_src # func_win32_import_lib_p ARG # True if ARG is an import lib, as indicated by $file_magic_cmd func_win32_import_lib_p () { $opt_debug case `eval $file_magic_cmd \"\$1\" 2>/dev/null | $SED -e 10q` in *import*) : ;; *) false ;; esac } # func_mode_link arg... func_mode_link () { $opt_debug case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) # It is impossible to link a dll without this setting, and # we shouldn't force the makefile maintainer to figure out # which system we are compiling for in order to pass an extra # flag for every libtool invocation. # allow_undefined=no # FIXME: Unfortunately, there are problems with the above when trying # to make a dll which has undefined symbols, in which case not # even a static library is built. For now, we need to specify # -no-undefined on the libtool link line when we can be certain # that all symbols are satisfied, otherwise we get a static library. allow_undefined=yes ;; *) allow_undefined=yes ;; esac libtool_args=$nonopt base_compile="$nonopt $@" compile_command=$nonopt finalize_command=$nonopt compile_rpath= finalize_rpath= compile_shlibpath= finalize_shlibpath= convenience= old_convenience= deplibs= old_deplibs= compiler_flags= linker_flags= dllsearchpath= lib_search_path=`pwd` inst_prefix_dir= new_inherited_linker_flags= avoid_version=no bindir= dlfiles= dlprefiles= dlself=no export_dynamic=no export_symbols= export_symbols_regex= generated= libobjs= ltlibs= module=no no_install=no objs= non_pic_objects= precious_files_regex= prefer_static_libs=no preload=no prev= prevarg= release= rpath= xrpath= perm_rpath= temp_rpath= thread_safe=no vinfo= vinfo_number=no weak_libs= single_module="${wl}-single_module" func_infer_tag $base_compile # We need to know -static, to get the right output filenames. for arg do case $arg in -shared) test "$build_libtool_libs" != yes && \ func_fatal_configuration "can not build a shared library" build_old_libs=no break ;; -all-static | -static | -static-libtool-libs) case $arg in -all-static) if test "$build_libtool_libs" = yes && test -z "$link_static_flag"; then func_warning "complete static linking is impossible in this configuration" fi if test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=yes ;; -static) if test -z "$pic_flag" && test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=built ;; -static-libtool-libs) if test -z "$pic_flag" && test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=yes ;; esac build_libtool_libs=no build_old_libs=yes break ;; esac done # See if our shared archives depend on static archives. test -n "$old_archive_from_new_cmds" && build_old_libs=yes # Go through the arguments, transforming them on the way. while test "$#" -gt 0; do arg="$1" shift func_quote_for_eval "$arg" qarg=$func_quote_for_eval_unquoted_result func_append libtool_args " $func_quote_for_eval_result" # If the previous option needs an argument, assign it. if test -n "$prev"; then case $prev in output) func_append compile_command " @OUTPUT@" func_append finalize_command " @OUTPUT@" ;; esac case $prev in bindir) bindir="$arg" prev= continue ;; dlfiles|dlprefiles) if test "$preload" = no; then # Add the symbol object into the linking commands. func_append compile_command " @SYMFILE@" func_append finalize_command " @SYMFILE@" preload=yes fi case $arg in *.la | *.lo) ;; # We handle these cases below. force) if test "$dlself" = no; then dlself=needless export_dynamic=yes fi prev= continue ;; self) if test "$prev" = dlprefiles; then dlself=yes elif test "$prev" = dlfiles && test "$dlopen_self" != yes; then dlself=yes else dlself=needless export_dynamic=yes fi prev= continue ;; *) if test "$prev" = dlfiles; then func_append dlfiles " $arg" else func_append dlprefiles " $arg" fi prev= continue ;; esac ;; expsyms) export_symbols="$arg" test -f "$arg" \ || func_fatal_error "symbol file \`$arg' does not exist" prev= continue ;; expsyms_regex) export_symbols_regex="$arg" prev= continue ;; framework) case $host in *-*-darwin*) case "$deplibs " in *" $qarg.ltframework "*) ;; *) func_append deplibs " $qarg.ltframework" # this is fixed later ;; esac ;; esac prev= continue ;; inst_prefix) inst_prefix_dir="$arg" prev= continue ;; objectlist) if test -f "$arg"; then save_arg=$arg moreargs= for fil in `cat "$save_arg"` do # func_append moreargs " $fil" arg=$fil # A libtool-controlled object. # Check to see that this really is a libtool object. if func_lalib_unsafe_p "$arg"; then pic_object= non_pic_object= # Read the .lo file func_source "$arg" if test -z "$pic_object" || test -z "$non_pic_object" || test "$pic_object" = none && test "$non_pic_object" = none; then func_fatal_error "cannot find name of object for \`$arg'" fi # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir="$func_dirname_result" if test "$pic_object" != none; then # Prepend the subdirectory the object is found in. pic_object="$xdir$pic_object" if test "$prev" = dlfiles; then if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then func_append dlfiles " $pic_object" prev= continue else # If libtool objects are unsupported, then we need to preload. prev=dlprefiles fi fi # CHECK ME: I think I busted this. -Ossama if test "$prev" = dlprefiles; then # Preload the old-style object. func_append dlprefiles " $pic_object" prev= fi # A PIC object. func_append libobjs " $pic_object" arg="$pic_object" fi # Non-PIC object. if test "$non_pic_object" != none; then # Prepend the subdirectory the object is found in. non_pic_object="$xdir$non_pic_object" # A standard non-PIC object func_append non_pic_objects " $non_pic_object" if test -z "$pic_object" || test "$pic_object" = none ; then arg="$non_pic_object" fi else # If the PIC object exists, use it instead. # $xdir was prepended to $pic_object above. non_pic_object="$pic_object" func_append non_pic_objects " $non_pic_object" fi else # Only an error if not doing a dry-run. if $opt_dry_run; then # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir="$func_dirname_result" func_lo2o "$arg" pic_object=$xdir$objdir/$func_lo2o_result non_pic_object=$xdir$func_lo2o_result func_append libobjs " $pic_object" func_append non_pic_objects " $non_pic_object" else func_fatal_error "\`$arg' is not a valid libtool object" fi fi done else func_fatal_error "link input file \`$arg' does not exist" fi arg=$save_arg prev= continue ;; precious_regex) precious_files_regex="$arg" prev= continue ;; release) release="-$arg" prev= continue ;; rpath | xrpath) # We need an absolute path. case $arg in [\\/]* | [A-Za-z]:[\\/]*) ;; *) func_fatal_error "only absolute run-paths are allowed" ;; esac if test "$prev" = rpath; then case "$rpath " in *" $arg "*) ;; *) func_append rpath " $arg" ;; esac else case "$xrpath " in *" $arg "*) ;; *) func_append xrpath " $arg" ;; esac fi prev= continue ;; shrext) shrext_cmds="$arg" prev= continue ;; weak) func_append weak_libs " $arg" prev= continue ;; xcclinker) func_append linker_flags " $qarg" func_append compiler_flags " $qarg" prev= func_append compile_command " $qarg" func_append finalize_command " $qarg" continue ;; xcompiler) func_append compiler_flags " $qarg" prev= func_append compile_command " $qarg" func_append finalize_command " $qarg" continue ;; xlinker) func_append linker_flags " $qarg" func_append compiler_flags " $wl$qarg" prev= func_append compile_command " $wl$qarg" func_append finalize_command " $wl$qarg" continue ;; *) eval "$prev=\"\$arg\"" prev= continue ;; esac fi # test -n "$prev" prevarg="$arg" case $arg in -all-static) if test -n "$link_static_flag"; then # See comment for -static flag below, for more details. func_append compile_command " $link_static_flag" func_append finalize_command " $link_static_flag" fi continue ;; -allow-undefined) # FIXME: remove this flag sometime in the future. func_fatal_error "\`-allow-undefined' must not be used because it is the default" ;; -avoid-version) avoid_version=yes continue ;; -bindir) prev=bindir continue ;; -dlopen) prev=dlfiles continue ;; -dlpreopen) prev=dlprefiles continue ;; -export-dynamic) export_dynamic=yes continue ;; -export-symbols | -export-symbols-regex) if test -n "$export_symbols" || test -n "$export_symbols_regex"; then func_fatal_error "more than one -exported-symbols argument is not allowed" fi if test "X$arg" = "X-export-symbols"; then prev=expsyms else prev=expsyms_regex fi continue ;; -framework) prev=framework continue ;; -inst-prefix-dir) prev=inst_prefix continue ;; # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:* # so, if we see these flags be careful not to treat them like -L -L[A-Z][A-Z]*:*) case $with_gcc/$host in no/*-*-irix* | /*-*-irix*) func_append compile_command " $arg" func_append finalize_command " $arg" ;; esac continue ;; -L*) func_stripname "-L" '' "$arg" if test -z "$func_stripname_result"; then if test "$#" -gt 0; then func_fatal_error "require no space between \`-L' and \`$1'" else func_fatal_error "need path for \`-L' option" fi fi func_resolve_sysroot "$func_stripname_result" dir=$func_resolve_sysroot_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) ;; *) absdir=`cd "$dir" && pwd` test -z "$absdir" && \ func_fatal_error "cannot determine absolute directory name of \`$dir'" dir="$absdir" ;; esac case "$deplibs " in *" -L$dir "* | *" $arg "*) # Will only happen for absolute or sysroot arguments ;; *) # Preserve sysroot, but never include relative directories case $dir in [\\/]* | [A-Za-z]:[\\/]* | =*) func_append deplibs " $arg" ;; *) func_append deplibs " -L$dir" ;; esac func_append lib_search_path " $dir" ;; esac case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) testbindir=`$ECHO "$dir" | $SED 's*/lib$*/bin*'` case :$dllsearchpath: in *":$dir:"*) ;; ::) dllsearchpath=$dir;; *) func_append dllsearchpath ":$dir";; esac case :$dllsearchpath: in *":$testbindir:"*) ;; ::) dllsearchpath=$testbindir;; *) func_append dllsearchpath ":$testbindir";; esac ;; esac continue ;; -l*) if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc* | *-*-haiku*) # These systems don't actually have a C or math library (as such) continue ;; *-*-os2*) # These systems don't actually have a C library (as such) test "X$arg" = "X-lc" && continue ;; *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) # Do not include libc due to us having libc/libc_r. test "X$arg" = "X-lc" && continue ;; *-*-rhapsody* | *-*-darwin1.[012]) # Rhapsody C and math libraries are in the System framework func_append deplibs " System.ltframework" continue ;; *-*-sco3.2v5* | *-*-sco5v6*) # Causes problems with __ctype test "X$arg" = "X-lc" && continue ;; *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) # Compiler inserts libc in the correct place for threads to work test "X$arg" = "X-lc" && continue ;; esac elif test "X$arg" = "X-lc_r"; then case $host in *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) # Do not include libc_r directly, use -pthread flag. continue ;; esac fi func_append deplibs " $arg" continue ;; -module) module=yes continue ;; # Tru64 UNIX uses -model [arg] to determine the layout of C++ # classes, name mangling, and exception handling. # Darwin uses the -arch flag to determine output architecture. -model|-arch|-isysroot|--sysroot) func_append compiler_flags " $arg" func_append compile_command " $arg" func_append finalize_command " $arg" prev=xcompiler continue ;; -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \ |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) func_append compiler_flags " $arg" func_append compile_command " $arg" func_append finalize_command " $arg" case "$new_inherited_linker_flags " in *" $arg "*) ;; * ) func_append new_inherited_linker_flags " $arg" ;; esac continue ;; -multi_module) single_module="${wl}-multi_module" continue ;; -no-fast-install) fast_install=no continue ;; -no-install) case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*) # The PATH hackery in wrapper scripts is required on Windows # and Darwin in order for the loader to find any dlls it needs. func_warning "\`-no-install' is ignored for $host" func_warning "assuming \`-no-fast-install' instead" fast_install=no ;; *) no_install=yes ;; esac continue ;; -no-undefined) allow_undefined=no continue ;; -objectlist) prev=objectlist continue ;; -o) prev=output ;; -precious-files-regex) prev=precious_regex continue ;; -release) prev=release continue ;; -rpath) prev=rpath continue ;; -R) prev=xrpath continue ;; -R*) func_stripname '-R' '' "$arg" dir=$func_stripname_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) ;; =*) func_stripname '=' '' "$dir" dir=$lt_sysroot$func_stripname_result ;; *) func_fatal_error "only absolute run-paths are allowed" ;; esac case "$xrpath " in *" $dir "*) ;; *) func_append xrpath " $dir" ;; esac continue ;; -shared) # The effects of -shared are defined in a previous loop. continue ;; -shrext) prev=shrext continue ;; -static | -static-libtool-libs) # The effects of -static are defined in a previous loop. # We used to do the same as -all-static on platforms that # didn't have a PIC flag, but the assumption that the effects # would be equivalent was wrong. It would break on at least # Digital Unix and AIX. continue ;; -thread-safe) thread_safe=yes continue ;; -version-info) prev=vinfo continue ;; -version-number) prev=vinfo vinfo_number=yes continue ;; -weak) prev=weak continue ;; -Wc,*) func_stripname '-Wc,' '' "$arg" args=$func_stripname_result arg= save_ifs="$IFS"; IFS=',' for flag in $args; do IFS="$save_ifs" func_quote_for_eval "$flag" func_append arg " $func_quote_for_eval_result" func_append compiler_flags " $func_quote_for_eval_result" done IFS="$save_ifs" func_stripname ' ' '' "$arg" arg=$func_stripname_result ;; -Wl,*) func_stripname '-Wl,' '' "$arg" args=$func_stripname_result arg= save_ifs="$IFS"; IFS=',' for flag in $args; do IFS="$save_ifs" func_quote_for_eval "$flag" func_append arg " $wl$func_quote_for_eval_result" func_append compiler_flags " $wl$func_quote_for_eval_result" func_append linker_flags " $func_quote_for_eval_result" done IFS="$save_ifs" func_stripname ' ' '' "$arg" arg=$func_stripname_result ;; -Xcompiler) prev=xcompiler continue ;; -Xlinker) prev=xlinker continue ;; -XCClinker) prev=xcclinker continue ;; # -msg_* for osf cc -msg_*) func_quote_for_eval "$arg" arg="$func_quote_for_eval_result" ;; # Flags to be passed through unchanged, with rationale: # -64, -mips[0-9] enable 64-bit mode for the SGI compiler # -r[0-9][0-9]* specify processor for the SGI compiler # -xarch=*, -xtarget=* enable 64-bit mode for the Sun compiler # +DA*, +DD* enable 64-bit mode for the HP compiler # -q* compiler args for the IBM compiler # -m*, -t[45]*, -txscale* architecture-specific flags for GCC # -F/path path to uninstalled frameworks, gcc on darwin # -p, -pg, --coverage, -fprofile-* profiling flags for GCC # @file GCC response files # -tp=* Portland pgcc target processor selection # --sysroot=* for sysroot support # -O*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \ -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \ -O*|-flto*|-fwhopr*|-fuse-linker-plugin) func_quote_for_eval "$arg" arg="$func_quote_for_eval_result" func_append compile_command " $arg" func_append finalize_command " $arg" func_append compiler_flags " $arg" continue ;; # Some other compiler flag. -* | +*) func_quote_for_eval "$arg" arg="$func_quote_for_eval_result" ;; *.$objext) # A standard object. func_append objs " $arg" ;; *.lo) # A libtool-controlled object. # Check to see that this really is a libtool object. if func_lalib_unsafe_p "$arg"; then pic_object= non_pic_object= # Read the .lo file func_source "$arg" if test -z "$pic_object" || test -z "$non_pic_object" || test "$pic_object" = none && test "$non_pic_object" = none; then func_fatal_error "cannot find name of object for \`$arg'" fi # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir="$func_dirname_result" if test "$pic_object" != none; then # Prepend the subdirectory the object is found in. pic_object="$xdir$pic_object" if test "$prev" = dlfiles; then if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then func_append dlfiles " $pic_object" prev= continue else # If libtool objects are unsupported, then we need to preload. prev=dlprefiles fi fi # CHECK ME: I think I busted this. -Ossama if test "$prev" = dlprefiles; then # Preload the old-style object. func_append dlprefiles " $pic_object" prev= fi # A PIC object. func_append libobjs " $pic_object" arg="$pic_object" fi # Non-PIC object. if test "$non_pic_object" != none; then # Prepend the subdirectory the object is found in. non_pic_object="$xdir$non_pic_object" # A standard non-PIC object func_append non_pic_objects " $non_pic_object" if test -z "$pic_object" || test "$pic_object" = none ; then arg="$non_pic_object" fi else # If the PIC object exists, use it instead. # $xdir was prepended to $pic_object above. non_pic_object="$pic_object" func_append non_pic_objects " $non_pic_object" fi else # Only an error if not doing a dry-run. if $opt_dry_run; then # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir="$func_dirname_result" func_lo2o "$arg" pic_object=$xdir$objdir/$func_lo2o_result non_pic_object=$xdir$func_lo2o_result func_append libobjs " $pic_object" func_append non_pic_objects " $non_pic_object" else func_fatal_error "\`$arg' is not a valid libtool object" fi fi ;; *.$libext) # An archive. func_append deplibs " $arg" func_append old_deplibs " $arg" continue ;; *.la) # A libtool-controlled library. func_resolve_sysroot "$arg" if test "$prev" = dlfiles; then # This library was specified with -dlopen. func_append dlfiles " $func_resolve_sysroot_result" prev= elif test "$prev" = dlprefiles; then # The library was specified with -dlpreopen. func_append dlprefiles " $func_resolve_sysroot_result" prev= else func_append deplibs " $func_resolve_sysroot_result" fi continue ;; # Some other compiler argument. *) # Unknown arguments in both finalize_command and compile_command need # to be aesthetically quoted because they are evaled later. func_quote_for_eval "$arg" arg="$func_quote_for_eval_result" ;; esac # arg # Now actually substitute the argument into the commands. if test -n "$arg"; then func_append compile_command " $arg" func_append finalize_command " $arg" fi done # argument parsing loop test -n "$prev" && \ func_fatal_help "the \`$prevarg' option requires an argument" if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then eval arg=\"$export_dynamic_flag_spec\" func_append compile_command " $arg" func_append finalize_command " $arg" fi oldlibs= # calculate the name of the file, without its directory func_basename "$output" outputname="$func_basename_result" libobjs_save="$libobjs" if test -n "$shlibpath_var"; then # get the directories listed in $shlibpath_var eval shlib_search_path=\`\$ECHO \"\${$shlibpath_var}\" \| \$SED \'s/:/ /g\'\` else shlib_search_path= fi eval sys_lib_search_path=\"$sys_lib_search_path_spec\" eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\" func_dirname "$output" "/" "" output_objdir="$func_dirname_result$objdir" func_to_tool_file "$output_objdir/" tool_output_objdir=$func_to_tool_file_result # Create the object directory. func_mkdir_p "$output_objdir" # Determine the type of output case $output in "") func_fatal_help "you must specify an output file" ;; *.$libext) linkmode=oldlib ;; *.lo | *.$objext) linkmode=obj ;; *.la) linkmode=lib ;; *) linkmode=prog ;; # Anything else should be a program. esac specialdeplibs= libs= # Find all interdependent deplibs by searching for libraries # that are linked more than once (e.g. -la -lb -la) for deplib in $deplibs; do if $opt_preserve_dup_deps ; then case "$libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append libs " $deplib" done if test "$linkmode" = lib; then libs="$predeps $libs $compiler_lib_search_path $postdeps" # Compute libraries that are listed more than once in $predeps # $postdeps and mark them as special (i.e., whose duplicates are # not to be eliminated). pre_post_deps= if $opt_duplicate_compiler_generated_deps; then for pre_post_dep in $predeps $postdeps; do case "$pre_post_deps " in *" $pre_post_dep "*) func_append specialdeplibs " $pre_post_deps" ;; esac func_append pre_post_deps " $pre_post_dep" done fi pre_post_deps= fi deplibs= newdependency_libs= newlib_search_path= need_relink=no # whether we're linking any uninstalled libtool libraries notinst_deplibs= # not-installed libtool libraries notinst_path= # paths that contain not-installed libtool libraries case $linkmode in lib) passes="conv dlpreopen link" for file in $dlfiles $dlprefiles; do case $file in *.la) ;; *) func_fatal_help "libraries can \`-dlopen' only libtool libraries: $file" ;; esac done ;; prog) compile_deplibs= finalize_deplibs= alldeplibs=no newdlfiles= newdlprefiles= passes="conv scan dlopen dlpreopen link" ;; *) passes="conv" ;; esac for pass in $passes; do # The preopen pass in lib mode reverses $deplibs; put it back here # so that -L comes before libs that need it for instance... if test "$linkmode,$pass" = "lib,link"; then ## FIXME: Find the place where the list is rebuilt in the wrong ## order, and fix it there properly tmp_deplibs= for deplib in $deplibs; do tmp_deplibs="$deplib $tmp_deplibs" done deplibs="$tmp_deplibs" fi if test "$linkmode,$pass" = "lib,link" || test "$linkmode,$pass" = "prog,scan"; then libs="$deplibs" deplibs= fi if test "$linkmode" = prog; then case $pass in dlopen) libs="$dlfiles" ;; dlpreopen) libs="$dlprefiles" ;; link) libs="$deplibs %DEPLIBS%" test "X$link_all_deplibs" != Xno && libs="$libs $dependency_libs" ;; esac fi if test "$linkmode,$pass" = "lib,dlpreopen"; then # Collect and forward deplibs of preopened libtool libs for lib in $dlprefiles; do # Ignore non-libtool-libs dependency_libs= func_resolve_sysroot "$lib" case $lib in *.la) func_source "$func_resolve_sysroot_result" ;; esac # Collect preopened libtool deplibs, except any this library # has declared as weak libs for deplib in $dependency_libs; do func_basename "$deplib" deplib_base=$func_basename_result case " $weak_libs " in *" $deplib_base "*) ;; *) func_append deplibs " $deplib" ;; esac done done libs="$dlprefiles" fi if test "$pass" = dlopen; then # Collect dlpreopened libraries save_deplibs="$deplibs" deplibs= fi for deplib in $libs; do lib= found=no case $deplib in -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \ |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) if test "$linkmode,$pass" = "prog,link"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else func_append compiler_flags " $deplib" if test "$linkmode" = lib ; then case "$new_inherited_linker_flags " in *" $deplib "*) ;; * ) func_append new_inherited_linker_flags " $deplib" ;; esac fi fi continue ;; -l*) if test "$linkmode" != lib && test "$linkmode" != prog; then func_warning "\`-l' is ignored for archives/objects" continue fi func_stripname '-l' '' "$deplib" name=$func_stripname_result if test "$linkmode" = lib; then searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path" else searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path" fi for searchdir in $searchdirs; do for search_ext in .la $std_shrext .so .a; do # Search the libtool library lib="$searchdir/lib${name}${search_ext}" if test -f "$lib"; then if test "$search_ext" = ".la"; then found=yes else found=no fi break 2 fi done done if test "$found" != yes; then # deplib doesn't seem to be a libtool library if test "$linkmode,$pass" = "prog,link"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs" fi continue else # deplib is a libtool library # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib, # We need to do some special things here, and not later. if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then case " $predeps $postdeps " in *" $deplib "*) if func_lalib_p "$lib"; then library_names= old_library= func_source "$lib" for l in $old_library $library_names; do ll="$l" done if test "X$ll" = "X$old_library" ; then # only static version available found=no func_dirname "$lib" "" "." ladir="$func_dirname_result" lib=$ladir/$old_library if test "$linkmode,$pass" = "prog,link"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs" fi continue fi fi ;; *) ;; esac fi fi ;; # -l *.ltframework) if test "$linkmode,$pass" = "prog,link"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" if test "$linkmode" = lib ; then case "$new_inherited_linker_flags " in *" $deplib "*) ;; * ) func_append new_inherited_linker_flags " $deplib" ;; esac fi fi continue ;; -L*) case $linkmode in lib) deplibs="$deplib $deplibs" test "$pass" = conv && continue newdependency_libs="$deplib $newdependency_libs" func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; prog) if test "$pass" = conv; then deplibs="$deplib $deplibs" continue fi if test "$pass" = scan; then deplibs="$deplib $deplibs" else compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" fi func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; *) func_warning "\`-L' is ignored for archives/objects" ;; esac # linkmode continue ;; # -L -R*) if test "$pass" = link; then func_stripname '-R' '' "$deplib" func_resolve_sysroot "$func_stripname_result" dir=$func_resolve_sysroot_result # Make sure the xrpath contains only unique directories. case "$xrpath " in *" $dir "*) ;; *) func_append xrpath " $dir" ;; esac fi deplibs="$deplib $deplibs" continue ;; *.la) func_resolve_sysroot "$deplib" lib=$func_resolve_sysroot_result ;; *.$libext) if test "$pass" = conv; then deplibs="$deplib $deplibs" continue fi case $linkmode in lib) # Linking convenience modules into shared libraries is allowed, # but linking other static libraries is non-portable. case " $dlpreconveniencelibs " in *" $deplib "*) ;; *) valid_a_lib=no case $deplibs_check_method in match_pattern*) set dummy $deplibs_check_method; shift match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` if eval "\$ECHO \"$deplib\"" 2>/dev/null | $SED 10q \ | $EGREP "$match_pattern_regex" > /dev/null; then valid_a_lib=yes fi ;; pass_all) valid_a_lib=yes ;; esac if test "$valid_a_lib" != yes; then echo $ECHO "*** Warning: Trying to link with static lib archive $deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because the file extensions .$libext of this argument makes me believe" echo "*** that it is just a static archive that I should not use here." else echo $ECHO "*** Warning: Linking the shared library $output against the" $ECHO "*** static library $deplib is not portable!" deplibs="$deplib $deplibs" fi ;; esac continue ;; prog) if test "$pass" != link; then deplibs="$deplib $deplibs" else compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" fi continue ;; esac # linkmode ;; # *.$libext *.lo | *.$objext) if test "$pass" = conv; then deplibs="$deplib $deplibs" elif test "$linkmode" = prog; then if test "$pass" = dlpreopen || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then # If there is no dlopen support or we're linking statically, # we need to preload. func_append newdlprefiles " $deplib" compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else func_append newdlfiles " $deplib" fi fi continue ;; %DEPLIBS%) alldeplibs=yes continue ;; esac # case $deplib if test "$found" = yes || test -f "$lib"; then : else func_fatal_error "cannot find the library \`$lib' or unhandled argument \`$deplib'" fi # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$lib" \ || func_fatal_error "\`$lib' is not a valid libtool archive" func_dirname "$lib" "" "." ladir="$func_dirname_result" dlname= dlopen= dlpreopen= libdir= library_names= old_library= inherited_linker_flags= # If the library was installed with an old release of libtool, # it will not redefine variables installed, or shouldnotlink installed=yes shouldnotlink=no avoidtemprpath= # Read the .la file func_source "$lib" # Convert "-framework foo" to "foo.ltframework" if test -n "$inherited_linker_flags"; then tmp_inherited_linker_flags=`$ECHO "$inherited_linker_flags" | $SED 's/-framework \([^ $]*\)/\1.ltframework/g'` for tmp_inherited_linker_flag in $tmp_inherited_linker_flags; do case " $new_inherited_linker_flags " in *" $tmp_inherited_linker_flag "*) ;; *) func_append new_inherited_linker_flags " $tmp_inherited_linker_flag";; esac done fi dependency_libs=`$ECHO " $dependency_libs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` if test "$linkmode,$pass" = "lib,link" || test "$linkmode,$pass" = "prog,scan" || { test "$linkmode" != prog && test "$linkmode" != lib; }; then test -n "$dlopen" && func_append dlfiles " $dlopen" test -n "$dlpreopen" && func_append dlprefiles " $dlpreopen" fi if test "$pass" = conv; then # Only check for convenience libraries deplibs="$lib $deplibs" if test -z "$libdir"; then if test -z "$old_library"; then func_fatal_error "cannot find name of link library for \`$lib'" fi # It is a libtool convenience library, so add in its objects. func_append convenience " $ladir/$objdir/$old_library" func_append old_convenience " $ladir/$objdir/$old_library" tmp_libs= for deplib in $dependency_libs; do deplibs="$deplib $deplibs" if $opt_preserve_dup_deps ; then case "$tmp_libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append tmp_libs " $deplib" done elif test "$linkmode" != prog && test "$linkmode" != lib; then func_fatal_error "\`$lib' is not a convenience library" fi continue fi # $pass = conv # Get the name of the library we link against. linklib= if test -n "$old_library" && { test "$prefer_static_libs" = yes || test "$prefer_static_libs,$installed" = "built,no"; }; then linklib=$old_library else for l in $old_library $library_names; do linklib="$l" done fi if test -z "$linklib"; then func_fatal_error "cannot find name of link library for \`$lib'" fi # This library was specified with -dlopen. if test "$pass" = dlopen; then if test -z "$libdir"; then func_fatal_error "cannot -dlopen a convenience library: \`$lib'" fi if test -z "$dlname" || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then # If there is no dlname, no dlopen support or we're linking # statically, we need to preload. We also need to preload any # dependent libraries so libltdl's deplib preloader doesn't # bomb out in the load deplibs phase. func_append dlprefiles " $lib $dependency_libs" else func_append newdlfiles " $lib" fi continue fi # $pass = dlopen # We need an absolute path. case $ladir in [\\/]* | [A-Za-z]:[\\/]*) abs_ladir="$ladir" ;; *) abs_ladir=`cd "$ladir" && pwd` if test -z "$abs_ladir"; then func_warning "cannot determine absolute directory name of \`$ladir'" func_warning "passing it literally to the linker, although it might fail" abs_ladir="$ladir" fi ;; esac func_basename "$lib" laname="$func_basename_result" # Find the relevant object directory and library name. if test "X$installed" = Xyes; then if test ! -f "$lt_sysroot$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then func_warning "library \`$lib' was moved." dir="$ladir" absdir="$abs_ladir" libdir="$abs_ladir" else dir="$lt_sysroot$libdir" absdir="$lt_sysroot$libdir" fi test "X$hardcode_automatic" = Xyes && avoidtemprpath=yes else if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then dir="$ladir" absdir="$abs_ladir" # Remove this search path later func_append notinst_path " $abs_ladir" else dir="$ladir/$objdir" absdir="$abs_ladir/$objdir" # Remove this search path later func_append notinst_path " $abs_ladir" fi fi # $installed = yes func_stripname 'lib' '.la' "$laname" name=$func_stripname_result # This library was specified with -dlpreopen. if test "$pass" = dlpreopen; then if test -z "$libdir" && test "$linkmode" = prog; then func_fatal_error "only libraries may -dlpreopen a convenience library: \`$lib'" fi case "$host" in # special handling for platforms with PE-DLLs. *cygwin* | *mingw* | *cegcc* ) # Linker will automatically link against shared library if both # static and shared are present. Therefore, ensure we extract # symbols from the import library if a shared library is present # (otherwise, the dlopen module name will be incorrect). We do # this by putting the import library name into $newdlprefiles. # We recover the dlopen module name by 'saving' the la file # name in a special purpose variable, and (later) extracting the # dlname from the la file. if test -n "$dlname"; then func_tr_sh "$dir/$linklib" eval "libfile_$func_tr_sh_result=\$abs_ladir/\$laname" func_append newdlprefiles " $dir/$linklib" else func_append newdlprefiles " $dir/$old_library" # Keep a list of preopened convenience libraries to check # that they are being used correctly in the link pass. test -z "$libdir" && \ func_append dlpreconveniencelibs " $dir/$old_library" fi ;; * ) # Prefer using a static library (so that no silly _DYNAMIC symbols # are required to link). if test -n "$old_library"; then func_append newdlprefiles " $dir/$old_library" # Keep a list of preopened convenience libraries to check # that they are being used correctly in the link pass. test -z "$libdir" && \ func_append dlpreconveniencelibs " $dir/$old_library" # Otherwise, use the dlname, so that lt_dlopen finds it. elif test -n "$dlname"; then func_append newdlprefiles " $dir/$dlname" else func_append newdlprefiles " $dir/$linklib" fi ;; esac fi # $pass = dlpreopen if test -z "$libdir"; then # Link the convenience library if test "$linkmode" = lib; then deplibs="$dir/$old_library $deplibs" elif test "$linkmode,$pass" = "prog,link"; then compile_deplibs="$dir/$old_library $compile_deplibs" finalize_deplibs="$dir/$old_library $finalize_deplibs" else deplibs="$lib $deplibs" # used for prog,scan pass fi continue fi if test "$linkmode" = prog && test "$pass" != link; then func_append newlib_search_path " $ladir" deplibs="$lib $deplibs" linkalldeplibs=no if test "$link_all_deplibs" != no || test -z "$library_names" || test "$build_libtool_libs" = no; then linkalldeplibs=yes fi tmp_libs= for deplib in $dependency_libs; do case $deplib in -L*) func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; esac # Need to link against all dependency_libs? if test "$linkalldeplibs" = yes; then deplibs="$deplib $deplibs" else # Need to hardcode shared library paths # or/and link against static libraries newdependency_libs="$deplib $newdependency_libs" fi if $opt_preserve_dup_deps ; then case "$tmp_libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append tmp_libs " $deplib" done # for deplib continue fi # $linkmode = prog... if test "$linkmode,$pass" = "prog,link"; then if test -n "$library_names" && { { test "$prefer_static_libs" = no || test "$prefer_static_libs,$installed" = "built,yes"; } || test -z "$old_library"; }; then # We need to hardcode the library path if test -n "$shlibpath_var" && test -z "$avoidtemprpath" ; then # Make sure the rpath contains only unique directories. case "$temp_rpath:" in *"$absdir:"*) ;; *) func_append temp_rpath "$absdir:" ;; esac fi # Hardcode the library path. # Skip directories that are in the system default run-time # search path. case " $sys_lib_dlsearch_path " in *" $absdir "*) ;; *) case "$compile_rpath " in *" $absdir "*) ;; *) func_append compile_rpath " $absdir" ;; esac ;; esac case " $sys_lib_dlsearch_path " in *" $libdir "*) ;; *) case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac ;; esac fi # $linkmode,$pass = prog,link... if test "$alldeplibs" = yes && { test "$deplibs_check_method" = pass_all || { test "$build_libtool_libs" = yes && test -n "$library_names"; }; }; then # We only need to search for static libraries continue fi fi link_static=no # Whether the deplib will be linked statically use_static_libs=$prefer_static_libs if test "$use_static_libs" = built && test "$installed" = yes; then use_static_libs=no fi if test -n "$library_names" && { test "$use_static_libs" = no || test -z "$old_library"; }; then case $host in *cygwin* | *mingw* | *cegcc*) # No point in relinking DLLs because paths are not encoded func_append notinst_deplibs " $lib" need_relink=no ;; *) if test "$installed" = no; then func_append notinst_deplibs " $lib" need_relink=yes fi ;; esac # This is a shared library # Warn about portability, can't link against -module's on some # systems (darwin). Don't bleat about dlopened modules though! dlopenmodule="" for dlpremoduletest in $dlprefiles; do if test "X$dlpremoduletest" = "X$lib"; then dlopenmodule="$dlpremoduletest" break fi done if test -z "$dlopenmodule" && test "$shouldnotlink" = yes && test "$pass" = link; then echo if test "$linkmode" = prog; then $ECHO "*** Warning: Linking the executable $output against the loadable module" else $ECHO "*** Warning: Linking the shared library $output against the loadable module" fi $ECHO "*** $linklib is not portable!" fi if test "$linkmode" = lib && test "$hardcode_into_libs" = yes; then # Hardcode the library path. # Skip directories that are in the system default run-time # search path. case " $sys_lib_dlsearch_path " in *" $absdir "*) ;; *) case "$compile_rpath " in *" $absdir "*) ;; *) func_append compile_rpath " $absdir" ;; esac ;; esac case " $sys_lib_dlsearch_path " in *" $libdir "*) ;; *) case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac ;; esac fi if test -n "$old_archive_from_expsyms_cmds"; then # figure out the soname set dummy $library_names shift realname="$1" shift libname=`eval "\\$ECHO \"$libname_spec\""` # use dlname if we got it. it's perfectly good, no? if test -n "$dlname"; then soname="$dlname" elif test -n "$soname_spec"; then # bleh windows case $host in *cygwin* | mingw* | *cegcc*) func_arith $current - $age major=$func_arith_result versuffix="-$major" ;; esac eval soname=\"$soname_spec\" else soname="$realname" fi # Make a new name for the extract_expsyms_cmds to use soroot="$soname" func_basename "$soroot" soname="$func_basename_result" func_stripname 'lib' '.dll' "$soname" newlib=libimp-$func_stripname_result.a # If the library has no export list, then create one now if test -f "$output_objdir/$soname-def"; then : else func_verbose "extracting exported symbol list from \`$soname'" func_execute_cmds "$extract_expsyms_cmds" 'exit $?' fi # Create $newlib if test -f "$output_objdir/$newlib"; then :; else func_verbose "generating import library for \`$soname'" func_execute_cmds "$old_archive_from_expsyms_cmds" 'exit $?' fi # make sure the library variables are pointing to the new library dir=$output_objdir linklib=$newlib fi # test -n "$old_archive_from_expsyms_cmds" if test "$linkmode" = prog || test "$opt_mode" != relink; then add_shlibpath= add_dir= add= lib_linked=yes case $hardcode_action in immediate | unsupported) if test "$hardcode_direct" = no; then add="$dir/$linklib" case $host in *-*-sco3.2v5.0.[024]*) add_dir="-L$dir" ;; *-*-sysv4*uw2*) add_dir="-L$dir" ;; *-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.[01].[10]* | \ *-*-unixware7*) add_dir="-L$dir" ;; *-*-darwin* ) # if the lib is a (non-dlopened) module then we can not # link against it, someone is ignoring the earlier warnings if /usr/bin/file -L $add 2> /dev/null | $GREP ": [^:]* bundle" >/dev/null ; then if test "X$dlopenmodule" != "X$lib"; then $ECHO "*** Warning: lib $linklib is a module, not a shared library" if test -z "$old_library" ; then echo echo "*** And there doesn't seem to be a static archive available" echo "*** The link will probably fail, sorry" else add="$dir/$old_library" fi elif test -n "$old_library"; then add="$dir/$old_library" fi fi esac elif test "$hardcode_minus_L" = no; then case $host in *-*-sunos*) add_shlibpath="$dir" ;; esac add_dir="-L$dir" add="-l$name" elif test "$hardcode_shlibpath_var" = no; then add_shlibpath="$dir" add="-l$name" else lib_linked=no fi ;; relink) if test "$hardcode_direct" = yes && test "$hardcode_direct_absolute" = no; then add="$dir/$linklib" elif test "$hardcode_minus_L" = yes; then add_dir="-L$absdir" # Try looking first in the location we're being installed to. if test -n "$inst_prefix_dir"; then case $libdir in [\\/]*) func_append add_dir " -L$inst_prefix_dir$libdir" ;; esac fi add="-l$name" elif test "$hardcode_shlibpath_var" = yes; then add_shlibpath="$dir" add="-l$name" else lib_linked=no fi ;; *) lib_linked=no ;; esac if test "$lib_linked" != yes; then func_fatal_configuration "unsupported hardcode properties" fi if test -n "$add_shlibpath"; then case :$compile_shlibpath: in *":$add_shlibpath:"*) ;; *) func_append compile_shlibpath "$add_shlibpath:" ;; esac fi if test "$linkmode" = prog; then test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs" test -n "$add" && compile_deplibs="$add $compile_deplibs" else test -n "$add_dir" && deplibs="$add_dir $deplibs" test -n "$add" && deplibs="$add $deplibs" if test "$hardcode_direct" != yes && test "$hardcode_minus_L" != yes && test "$hardcode_shlibpath_var" = yes; then case :$finalize_shlibpath: in *":$libdir:"*) ;; *) func_append finalize_shlibpath "$libdir:" ;; esac fi fi fi if test "$linkmode" = prog || test "$opt_mode" = relink; then add_shlibpath= add_dir= add= # Finalize command for both is simple: just hardcode it. if test "$hardcode_direct" = yes && test "$hardcode_direct_absolute" = no; then add="$libdir/$linklib" elif test "$hardcode_minus_L" = yes; then add_dir="-L$libdir" add="-l$name" elif test "$hardcode_shlibpath_var" = yes; then case :$finalize_shlibpath: in *":$libdir:"*) ;; *) func_append finalize_shlibpath "$libdir:" ;; esac add="-l$name" elif test "$hardcode_automatic" = yes; then if test -n "$inst_prefix_dir" && test -f "$inst_prefix_dir$libdir/$linklib" ; then add="$inst_prefix_dir$libdir/$linklib" else add="$libdir/$linklib" fi else # We cannot seem to hardcode it, guess we'll fake it. add_dir="-L$libdir" # Try looking first in the location we're being installed to. if test -n "$inst_prefix_dir"; then case $libdir in [\\/]*) func_append add_dir " -L$inst_prefix_dir$libdir" ;; esac fi add="-l$name" fi if test "$linkmode" = prog; then test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs" test -n "$add" && finalize_deplibs="$add $finalize_deplibs" else test -n "$add_dir" && deplibs="$add_dir $deplibs" test -n "$add" && deplibs="$add $deplibs" fi fi elif test "$linkmode" = prog; then # Here we assume that one of hardcode_direct or hardcode_minus_L # is not unsupported. This is valid on all known static and # shared platforms. if test "$hardcode_direct" != unsupported; then test -n "$old_library" && linklib="$old_library" compile_deplibs="$dir/$linklib $compile_deplibs" finalize_deplibs="$dir/$linklib $finalize_deplibs" else compile_deplibs="-l$name -L$dir $compile_deplibs" finalize_deplibs="-l$name -L$dir $finalize_deplibs" fi elif test "$build_libtool_libs" = yes; then # Not a shared library if test "$deplibs_check_method" != pass_all; then # We're trying link a shared library against a static one # but the system doesn't support it. # Just print a warning and add the library to dependency_libs so # that the program can be linked against the static library. echo $ECHO "*** Warning: This system can not link to static lib archive $lib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have." if test "$module" = yes; then echo "*** But as you try to build a module library, libtool will still create " echo "*** a static module, that should work as long as the dlopening application" echo "*** is linked with the -dlopen flag to resolve symbols at runtime." if test -z "$global_symbol_pipe"; then echo echo "*** However, this would only work if libtool was able to extract symbol" echo "*** lists from a program, using \`nm' or equivalent, but libtool could" echo "*** not find such a program. So, this module is probably useless." echo "*** \`nm' from GNU binutils and a full rebuild may help." fi if test "$build_old_libs" = no; then build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi fi else deplibs="$dir/$old_library $deplibs" link_static=yes fi fi # link shared/static library? if test "$linkmode" = lib; then if test -n "$dependency_libs" && { test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes || test "$link_static" = yes; }; then # Extract -R from dependency_libs temp_deplibs= for libdir in $dependency_libs; do case $libdir in -R*) func_stripname '-R' '' "$libdir" temp_xrpath=$func_stripname_result case " $xrpath " in *" $temp_xrpath "*) ;; *) func_append xrpath " $temp_xrpath";; esac;; *) func_append temp_deplibs " $libdir";; esac done dependency_libs="$temp_deplibs" fi func_append newlib_search_path " $absdir" # Link against this library test "$link_static" = no && newdependency_libs="$abs_ladir/$laname $newdependency_libs" # ... and its dependency_libs tmp_libs= for deplib in $dependency_libs; do newdependency_libs="$deplib $newdependency_libs" case $deplib in -L*) func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result";; *) func_resolve_sysroot "$deplib" ;; esac if $opt_preserve_dup_deps ; then case "$tmp_libs " in *" $func_resolve_sysroot_result "*) func_append specialdeplibs " $func_resolve_sysroot_result" ;; esac fi func_append tmp_libs " $func_resolve_sysroot_result" done if test "$link_all_deplibs" != no; then # Add the search paths of all dependency libraries for deplib in $dependency_libs; do path= case $deplib in -L*) path="$deplib" ;; *.la) func_resolve_sysroot "$deplib" deplib=$func_resolve_sysroot_result func_dirname "$deplib" "" "." dir=$func_dirname_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) absdir="$dir" ;; *) absdir=`cd "$dir" && pwd` if test -z "$absdir"; then func_warning "cannot determine absolute directory name of \`$dir'" absdir="$dir" fi ;; esac if $GREP "^installed=no" $deplib > /dev/null; then case $host in *-*-darwin*) depdepl= eval deplibrary_names=`${SED} -n -e 's/^library_names=\(.*\)$/\1/p' $deplib` if test -n "$deplibrary_names" ; then for tmp in $deplibrary_names ; do depdepl=$tmp done if test -f "$absdir/$objdir/$depdepl" ; then depdepl="$absdir/$objdir/$depdepl" darwin_install_name=`${OTOOL} -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` if test -z "$darwin_install_name"; then darwin_install_name=`${OTOOL64} -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` fi func_append compiler_flags " ${wl}-dylib_file ${wl}${darwin_install_name}:${depdepl}" func_append linker_flags " -dylib_file ${darwin_install_name}:${depdepl}" path= fi fi ;; *) path="-L$absdir/$objdir" ;; esac else eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` test -z "$libdir" && \ func_fatal_error "\`$deplib' is not a valid libtool archive" test "$absdir" != "$libdir" && \ func_warning "\`$deplib' seems to be moved" path="-L$absdir" fi ;; esac case " $deplibs " in *" $path "*) ;; *) deplibs="$path $deplibs" ;; esac done fi # link_all_deplibs != no fi # linkmode = lib done # for deplib in $libs if test "$pass" = link; then if test "$linkmode" = "prog"; then compile_deplibs="$new_inherited_linker_flags $compile_deplibs" finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs" else compiler_flags="$compiler_flags "`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` fi fi dependency_libs="$newdependency_libs" if test "$pass" = dlpreopen; then # Link the dlpreopened libraries before other libraries for deplib in $save_deplibs; do deplibs="$deplib $deplibs" done fi if test "$pass" != dlopen; then if test "$pass" != conv; then # Make sure lib_search_path contains only unique directories. lib_search_path= for dir in $newlib_search_path; do case "$lib_search_path " in *" $dir "*) ;; *) func_append lib_search_path " $dir" ;; esac done newlib_search_path= fi if test "$linkmode,$pass" != "prog,link"; then vars="deplibs" else vars="compile_deplibs finalize_deplibs" fi for var in $vars dependency_libs; do # Add libraries to $var in reverse order eval tmp_libs=\"\$$var\" new_libs= for deplib in $tmp_libs; do # FIXME: Pedantically, this is the right thing to do, so # that some nasty dependency loop isn't accidentally # broken: #new_libs="$deplib $new_libs" # Pragmatically, this seems to cause very few problems in # practice: case $deplib in -L*) new_libs="$deplib $new_libs" ;; -R*) ;; *) # And here is the reason: when a library appears more # than once as an explicit dependence of a library, or # is implicitly linked in more than once by the # compiler, it is considered special, and multiple # occurrences thereof are not removed. Compare this # with having the same library being listed as a # dependency of multiple other libraries: in this case, # we know (pedantically, we assume) the library does not # need to be listed more than once, so we keep only the # last copy. This is not always right, but it is rare # enough that we require users that really mean to play # such unportable linking tricks to link the library # using -Wl,-lname, so that libtool does not consider it # for duplicate removal. case " $specialdeplibs " in *" $deplib "*) new_libs="$deplib $new_libs" ;; *) case " $new_libs " in *" $deplib "*) ;; *) new_libs="$deplib $new_libs" ;; esac ;; esac ;; esac done tmp_libs= for deplib in $new_libs; do case $deplib in -L*) case " $tmp_libs " in *" $deplib "*) ;; *) func_append tmp_libs " $deplib" ;; esac ;; *) func_append tmp_libs " $deplib" ;; esac done eval $var=\"$tmp_libs\" done # for var fi # Last step: remove runtime libs from dependency_libs # (they stay in deplibs) tmp_libs= for i in $dependency_libs ; do case " $predeps $postdeps $compiler_lib_search_path " in *" $i "*) i="" ;; esac if test -n "$i" ; then func_append tmp_libs " $i" fi done dependency_libs=$tmp_libs done # for pass if test "$linkmode" = prog; then dlfiles="$newdlfiles" fi if test "$linkmode" = prog || test "$linkmode" = lib; then dlprefiles="$newdlprefiles" fi case $linkmode in oldlib) if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then func_warning "\`-dlopen' is ignored for archives" fi case " $deplibs" in *\ -l* | *\ -L*) func_warning "\`-l' and \`-L' are ignored for archives" ;; esac test -n "$rpath" && \ func_warning "\`-rpath' is ignored for archives" test -n "$xrpath" && \ func_warning "\`-R' is ignored for archives" test -n "$vinfo" && \ func_warning "\`-version-info/-version-number' is ignored for archives" test -n "$release" && \ func_warning "\`-release' is ignored for archives" test -n "$export_symbols$export_symbols_regex" && \ func_warning "\`-export-symbols' is ignored for archives" # Now set the variables for building old libraries. build_libtool_libs=no oldlibs="$output" func_append objs "$old_deplibs" ;; lib) # Make sure we only generate libraries of the form `libNAME.la'. case $outputname in lib*) func_stripname 'lib' '.la' "$outputname" name=$func_stripname_result eval shared_ext=\"$shrext_cmds\" eval libname=\"$libname_spec\" ;; *) test "$module" = no && \ func_fatal_help "libtool library \`$output' must begin with \`lib'" if test "$need_lib_prefix" != no; then # Add the "lib" prefix for modules if required func_stripname '' '.la' "$outputname" name=$func_stripname_result eval shared_ext=\"$shrext_cmds\" eval libname=\"$libname_spec\" else func_stripname '' '.la' "$outputname" libname=$func_stripname_result fi ;; esac if test -n "$objs"; then if test "$deplibs_check_method" != pass_all; then func_fatal_error "cannot build libtool library \`$output' from non-libtool objects on this host:$objs" else echo $ECHO "*** Warning: Linking the shared library $output against the non-libtool" $ECHO "*** objects $objs is not portable!" func_append libobjs " $objs" fi fi test "$dlself" != no && \ func_warning "\`-dlopen self' is ignored for libtool libraries" set dummy $rpath shift test "$#" -gt 1 && \ func_warning "ignoring multiple \`-rpath's for a libtool library" install_libdir="$1" oldlibs= if test -z "$rpath"; then if test "$build_libtool_libs" = yes; then # Building a libtool convenience library. # Some compilers have problems with a `.al' extension so # convenience libraries should have the same extension an # archive normally would. oldlibs="$output_objdir/$libname.$libext $oldlibs" build_libtool_libs=convenience build_old_libs=yes fi test -n "$vinfo" && \ func_warning "\`-version-info/-version-number' is ignored for convenience libraries" test -n "$release" && \ func_warning "\`-release' is ignored for convenience libraries" else # Parse the version information argument. save_ifs="$IFS"; IFS=':' set dummy $vinfo 0 0 0 shift IFS="$save_ifs" test -n "$7" && \ func_fatal_help "too many parameters to \`-version-info'" # convert absolute version numbers to libtool ages # this retains compatibility with .la files and attempts # to make the code below a bit more comprehensible case $vinfo_number in yes) number_major="$1" number_minor="$2" number_revision="$3" # # There are really only two kinds -- those that # use the current revision as the major version # and those that subtract age and use age as # a minor version. But, then there is irix # which has an extra 1 added just for fun # case $version_type in # correct linux to gnu/linux during the next big refactor darwin|linux|osf|windows|none) func_arith $number_major + $number_minor current=$func_arith_result age="$number_minor" revision="$number_revision" ;; freebsd-aout|freebsd-elf|qnx|sunos) current="$number_major" revision="$number_minor" age="0" ;; irix|nonstopux) func_arith $number_major + $number_minor current=$func_arith_result age="$number_minor" revision="$number_minor" lt_irix_increment=no ;; *) func_fatal_configuration "$modename: unknown library version type \`$version_type'" ;; esac ;; no) current="$1" revision="$2" age="$3" ;; esac # Check that each of the things are valid numbers. case $current in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "CURRENT \`$current' must be a nonnegative integer" func_fatal_error "\`$vinfo' is not valid version information" ;; esac case $revision in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "REVISION \`$revision' must be a nonnegative integer" func_fatal_error "\`$vinfo' is not valid version information" ;; esac case $age in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "AGE \`$age' must be a nonnegative integer" func_fatal_error "\`$vinfo' is not valid version information" ;; esac if test "$age" -gt "$current"; then func_error "AGE \`$age' is greater than the current interface number \`$current'" func_fatal_error "\`$vinfo' is not valid version information" fi # Calculate the version variables. major= versuffix= verstring= case $version_type in none) ;; darwin) # Like Linux, but with the current version available in # verstring for coding it into the library header func_arith $current - $age major=.$func_arith_result versuffix="$major.$age.$revision" # Darwin ld doesn't like 0 for these options... func_arith $current + 1 minor_current=$func_arith_result xlcverstring="${wl}-compatibility_version ${wl}$minor_current ${wl}-current_version ${wl}$minor_current.$revision" verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" ;; freebsd-aout) major=".$current" versuffix=".$current.$revision"; ;; freebsd-elf) major=".$current" versuffix=".$current" ;; irix | nonstopux) if test "X$lt_irix_increment" = "Xno"; then func_arith $current - $age else func_arith $current - $age + 1 fi major=$func_arith_result case $version_type in nonstopux) verstring_prefix=nonstopux ;; *) verstring_prefix=sgi ;; esac verstring="$verstring_prefix$major.$revision" # Add in all the interfaces that we are compatible with. loop=$revision while test "$loop" -ne 0; do func_arith $revision - $loop iface=$func_arith_result func_arith $loop - 1 loop=$func_arith_result verstring="$verstring_prefix$major.$iface:$verstring" done # Before this point, $major must not contain `.'. major=.$major versuffix="$major.$revision" ;; linux) # correct to gnu/linux during the next big refactor func_arith $current - $age major=.$func_arith_result versuffix="$major.$age.$revision" ;; osf) func_arith $current - $age major=.$func_arith_result versuffix=".$current.$age.$revision" verstring="$current.$age.$revision" # Add in all the interfaces that we are compatible with. loop=$age while test "$loop" -ne 0; do func_arith $current - $loop iface=$func_arith_result func_arith $loop - 1 loop=$func_arith_result verstring="$verstring:${iface}.0" done # Make executables depend on our current version. func_append verstring ":${current}.0" ;; qnx) major=".$current" versuffix=".$current" ;; sunos) major=".$current" versuffix=".$current.$revision" ;; windows) # Use '-' rather than '.', since we only want one # extension on DOS 8.3 filesystems. func_arith $current - $age major=$func_arith_result versuffix="-$major" ;; *) func_fatal_configuration "unknown library version type \`$version_type'" ;; esac # Clear the version info if we defaulted, and they specified a release. if test -z "$vinfo" && test -n "$release"; then major= case $version_type in darwin) # we can't check for "0.0" in archive_cmds due to quoting # problems, so we reset it completely verstring= ;; *) verstring="0.0" ;; esac if test "$need_version" = no; then versuffix= else versuffix=".0.0" fi fi # Remove version info from name if versioning should be avoided if test "$avoid_version" = yes && test "$need_version" = no; then major= versuffix= verstring="" fi # Check to see if the archive will have undefined symbols. if test "$allow_undefined" = yes; then if test "$allow_undefined_flag" = unsupported; then func_warning "undefined symbols not allowed in $host shared libraries" build_libtool_libs=no build_old_libs=yes fi else # Don't allow undefined symbols. allow_undefined_flag="$no_undefined_flag" fi fi func_generate_dlsyms "$libname" "$libname" "yes" func_append libobjs " $symfileobj" test "X$libobjs" = "X " && libobjs= if test "$opt_mode" != relink; then # Remove our outputs, but don't remove object files since they # may have been created when compiling PIC objects. removelist= tempremovelist=`$ECHO "$output_objdir/*"` for p in $tempremovelist; do case $p in *.$objext | *.gcno) ;; $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/${libname}${release}.*) if test "X$precious_files_regex" != "X"; then if $ECHO "$p" | $EGREP -e "$precious_files_regex" >/dev/null 2>&1 then continue fi fi func_append removelist " $p" ;; *) ;; esac done test -n "$removelist" && \ func_show_eval "${RM}r \$removelist" fi # Now set the variables for building old libraries. if test "$build_old_libs" = yes && test "$build_libtool_libs" != convenience ; then func_append oldlibs " $output_objdir/$libname.$libext" # Transform .lo files to .o files. oldobjs="$objs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.${libext}$/d; $lo2o" | $NL2SP` fi # Eliminate all temporary directories. #for path in $notinst_path; do # lib_search_path=`$ECHO "$lib_search_path " | $SED "s% $path % %g"` # deplibs=`$ECHO "$deplibs " | $SED "s% -L$path % %g"` # dependency_libs=`$ECHO "$dependency_libs " | $SED "s% -L$path % %g"` #done if test -n "$xrpath"; then # If the user specified any rpath flags, then add them. temp_xrpath= for libdir in $xrpath; do func_replace_sysroot "$libdir" func_append temp_xrpath " -R$func_replace_sysroot_result" case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac done if test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes; then dependency_libs="$temp_xrpath $dependency_libs" fi fi # Make sure dlfiles contains only unique files that won't be dlpreopened old_dlfiles="$dlfiles" dlfiles= for lib in $old_dlfiles; do case " $dlprefiles $dlfiles " in *" $lib "*) ;; *) func_append dlfiles " $lib" ;; esac done # Make sure dlprefiles contains only unique files old_dlprefiles="$dlprefiles" dlprefiles= for lib in $old_dlprefiles; do case "$dlprefiles " in *" $lib "*) ;; *) func_append dlprefiles " $lib" ;; esac done if test "$build_libtool_libs" = yes; then if test -n "$rpath"; then case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc* | *-*-haiku*) # these systems don't actually have a c library (as such)! ;; *-*-rhapsody* | *-*-darwin1.[012]) # Rhapsody C library is in the System framework func_append deplibs " System.ltframework" ;; *-*-netbsd*) # Don't link with libc until the a.out ld.so is fixed. ;; *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) # Do not include libc due to us having libc/libc_r. ;; *-*-sco3.2v5* | *-*-sco5v6*) # Causes problems with __ctype ;; *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) # Compiler inserts libc in the correct place for threads to work ;; *) # Add libc to deplibs on all other systems if necessary. if test "$build_libtool_need_lc" = "yes"; then func_append deplibs " -lc" fi ;; esac fi # Transform deplibs into only deplibs that can be linked in shared. name_save=$name libname_save=$libname release_save=$release versuffix_save=$versuffix major_save=$major # I'm not sure if I'm treating the release correctly. I think # release should show up in the -l (ie -lgmp5) so we don't want to # add it in twice. Is that correct? release="" versuffix="" major="" newdeplibs= droppeddeps=no case $deplibs_check_method in pass_all) # Don't check for shared/static. Everything works. # This might be a little naive. We might want to check # whether the library exists or not. But this is on # osf3 & osf4 and I'm not really sure... Just # implementing what was already the behavior. newdeplibs=$deplibs ;; test_compile) # This code stresses the "libraries are programs" paradigm to its # limits. Maybe even breaks it. We compile a program, linking it # against the deplibs as a proxy for the library. Then we can check # whether they linked in statically or dynamically with ldd. $opt_dry_run || $RM conftest.c cat > conftest.c </dev/null` $nocaseglob else potential_libs=`ls $i/$libnameglob[.-]* 2>/dev/null` fi for potent_lib in $potential_libs; do # Follow soft links. if ls -lLd "$potent_lib" 2>/dev/null | $GREP " -> " >/dev/null; then continue fi # The statement above tries to avoid entering an # endless loop below, in case of cyclic links. # We might still enter an endless loop, since a link # loop can be closed while we follow links, # but so what? potlib="$potent_lib" while test -h "$potlib" 2>/dev/null; do potliblink=`ls -ld $potlib | ${SED} 's/.* -> //'` case $potliblink in [\\/]* | [A-Za-z]:[\\/]*) potlib="$potliblink";; *) potlib=`$ECHO "$potlib" | $SED 's,[^/]*$,,'`"$potliblink";; esac done if eval $file_magic_cmd \"\$potlib\" 2>/dev/null | $SED -e 10q | $EGREP "$file_magic_regex" > /dev/null; then func_append newdeplibs " $a_deplib" a_deplib="" break 2 fi done done fi if test -n "$a_deplib" ; then droppeddeps=yes echo $ECHO "*** Warning: linker path does not have real file for library $a_deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because I did check the linker path looking for a file starting" if test -z "$potlib" ; then $ECHO "*** with $libname but no candidates were found. (...for file magic test)" else $ECHO "*** with $libname and none of the candidates passed a file format test" $ECHO "*** using a file magic. Last file checked: $potlib" fi fi ;; *) # Add a -L argument. func_append newdeplibs " $a_deplib" ;; esac done # Gone through all deplibs. ;; match_pattern*) set dummy $deplibs_check_method; shift match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` for a_deplib in $deplibs; do case $a_deplib in -l*) func_stripname -l '' "$a_deplib" name=$func_stripname_result if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then case " $predeps $postdeps " in *" $a_deplib "*) func_append newdeplibs " $a_deplib" a_deplib="" ;; esac fi if test -n "$a_deplib" ; then libname=`eval "\\$ECHO \"$libname_spec\""` for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do potential_libs=`ls $i/$libname[.-]* 2>/dev/null` for potent_lib in $potential_libs; do potlib="$potent_lib" # see symlink-check above in file_magic test if eval "\$ECHO \"$potent_lib\"" 2>/dev/null | $SED 10q | \ $EGREP "$match_pattern_regex" > /dev/null; then func_append newdeplibs " $a_deplib" a_deplib="" break 2 fi done done fi if test -n "$a_deplib" ; then droppeddeps=yes echo $ECHO "*** Warning: linker path does not have real file for library $a_deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because I did check the linker path looking for a file starting" if test -z "$potlib" ; then $ECHO "*** with $libname but no candidates were found. (...for regex pattern test)" else $ECHO "*** with $libname and none of the candidates passed a file format test" $ECHO "*** using a regex pattern. Last file checked: $potlib" fi fi ;; *) # Add a -L argument. func_append newdeplibs " $a_deplib" ;; esac done # Gone through all deplibs. ;; none | unknown | *) newdeplibs="" tmp_deplibs=`$ECHO " $deplibs" | $SED 's/ -lc$//; s/ -[LR][^ ]*//g'` if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then for i in $predeps $postdeps ; do # can't use Xsed below, because $i might contain '/' tmp_deplibs=`$ECHO " $tmp_deplibs" | $SED "s,$i,,"` done fi case $tmp_deplibs in *[!\ \ ]*) echo if test "X$deplibs_check_method" = "Xnone"; then echo "*** Warning: inter-library dependencies are not supported in this platform." else echo "*** Warning: inter-library dependencies are not known to be supported." fi echo "*** All declared inter-library dependencies are being dropped." droppeddeps=yes ;; esac ;; esac versuffix=$versuffix_save major=$major_save release=$release_save libname=$libname_save name=$name_save case $host in *-*-rhapsody* | *-*-darwin1.[012]) # On Rhapsody replace the C library with the System framework newdeplibs=`$ECHO " $newdeplibs" | $SED 's/ -lc / System.ltframework /'` ;; esac if test "$droppeddeps" = yes; then if test "$module" = yes; then echo echo "*** Warning: libtool could not satisfy all declared inter-library" $ECHO "*** dependencies of module $libname. Therefore, libtool will create" echo "*** a static module, that should work as long as the dlopening" echo "*** application is linked with the -dlopen flag." if test -z "$global_symbol_pipe"; then echo echo "*** However, this would only work if libtool was able to extract symbol" echo "*** lists from a program, using \`nm' or equivalent, but libtool could" echo "*** not find such a program. So, this module is probably useless." echo "*** \`nm' from GNU binutils and a full rebuild may help." fi if test "$build_old_libs" = no; then oldlibs="$output_objdir/$libname.$libext" build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi else echo "*** The inter-library dependencies that have been dropped here will be" echo "*** automatically added whenever a program is linked with this library" echo "*** or is declared to -dlopen it." if test "$allow_undefined" = no; then echo echo "*** Since this library must not contain undefined symbols," echo "*** because either the platform does not support them or" echo "*** it was explicitly requested with -no-undefined," echo "*** libtool will only create a static version of it." if test "$build_old_libs" = no; then oldlibs="$output_objdir/$libname.$libext" build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi fi fi fi # Done checking deplibs! deplibs=$newdeplibs fi # Time to change all our "foo.ltframework" stuff back to "-framework foo" case $host in *-*-darwin*) newdeplibs=`$ECHO " $newdeplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` new_inherited_linker_flags=`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` deplibs=`$ECHO " $deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` ;; esac # move library search paths that coincide with paths to not yet # installed libraries to the beginning of the library search list new_libs= for path in $notinst_path; do case " $new_libs " in *" -L$path/$objdir "*) ;; *) case " $deplibs " in *" -L$path/$objdir "*) func_append new_libs " -L$path/$objdir" ;; esac ;; esac done for deplib in $deplibs; do case $deplib in -L*) case " $new_libs " in *" $deplib "*) ;; *) func_append new_libs " $deplib" ;; esac ;; *) func_append new_libs " $deplib" ;; esac done deplibs="$new_libs" # All the library-specific variables (install_libdir is set above). library_names= old_library= dlname= # Test again, we may have decided not to build it any more if test "$build_libtool_libs" = yes; then # Remove ${wl} instances when linking with ld. # FIXME: should test the right _cmds variable. case $archive_cmds in *\$LD\ *) wl= ;; esac if test "$hardcode_into_libs" = yes; then # Hardcode the library paths hardcode_libdirs= dep_rpath= rpath="$finalize_rpath" test "$opt_mode" != relink && rpath="$compile_rpath$rpath" for libdir in $rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then func_replace_sysroot "$libdir" libdir=$func_replace_sysroot_result if test -z "$hardcode_libdirs"; then hardcode_libdirs="$libdir" else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append dep_rpath " $flag" fi elif test -n "$runpath_var"; then case "$perm_rpath " in *" $libdir "*) ;; *) func_append perm_rpath " $libdir" ;; esac fi done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir="$hardcode_libdirs" eval "dep_rpath=\"$hardcode_libdir_flag_spec\"" fi if test -n "$runpath_var" && test -n "$perm_rpath"; then # We should set the runpath_var. rpath= for dir in $perm_rpath; do func_append rpath "$dir:" done eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var" fi test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs" fi shlibpath="$finalize_shlibpath" test "$opt_mode" != relink && shlibpath="$compile_shlibpath$shlibpath" if test -n "$shlibpath"; then eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var" fi # Get the real and link names of the library. eval shared_ext=\"$shrext_cmds\" eval library_names=\"$library_names_spec\" set dummy $library_names shift realname="$1" shift if test -n "$soname_spec"; then eval soname=\"$soname_spec\" else soname="$realname" fi if test -z "$dlname"; then dlname=$soname fi lib="$output_objdir/$realname" linknames= for link do func_append linknames " $link" done # Use standard objects if they are pic test -z "$pic_flag" && libobjs=`$ECHO "$libobjs" | $SP2NL | $SED "$lo2o" | $NL2SP` test "X$libobjs" = "X " && libobjs= delfiles= if test -n "$export_symbols" && test -n "$include_expsyms"; then $opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp" export_symbols="$output_objdir/$libname.uexp" func_append delfiles " $export_symbols" fi orig_export_symbols= case $host_os in cygwin* | mingw* | cegcc*) if test -n "$export_symbols" && test -z "$export_symbols_regex"; then # exporting using user supplied symfile if test "x`$SED 1q $export_symbols`" != xEXPORTS; then # and it's NOT already a .def file. Must figure out # which of the given symbols are data symbols and tag # them as such. So, trigger use of export_symbols_cmds. # export_symbols gets reassigned inside the "prepare # the list of exported symbols" if statement, so the # include_expsyms logic still works. orig_export_symbols="$export_symbols" export_symbols= always_export_symbols=yes fi fi ;; esac # Prepare the list of exported symbols if test -z "$export_symbols"; then if test "$always_export_symbols" = yes || test -n "$export_symbols_regex"; then func_verbose "generating symbol list for \`$libname.la'" export_symbols="$output_objdir/$libname.exp" $opt_dry_run || $RM $export_symbols cmds=$export_symbols_cmds save_ifs="$IFS"; IFS='~' for cmd1 in $cmds; do IFS="$save_ifs" # Take the normal branch if the nm_file_list_spec branch # doesn't work or if tool conversion is not needed. case $nm_file_list_spec~$to_tool_file_cmd in *~func_convert_file_noop | *~func_convert_file_msys_to_w32 | ~*) try_normal_branch=yes eval cmd=\"$cmd1\" func_len " $cmd" len=$func_len_result ;; *) try_normal_branch=no ;; esac if test "$try_normal_branch" = yes \ && { test "$len" -lt "$max_cmd_len" \ || test "$max_cmd_len" -le -1; } then func_show_eval "$cmd" 'exit $?' skipped_export=false elif test -n "$nm_file_list_spec"; then func_basename "$output" output_la=$func_basename_result save_libobjs=$libobjs save_output=$output output=${output_objdir}/${output_la}.nm func_to_tool_file "$output" libobjs=$nm_file_list_spec$func_to_tool_file_result func_append delfiles " $output" func_verbose "creating $NM input file list: $output" for obj in $save_libobjs; do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" done > "$output" eval cmd=\"$cmd1\" func_show_eval "$cmd" 'exit $?' output=$save_output libobjs=$save_libobjs skipped_export=false else # The command line is too long to execute in one step. func_verbose "using reloadable object file for export list..." skipped_export=: # Break out early, otherwise skipped_export may be # set to false by a later but shorter cmd. break fi done IFS="$save_ifs" if test -n "$export_symbols_regex" && test "X$skipped_export" != "X:"; then func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' func_show_eval '$MV "${export_symbols}T" "$export_symbols"' fi fi fi if test -n "$export_symbols" && test -n "$include_expsyms"; then tmp_export_symbols="$export_symbols" test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols" $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"' fi if test "X$skipped_export" != "X:" && test -n "$orig_export_symbols"; then # The given exports_symbols file has to be filtered, so filter it. func_verbose "filter symbol list for \`$libname.la' to tag DATA exports" # FIXME: $output_objdir/$libname.filter potentially contains lots of # 's' commands which not all seds can handle. GNU sed should be fine # though. Also, the filter scales superlinearly with the number of # global variables. join(1) would be nice here, but unfortunately # isn't a blessed tool. $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter func_append delfiles " $export_symbols $output_objdir/$libname.filter" export_symbols=$output_objdir/$libname.def $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols fi tmp_deplibs= for test_deplib in $deplibs; do case " $convenience " in *" $test_deplib "*) ;; *) func_append tmp_deplibs " $test_deplib" ;; esac done deplibs="$tmp_deplibs" if test -n "$convenience"; then if test -n "$whole_archive_flag_spec" && test "$compiler_needs_object" = yes && test -z "$libobjs"; then # extract the archives, so we have objects to list. # TODO: could optimize this to just extract one archive. whole_archive_flag_spec= fi if test -n "$whole_archive_flag_spec"; then save_libobjs=$libobjs eval libobjs=\"\$libobjs $whole_archive_flag_spec\" test "X$libobjs" = "X " && libobjs= else gentop="$output_objdir/${outputname}x" func_append generated " $gentop" func_extract_archives $gentop $convenience func_append libobjs " $func_extract_archives_result" test "X$libobjs" = "X " && libobjs= fi fi if test "$thread_safe" = yes && test -n "$thread_safe_flag_spec"; then eval flag=\"$thread_safe_flag_spec\" func_append linker_flags " $flag" fi # Make a backup of the uninstalled library when relinking if test "$opt_mode" = relink; then $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}U && $MV $realname ${realname}U)' || exit $? fi # Do each of the archive commands. if test "$module" = yes && test -n "$module_cmds" ; then if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then eval test_cmds=\"$module_expsym_cmds\" cmds=$module_expsym_cmds else eval test_cmds=\"$module_cmds\" cmds=$module_cmds fi else if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then eval test_cmds=\"$archive_expsym_cmds\" cmds=$archive_expsym_cmds else eval test_cmds=\"$archive_cmds\" cmds=$archive_cmds fi fi if test "X$skipped_export" != "X:" && func_len " $test_cmds" && len=$func_len_result && test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then : else # The command line is too long to link in one step, link piecewise # or, if using GNU ld and skipped_export is not :, use a linker # script. # Save the value of $output and $libobjs because we want to # use them later. If we have whole_archive_flag_spec, we # want to use save_libobjs as it was before # whole_archive_flag_spec was expanded, because we can't # assume the linker understands whole_archive_flag_spec. # This may have to be revisited, in case too many # convenience libraries get linked in and end up exceeding # the spec. if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then save_libobjs=$libobjs fi save_output=$output func_basename "$output" output_la=$func_basename_result # Clear the reloadable object creation command queue and # initialize k to one. test_cmds= concat_cmds= objlist= last_robj= k=1 if test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "$with_gnu_ld" = yes; then output=${output_objdir}/${output_la}.lnkscript func_verbose "creating GNU ld script: $output" echo 'INPUT (' > $output for obj in $save_libobjs do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" >> $output done echo ')' >> $output func_append delfiles " $output" func_to_tool_file "$output" output=$func_to_tool_file_result elif test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "X$file_list_spec" != X; then output=${output_objdir}/${output_la}.lnk func_verbose "creating linker input file list: $output" : > $output set x $save_libobjs shift firstobj= if test "$compiler_needs_object" = yes; then firstobj="$1 " shift fi for obj do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" >> $output done func_append delfiles " $output" func_to_tool_file "$output" output=$firstobj\"$file_list_spec$func_to_tool_file_result\" else if test -n "$save_libobjs"; then func_verbose "creating reloadable object files..." output=$output_objdir/$output_la-${k}.$objext eval test_cmds=\"$reload_cmds\" func_len " $test_cmds" len0=$func_len_result len=$len0 # Loop over the list of objects to be linked. for obj in $save_libobjs do func_len " $obj" func_arith $len + $func_len_result len=$func_arith_result if test "X$objlist" = X || test "$len" -lt "$max_cmd_len"; then func_append objlist " $obj" else # The command $test_cmds is almost too long, add a # command to the queue. if test "$k" -eq 1 ; then # The first file doesn't have a previous command to add. reload_objs=$objlist eval concat_cmds=\"$reload_cmds\" else # All subsequent reloadable object files will link in # the last one created. reload_objs="$objlist $last_robj" eval concat_cmds=\"\$concat_cmds~$reload_cmds~\$RM $last_robj\" fi last_robj=$output_objdir/$output_la-${k}.$objext func_arith $k + 1 k=$func_arith_result output=$output_objdir/$output_la-${k}.$objext objlist=" $obj" func_len " $last_robj" func_arith $len0 + $func_len_result len=$func_arith_result fi done # Handle the remaining objects by creating one last # reloadable object file. All subsequent reloadable object # files will link in the last one created. test -z "$concat_cmds" || concat_cmds=$concat_cmds~ reload_objs="$objlist $last_robj" eval concat_cmds=\"\${concat_cmds}$reload_cmds\" if test -n "$last_robj"; then eval concat_cmds=\"\${concat_cmds}~\$RM $last_robj\" fi func_append delfiles " $output" else output= fi if ${skipped_export-false}; then func_verbose "generating symbol list for \`$libname.la'" export_symbols="$output_objdir/$libname.exp" $opt_dry_run || $RM $export_symbols libobjs=$output # Append the command to create the export file. test -z "$concat_cmds" || concat_cmds=$concat_cmds~ eval concat_cmds=\"\$concat_cmds$export_symbols_cmds\" if test -n "$last_robj"; then eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" fi fi test -n "$save_libobjs" && func_verbose "creating a temporary reloadable object file: $output" # Loop through the commands generated above and execute them. save_ifs="$IFS"; IFS='~' for cmd in $concat_cmds; do IFS="$save_ifs" $opt_silent || { func_quote_for_expand "$cmd" eval "func_echo $func_quote_for_expand_result" } $opt_dry_run || eval "$cmd" || { lt_exit=$? # Restore the uninstalled library and exit if test "$opt_mode" = relink; then ( cd "$output_objdir" && \ $RM "${realname}T" && \ $MV "${realname}U" "$realname" ) fi exit $lt_exit } done IFS="$save_ifs" if test -n "$export_symbols_regex" && ${skipped_export-false}; then func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' func_show_eval '$MV "${export_symbols}T" "$export_symbols"' fi fi if ${skipped_export-false}; then if test -n "$export_symbols" && test -n "$include_expsyms"; then tmp_export_symbols="$export_symbols" test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols" $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"' fi if test -n "$orig_export_symbols"; then # The given exports_symbols file has to be filtered, so filter it. func_verbose "filter symbol list for \`$libname.la' to tag DATA exports" # FIXME: $output_objdir/$libname.filter potentially contains lots of # 's' commands which not all seds can handle. GNU sed should be fine # though. Also, the filter scales superlinearly with the number of # global variables. join(1) would be nice here, but unfortunately # isn't a blessed tool. $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter func_append delfiles " $export_symbols $output_objdir/$libname.filter" export_symbols=$output_objdir/$libname.def $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols fi fi libobjs=$output # Restore the value of output. output=$save_output if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then eval libobjs=\"\$libobjs $whole_archive_flag_spec\" test "X$libobjs" = "X " && libobjs= fi # Expand the library linking commands again to reset the # value of $libobjs for piecewise linking. # Do each of the archive commands. if test "$module" = yes && test -n "$module_cmds" ; then if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then cmds=$module_expsym_cmds else cmds=$module_cmds fi else if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then cmds=$archive_expsym_cmds else cmds=$archive_cmds fi fi fi if test -n "$delfiles"; then # Append the command to remove temporary files to $cmds. eval cmds=\"\$cmds~\$RM $delfiles\" fi # Add any objects from preloaded convenience libraries if test -n "$dlprefiles"; then gentop="$output_objdir/${outputname}x" func_append generated " $gentop" func_extract_archives $gentop $dlprefiles func_append libobjs " $func_extract_archives_result" test "X$libobjs" = "X " && libobjs= fi save_ifs="$IFS"; IFS='~' for cmd in $cmds; do IFS="$save_ifs" eval cmd=\"$cmd\" $opt_silent || { func_quote_for_expand "$cmd" eval "func_echo $func_quote_for_expand_result" } $opt_dry_run || eval "$cmd" || { lt_exit=$? # Restore the uninstalled library and exit if test "$opt_mode" = relink; then ( cd "$output_objdir" && \ $RM "${realname}T" && \ $MV "${realname}U" "$realname" ) fi exit $lt_exit } done IFS="$save_ifs" # Restore the uninstalled library and exit if test "$opt_mode" = relink; then $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $? if test -n "$convenience"; then if test -z "$whole_archive_flag_spec"; then func_show_eval '${RM}r "$gentop"' fi fi exit $EXIT_SUCCESS fi # Create links to the real library. for linkname in $linknames; do if test "$realname" != "$linkname"; then func_show_eval '(cd "$output_objdir" && $RM "$linkname" && $LN_S "$realname" "$linkname")' 'exit $?' fi done # If -module or -export-dynamic was specified, set the dlname. if test "$module" = yes || test "$export_dynamic" = yes; then # On all known operating systems, these are identical. dlname="$soname" fi fi ;; obj) if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then func_warning "\`-dlopen' is ignored for objects" fi case " $deplibs" in *\ -l* | *\ -L*) func_warning "\`-l' and \`-L' are ignored for objects" ;; esac test -n "$rpath" && \ func_warning "\`-rpath' is ignored for objects" test -n "$xrpath" && \ func_warning "\`-R' is ignored for objects" test -n "$vinfo" && \ func_warning "\`-version-info' is ignored for objects" test -n "$release" && \ func_warning "\`-release' is ignored for objects" case $output in *.lo) test -n "$objs$old_deplibs" && \ func_fatal_error "cannot build library object \`$output' from non-libtool objects" libobj=$output func_lo2o "$libobj" obj=$func_lo2o_result ;; *) libobj= obj="$output" ;; esac # Delete the old objects. $opt_dry_run || $RM $obj $libobj # Objects from convenience libraries. This assumes # single-version convenience libraries. Whenever we create # different ones for PIC/non-PIC, this we'll have to duplicate # the extraction. reload_conv_objs= gentop= # reload_cmds runs $LD directly, so let us get rid of # -Wl from whole_archive_flag_spec and hope we can get by with # turning comma into space.. wl= if test -n "$convenience"; then if test -n "$whole_archive_flag_spec"; then eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\" reload_conv_objs=$reload_objs\ `$ECHO "$tmp_whole_archive_flags" | $SED 's|,| |g'` else gentop="$output_objdir/${obj}x" func_append generated " $gentop" func_extract_archives $gentop $convenience reload_conv_objs="$reload_objs $func_extract_archives_result" fi fi # If we're not building shared, we need to use non_pic_objs test "$build_libtool_libs" != yes && libobjs="$non_pic_objects" # Create the old-style object. reload_objs="$objs$old_deplibs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.${libext}$/d; /\.lib$/d; $lo2o" | $NL2SP`" $reload_conv_objs" ### testsuite: skip nested quoting test output="$obj" func_execute_cmds "$reload_cmds" 'exit $?' # Exit if we aren't doing a library object file. if test -z "$libobj"; then if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi exit $EXIT_SUCCESS fi if test "$build_libtool_libs" != yes; then if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi # Create an invalid libtool object if no PIC, so that we don't # accidentally link it into a program. # $show "echo timestamp > $libobj" # $opt_dry_run || eval "echo timestamp > $libobj" || exit $? exit $EXIT_SUCCESS fi if test -n "$pic_flag" || test "$pic_mode" != default; then # Only do commands if we really have different PIC objects. reload_objs="$libobjs $reload_conv_objs" output="$libobj" func_execute_cmds "$reload_cmds" 'exit $?' fi if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi exit $EXIT_SUCCESS ;; prog) case $host in *cygwin*) func_stripname '' '.exe' "$output" output=$func_stripname_result.exe;; esac test -n "$vinfo" && \ func_warning "\`-version-info' is ignored for programs" test -n "$release" && \ func_warning "\`-release' is ignored for programs" test "$preload" = yes \ && test "$dlopen_support" = unknown \ && test "$dlopen_self" = unknown \ && test "$dlopen_self_static" = unknown && \ func_warning "\`LT_INIT([dlopen])' not used. Assuming no dlopen support." case $host in *-*-rhapsody* | *-*-darwin1.[012]) # On Rhapsody replace the C library is the System framework compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's/ -lc / System.ltframework /'` finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's/ -lc / System.ltframework /'` ;; esac case $host in *-*-darwin*) # Don't allow lazy linking, it breaks C++ global constructors # But is supposedly fixed on 10.4 or later (yay!). if test "$tagname" = CXX ; then case ${MACOSX_DEPLOYMENT_TARGET-10.0} in 10.[0123]) func_append compile_command " ${wl}-bind_at_load" func_append finalize_command " ${wl}-bind_at_load" ;; esac fi # Time to change all our "foo.ltframework" stuff back to "-framework foo" compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` ;; esac # move library search paths that coincide with paths to not yet # installed libraries to the beginning of the library search list new_libs= for path in $notinst_path; do case " $new_libs " in *" -L$path/$objdir "*) ;; *) case " $compile_deplibs " in *" -L$path/$objdir "*) func_append new_libs " -L$path/$objdir" ;; esac ;; esac done for deplib in $compile_deplibs; do case $deplib in -L*) case " $new_libs " in *" $deplib "*) ;; *) func_append new_libs " $deplib" ;; esac ;; *) func_append new_libs " $deplib" ;; esac done compile_deplibs="$new_libs" func_append compile_command " $compile_deplibs" func_append finalize_command " $finalize_deplibs" if test -n "$rpath$xrpath"; then # If the user specified any rpath flags, then add them. for libdir in $rpath $xrpath; do # This is the magic to use -rpath. case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac done fi # Now hardcode the library paths rpath= hardcode_libdirs= for libdir in $compile_rpath $finalize_rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then if test -z "$hardcode_libdirs"; then hardcode_libdirs="$libdir" else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append rpath " $flag" fi elif test -n "$runpath_var"; then case "$perm_rpath " in *" $libdir "*) ;; *) func_append perm_rpath " $libdir" ;; esac fi case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) testbindir=`${ECHO} "$libdir" | ${SED} -e 's*/lib$*/bin*'` case :$dllsearchpath: in *":$libdir:"*) ;; ::) dllsearchpath=$libdir;; *) func_append dllsearchpath ":$libdir";; esac case :$dllsearchpath: in *":$testbindir:"*) ;; ::) dllsearchpath=$testbindir;; *) func_append dllsearchpath ":$testbindir";; esac ;; esac done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir="$hardcode_libdirs" eval rpath=\" $hardcode_libdir_flag_spec\" fi compile_rpath="$rpath" rpath= hardcode_libdirs= for libdir in $finalize_rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then if test -z "$hardcode_libdirs"; then hardcode_libdirs="$libdir" else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append rpath " $flag" fi elif test -n "$runpath_var"; then case "$finalize_perm_rpath " in *" $libdir "*) ;; *) func_append finalize_perm_rpath " $libdir" ;; esac fi done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir="$hardcode_libdirs" eval rpath=\" $hardcode_libdir_flag_spec\" fi finalize_rpath="$rpath" if test -n "$libobjs" && test "$build_old_libs" = yes; then # Transform all the library objects into standard objects. compile_command=`$ECHO "$compile_command" | $SP2NL | $SED "$lo2o" | $NL2SP` finalize_command=`$ECHO "$finalize_command" | $SP2NL | $SED "$lo2o" | $NL2SP` fi func_generate_dlsyms "$outputname" "@PROGRAM@" "no" # template prelinking step if test -n "$prelink_cmds"; then func_execute_cmds "$prelink_cmds" 'exit $?' fi wrappers_required=yes case $host in *cegcc* | *mingw32ce*) # Disable wrappers for cegcc and mingw32ce hosts, we are cross compiling anyway. wrappers_required=no ;; *cygwin* | *mingw* ) if test "$build_libtool_libs" != yes; then wrappers_required=no fi ;; *) if test "$need_relink" = no || test "$build_libtool_libs" != yes; then wrappers_required=no fi ;; esac if test "$wrappers_required" = no; then # Replace the output file specification. compile_command=`$ECHO "$compile_command" | $SED 's%@OUTPUT@%'"$output"'%g'` link_command="$compile_command$compile_rpath" # We have no uninstalled library dependencies, so finalize right now. exit_status=0 func_show_eval "$link_command" 'exit_status=$?' if test -n "$postlink_cmds"; then func_to_tool_file "$output" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi # Delete the generated files. if test -f "$output_objdir/${outputname}S.${objext}"; then func_show_eval '$RM "$output_objdir/${outputname}S.${objext}"' fi exit $exit_status fi if test -n "$compile_shlibpath$finalize_shlibpath"; then compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command" fi if test -n "$finalize_shlibpath"; then finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command" fi compile_var= finalize_var= if test -n "$runpath_var"; then if test -n "$perm_rpath"; then # We should set the runpath_var. rpath= for dir in $perm_rpath; do func_append rpath "$dir:" done compile_var="$runpath_var=\"$rpath\$$runpath_var\" " fi if test -n "$finalize_perm_rpath"; then # We should set the runpath_var. rpath= for dir in $finalize_perm_rpath; do func_append rpath "$dir:" done finalize_var="$runpath_var=\"$rpath\$$runpath_var\" " fi fi if test "$no_install" = yes; then # We don't need to create a wrapper script. link_command="$compile_var$compile_command$compile_rpath" # Replace the output file specification. link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output"'%g'` # Delete the old output file. $opt_dry_run || $RM $output # Link the executable and exit func_show_eval "$link_command" 'exit $?' if test -n "$postlink_cmds"; then func_to_tool_file "$output" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi exit $EXIT_SUCCESS fi if test "$hardcode_action" = relink; then # Fast installation is not supported link_command="$compile_var$compile_command$compile_rpath" relink_command="$finalize_var$finalize_command$finalize_rpath" func_warning "this platform does not like uninstalled shared libraries" func_warning "\`$output' will be relinked during installation" else if test "$fast_install" != no; then link_command="$finalize_var$compile_command$finalize_rpath" if test "$fast_install" = yes; then relink_command=`$ECHO "$compile_var$compile_command$compile_rpath" | $SED 's%@OUTPUT@%\$progdir/\$file%g'` else # fast_install is set to needless relink_command= fi else link_command="$compile_var$compile_command$compile_rpath" relink_command="$finalize_var$finalize_command$finalize_rpath" fi fi # Replace the output file specification. link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'` # Delete the old output files. $opt_dry_run || $RM $output $output_objdir/$outputname $output_objdir/lt-$outputname func_show_eval "$link_command" 'exit $?' if test -n "$postlink_cmds"; then func_to_tool_file "$output_objdir/$outputname" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi # Now create the wrapper script. func_verbose "creating $output" # Quote the relink command for shipping. if test -n "$relink_command"; then # Preserve any variables that may affect compiler behavior for var in $variables_saved_for_relink; do if eval test -z \"\${$var+set}\"; then relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" elif eval var_value=\$$var; test -z "$var_value"; then relink_command="$var=; export $var; $relink_command" else func_quote_for_eval "$var_value" relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command" fi done relink_command="(cd `pwd`; $relink_command)" relink_command=`$ECHO "$relink_command" | $SED "$sed_quote_subst"` fi # Only actually do things if not in dry run mode. $opt_dry_run || { # win32 will think the script is a binary if it has # a .exe suffix, so we strip it off here. case $output in *.exe) func_stripname '' '.exe' "$output" output=$func_stripname_result ;; esac # test for cygwin because mv fails w/o .exe extensions case $host in *cygwin*) exeext=.exe func_stripname '' '.exe' "$outputname" outputname=$func_stripname_result ;; *) exeext= ;; esac case $host in *cygwin* | *mingw* ) func_dirname_and_basename "$output" "" "." output_name=$func_basename_result output_path=$func_dirname_result cwrappersource="$output_path/$objdir/lt-$output_name.c" cwrapper="$output_path/$output_name.exe" $RM $cwrappersource $cwrapper trap "$RM $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15 func_emit_cwrapperexe_src > $cwrappersource # The wrapper executable is built using the $host compiler, # because it contains $host paths and files. If cross- # compiling, it, like the target executable, must be # executed on the $host or under an emulation environment. $opt_dry_run || { $LTCC $LTCFLAGS -o $cwrapper $cwrappersource $STRIP $cwrapper } # Now, create the wrapper script for func_source use: func_ltwrapper_scriptname $cwrapper $RM $func_ltwrapper_scriptname_result trap "$RM $func_ltwrapper_scriptname_result; exit $EXIT_FAILURE" 1 2 15 $opt_dry_run || { # note: this script will not be executed, so do not chmod. if test "x$build" = "x$host" ; then $cwrapper --lt-dump-script > $func_ltwrapper_scriptname_result else func_emit_wrapper no > $func_ltwrapper_scriptname_result fi } ;; * ) $RM $output trap "$RM $output; exit $EXIT_FAILURE" 1 2 15 func_emit_wrapper no > $output chmod +x $output ;; esac } exit $EXIT_SUCCESS ;; esac # See if we need to build an old-fashioned archive. for oldlib in $oldlibs; do if test "$build_libtool_libs" = convenience; then oldobjs="$libobjs_save $symfileobj" addlibs="$convenience" build_libtool_libs=no else if test "$build_libtool_libs" = module; then oldobjs="$libobjs_save" build_libtool_libs=no else oldobjs="$old_deplibs $non_pic_objects" if test "$preload" = yes && test -f "$symfileobj"; then func_append oldobjs " $symfileobj" fi fi addlibs="$old_convenience" fi if test -n "$addlibs"; then gentop="$output_objdir/${outputname}x" func_append generated " $gentop" func_extract_archives $gentop $addlibs func_append oldobjs " $func_extract_archives_result" fi # Do each command in the archive commands. if test -n "$old_archive_from_new_cmds" && test "$build_libtool_libs" = yes; then cmds=$old_archive_from_new_cmds else # Add any objects from preloaded convenience libraries if test -n "$dlprefiles"; then gentop="$output_objdir/${outputname}x" func_append generated " $gentop" func_extract_archives $gentop $dlprefiles func_append oldobjs " $func_extract_archives_result" fi # POSIX demands no paths to be encoded in archives. We have # to avoid creating archives with duplicate basenames if we # might have to extract them afterwards, e.g., when creating a # static archive out of a convenience library, or when linking # the entirety of a libtool archive into another (currently # not supported by libtool). if (for obj in $oldobjs do func_basename "$obj" $ECHO "$func_basename_result" done | sort | sort -uc >/dev/null 2>&1); then : else echo "copying selected object files to avoid basename conflicts..." gentop="$output_objdir/${outputname}x" func_append generated " $gentop" func_mkdir_p "$gentop" save_oldobjs=$oldobjs oldobjs= counter=1 for obj in $save_oldobjs do func_basename "$obj" objbase="$func_basename_result" case " $oldobjs " in " ") oldobjs=$obj ;; *[\ /]"$objbase "*) while :; do # Make sure we don't pick an alternate name that also # overlaps. newobj=lt$counter-$objbase func_arith $counter + 1 counter=$func_arith_result case " $oldobjs " in *[\ /]"$newobj "*) ;; *) if test ! -f "$gentop/$newobj"; then break; fi ;; esac done func_show_eval "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj" func_append oldobjs " $gentop/$newobj" ;; *) func_append oldobjs " $obj" ;; esac done fi func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 tool_oldlib=$func_to_tool_file_result eval cmds=\"$old_archive_cmds\" func_len " $cmds" len=$func_len_result if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then cmds=$old_archive_cmds elif test -n "$archiver_list_spec"; then func_verbose "using command file archive linking..." for obj in $oldobjs do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" done > $output_objdir/$libname.libcmd func_to_tool_file "$output_objdir/$libname.libcmd" oldobjs=" $archiver_list_spec$func_to_tool_file_result" cmds=$old_archive_cmds else # the command line is too long to link in one step, link in parts func_verbose "using piecewise archive linking..." save_RANLIB=$RANLIB RANLIB=: objlist= concat_cmds= save_oldobjs=$oldobjs oldobjs= # Is there a better way of finding the last object in the list? for obj in $save_oldobjs do last_oldobj=$obj done eval test_cmds=\"$old_archive_cmds\" func_len " $test_cmds" len0=$func_len_result len=$len0 for obj in $save_oldobjs do func_len " $obj" func_arith $len + $func_len_result len=$func_arith_result func_append objlist " $obj" if test "$len" -lt "$max_cmd_len"; then : else # the above command should be used before it gets too long oldobjs=$objlist if test "$obj" = "$last_oldobj" ; then RANLIB=$save_RANLIB fi test -z "$concat_cmds" || concat_cmds=$concat_cmds~ eval concat_cmds=\"\${concat_cmds}$old_archive_cmds\" objlist= len=$len0 fi done RANLIB=$save_RANLIB oldobjs=$objlist if test "X$oldobjs" = "X" ; then eval cmds=\"\$concat_cmds\" else eval cmds=\"\$concat_cmds~\$old_archive_cmds\" fi fi fi func_execute_cmds "$cmds" 'exit $?' done test -n "$generated" && \ func_show_eval "${RM}r$generated" # Now create the libtool archive. case $output in *.la) old_library= test "$build_old_libs" = yes && old_library="$libname.$libext" func_verbose "creating $output" # Preserve any variables that may affect compiler behavior for var in $variables_saved_for_relink; do if eval test -z \"\${$var+set}\"; then relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" elif eval var_value=\$$var; test -z "$var_value"; then relink_command="$var=; export $var; $relink_command" else func_quote_for_eval "$var_value" relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command" fi done # Quote the link command for shipping. relink_command="(cd `pwd`; $SHELL $progpath $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)" relink_command=`$ECHO "$relink_command" | $SED "$sed_quote_subst"` if test "$hardcode_automatic" = yes ; then relink_command= fi # Only create the output if not a dry run. $opt_dry_run || { for installed in no yes; do if test "$installed" = yes; then if test -z "$install_libdir"; then break fi output="$output_objdir/$outputname"i # Replace all uninstalled libtool libraries with the installed ones newdependency_libs= for deplib in $dependency_libs; do case $deplib in *.la) func_basename "$deplib" name="$func_basename_result" func_resolve_sysroot "$deplib" eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $func_resolve_sysroot_result` test -z "$libdir" && \ func_fatal_error "\`$deplib' is not a valid libtool archive" func_append newdependency_libs " ${lt_sysroot:+=}$libdir/$name" ;; -L*) func_stripname -L '' "$deplib" func_replace_sysroot "$func_stripname_result" func_append newdependency_libs " -L$func_replace_sysroot_result" ;; -R*) func_stripname -R '' "$deplib" func_replace_sysroot "$func_stripname_result" func_append newdependency_libs " -R$func_replace_sysroot_result" ;; *) func_append newdependency_libs " $deplib" ;; esac done dependency_libs="$newdependency_libs" newdlfiles= for lib in $dlfiles; do case $lib in *.la) func_basename "$lib" name="$func_basename_result" eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib` test -z "$libdir" && \ func_fatal_error "\`$lib' is not a valid libtool archive" func_append newdlfiles " ${lt_sysroot:+=}$libdir/$name" ;; *) func_append newdlfiles " $lib" ;; esac done dlfiles="$newdlfiles" newdlprefiles= for lib in $dlprefiles; do case $lib in *.la) # Only pass preopened files to the pseudo-archive (for # eventual linking with the app. that links it) if we # didn't already link the preopened objects directly into # the library: func_basename "$lib" name="$func_basename_result" eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib` test -z "$libdir" && \ func_fatal_error "\`$lib' is not a valid libtool archive" func_append newdlprefiles " ${lt_sysroot:+=}$libdir/$name" ;; esac done dlprefiles="$newdlprefiles" else newdlfiles= for lib in $dlfiles; do case $lib in [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;; *) abs=`pwd`"/$lib" ;; esac func_append newdlfiles " $abs" done dlfiles="$newdlfiles" newdlprefiles= for lib in $dlprefiles; do case $lib in [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;; *) abs=`pwd`"/$lib" ;; esac func_append newdlprefiles " $abs" done dlprefiles="$newdlprefiles" fi $RM $output # place dlname in correct position for cygwin # In fact, it would be nice if we could use this code for all target # systems that can't hard-code library paths into their executables # and that have no shared library path variable independent of PATH, # but it turns out we can't easily determine that from inspecting # libtool variables, so we have to hard-code the OSs to which it # applies here; at the moment, that means platforms that use the PE # object format with DLL files. See the long comment at the top of # tests/bindir.at for full details. tdlname=$dlname case $host,$output,$installed,$module,$dlname in *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll) # If a -bindir argument was supplied, place the dll there. if test "x$bindir" != x ; then func_relative_path "$install_libdir" "$bindir" tdlname=$func_relative_path_result$dlname else # Otherwise fall back on heuristic. tdlname=../bin/$dlname fi ;; esac $ECHO > $output "\ # $outputname - a libtool library file # Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION # # Please DO NOT delete this file! # It is necessary for linking the library. # The name that we can dlopen(3). dlname='$tdlname' # Names of this library. library_names='$library_names' # The name of the static archive. old_library='$old_library' # Linker flags that can not go in dependency_libs. inherited_linker_flags='$new_inherited_linker_flags' # Libraries that this one depends upon. dependency_libs='$dependency_libs' # Names of additional weak libraries provided by this library weak_library_names='$weak_libs' # Version information for $libname. current=$current age=$age revision=$revision # Is this an already installed library? installed=$installed # Should we warn about portability when linking against -modules? shouldnotlink=$module # Files to dlopen/dlpreopen dlopen='$dlfiles' dlpreopen='$dlprefiles' # Directory that this library needs to be installed in: libdir='$install_libdir'" if test "$installed" = no && test "$need_relink" = yes; then $ECHO >> $output "\ relink_command=\"$relink_command\"" fi done } # Do a symbolic link so that the libtool archive can be found in # LD_LIBRARY_PATH before the program is installed. func_show_eval '( cd "$output_objdir" && $RM "$outputname" && $LN_S "../$outputname" "$outputname" )' 'exit $?' ;; esac exit $EXIT_SUCCESS } { test "$opt_mode" = link || test "$opt_mode" = relink; } && func_mode_link ${1+"$@"} # func_mode_uninstall arg... func_mode_uninstall () { $opt_debug RM="$nonopt" files= rmforce= exit_status=0 # This variable tells wrapper scripts just to set variables rather # than running their programs. libtool_install_magic="$magic" for arg do case $arg in -f) func_append RM " $arg"; rmforce=yes ;; -*) func_append RM " $arg" ;; *) func_append files " $arg" ;; esac done test -z "$RM" && \ func_fatal_help "you must specify an RM program" rmdirs= for file in $files; do func_dirname "$file" "" "." dir="$func_dirname_result" if test "X$dir" = X.; then odir="$objdir" else odir="$dir/$objdir" fi func_basename "$file" name="$func_basename_result" test "$opt_mode" = uninstall && odir="$dir" # Remember odir for removal later, being careful to avoid duplicates if test "$opt_mode" = clean; then case " $rmdirs " in *" $odir "*) ;; *) func_append rmdirs " $odir" ;; esac fi # Don't error if the file doesn't exist and rm -f was used. if { test -L "$file"; } >/dev/null 2>&1 || { test -h "$file"; } >/dev/null 2>&1 || test -f "$file"; then : elif test -d "$file"; then exit_status=1 continue elif test "$rmforce" = yes; then continue fi rmfiles="$file" case $name in *.la) # Possibly a libtool archive, so verify it. if func_lalib_p "$file"; then func_source $dir/$name # Delete the libtool libraries and symlinks. for n in $library_names; do func_append rmfiles " $odir/$n" done test -n "$old_library" && func_append rmfiles " $odir/$old_library" case "$opt_mode" in clean) case " $library_names " in *" $dlname "*) ;; *) test -n "$dlname" && func_append rmfiles " $odir/$dlname" ;; esac test -n "$libdir" && func_append rmfiles " $odir/$name $odir/${name}i" ;; uninstall) if test -n "$library_names"; then # Do each command in the postuninstall commands. func_execute_cmds "$postuninstall_cmds" 'test "$rmforce" = yes || exit_status=1' fi if test -n "$old_library"; then # Do each command in the old_postuninstall commands. func_execute_cmds "$old_postuninstall_cmds" 'test "$rmforce" = yes || exit_status=1' fi # FIXME: should reinstall the best remaining shared library. ;; esac fi ;; *.lo) # Possibly a libtool object, so verify it. if func_lalib_p "$file"; then # Read the .lo file func_source $dir/$name # Add PIC object to the list of files to remove. if test -n "$pic_object" && test "$pic_object" != none; then func_append rmfiles " $dir/$pic_object" fi # Add non-PIC object to the list of files to remove. if test -n "$non_pic_object" && test "$non_pic_object" != none; then func_append rmfiles " $dir/$non_pic_object" fi fi ;; *) if test "$opt_mode" = clean ; then noexename=$name case $file in *.exe) func_stripname '' '.exe' "$file" file=$func_stripname_result func_stripname '' '.exe' "$name" noexename=$func_stripname_result # $file with .exe has already been added to rmfiles, # add $file without .exe func_append rmfiles " $file" ;; esac # Do a test to see if this is a libtool program. if func_ltwrapper_p "$file"; then if func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" relink_command= func_source $func_ltwrapper_scriptname_result func_append rmfiles " $func_ltwrapper_scriptname_result" else relink_command= func_source $dir/$noexename fi # note $name still contains .exe if it was in $file originally # as does the version of $file that was added into $rmfiles func_append rmfiles " $odir/$name $odir/${name}S.${objext}" if test "$fast_install" = yes && test -n "$relink_command"; then func_append rmfiles " $odir/lt-$name" fi if test "X$noexename" != "X$name" ; then func_append rmfiles " $odir/lt-${noexename}.c" fi fi fi ;; esac func_show_eval "$RM $rmfiles" 'exit_status=1' done # Try to remove the ${objdir}s in the directories where we deleted files for dir in $rmdirs; do if test -d "$dir"; then func_show_eval "rmdir $dir >/dev/null 2>&1" fi done exit $exit_status } { test "$opt_mode" = uninstall || test "$opt_mode" = clean; } && func_mode_uninstall ${1+"$@"} test -z "$opt_mode" && { help="$generic_help" func_fatal_help "you must specify a MODE" } test -z "$exec_cmd" && \ func_fatal_help "invalid operation mode \`$opt_mode'" if test -n "$exec_cmd"; then eval exec "$exec_cmd" exit $EXIT_FAILURE fi exit $exit_status # The TAGs below are defined such that we never get into a situation # in which we disable both kinds of libraries. Given conflicting # choices, we go for a static library, that is the most portable, # since we can't tell whether shared libraries were disabled because # the user asked for that or because the platform doesn't support # them. This is particularly important on AIX, because we don't # support having both static and shared libraries enabled at the same # time on that platform, so we default to a shared-only configuration. # If a disable-shared tag is given, we'll fallback to a static-only # configuration. But we'll never go from static-only to shared-only. # ### BEGIN LIBTOOL TAG CONFIG: disable-shared build_libtool_libs=no build_old_libs=yes # ### END LIBTOOL TAG CONFIG: disable-shared # ### BEGIN LIBTOOL TAG CONFIG: disable-static build_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac` # ### END LIBTOOL TAG CONFIG: disable-static # Local Variables: # mode:shell-script # sh-indentation:2 # End: # vi:sw=2 eztrace-1.1-2/m4/000077500000000000000000000000001265506773700135115ustar00rootroot00000000000000eztrace-1.1-2/m4/libtool.m4000066400000000000000000010601111265506773700154170ustar00rootroot00000000000000# libtool.m4 - Configure libtool for the host system. -*-Autoconf-*- # # Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, # 2006, 2007, 2008, 2009, 2010, 2011 Free Software # Foundation, Inc. # Written by Gordon Matzigkeit, 1996 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. m4_define([_LT_COPYING], [dnl # Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, # 2006, 2007, 2008, 2009, 2010, 2011 Free Software # Foundation, Inc. # Written by Gordon Matzigkeit, 1996 # # This file is part of GNU Libtool. # # GNU Libtool is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License as # published by the Free Software Foundation; either version 2 of # the License, or (at your option) any later version. # # As a special exception to the GNU General Public License, # if you distribute this file as part of a program or library that # is built using GNU Libtool, you may include this file under the # same distribution terms that you use for the rest of that program. # # GNU Libtool is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with GNU Libtool; see the file COPYING. If not, a copy # can be downloaded from http://www.gnu.org/licenses/gpl.html, or # obtained by writing to the Free Software Foundation, Inc., # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. ]) # serial 57 LT_INIT # LT_PREREQ(VERSION) # ------------------ # Complain and exit if this libtool version is less that VERSION. m4_defun([LT_PREREQ], [m4_if(m4_version_compare(m4_defn([LT_PACKAGE_VERSION]), [$1]), -1, [m4_default([$3], [m4_fatal([Libtool version $1 or higher is required], 63)])], [$2])]) # _LT_CHECK_BUILDDIR # ------------------ # Complain if the absolute build directory name contains unusual characters m4_defun([_LT_CHECK_BUILDDIR], [case `pwd` in *\ * | *\ *) AC_MSG_WARN([Libtool does not cope well with whitespace in `pwd`]) ;; esac ]) # LT_INIT([OPTIONS]) # ------------------ AC_DEFUN([LT_INIT], [AC_PREREQ([2.58])dnl We use AC_INCLUDES_DEFAULT AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl AC_BEFORE([$0], [LT_LANG])dnl AC_BEFORE([$0], [LT_OUTPUT])dnl AC_BEFORE([$0], [LTDL_INIT])dnl m4_require([_LT_CHECK_BUILDDIR])dnl dnl Autoconf doesn't catch unexpanded LT_ macros by default: m4_pattern_forbid([^_?LT_[A-Z_]+$])dnl m4_pattern_allow([^(_LT_EOF|LT_DLGLOBAL|LT_DLLAZY_OR_NOW|LT_MULTI_MODULE)$])dnl dnl aclocal doesn't pull ltoptions.m4, ltsugar.m4, or ltversion.m4 dnl unless we require an AC_DEFUNed macro: AC_REQUIRE([LTOPTIONS_VERSION])dnl AC_REQUIRE([LTSUGAR_VERSION])dnl AC_REQUIRE([LTVERSION_VERSION])dnl AC_REQUIRE([LTOBSOLETE_VERSION])dnl m4_require([_LT_PROG_LTMAIN])dnl _LT_SHELL_INIT([SHELL=${CONFIG_SHELL-/bin/sh}]) dnl Parse OPTIONS _LT_SET_OPTIONS([$0], [$1]) # This can be used to rebuild libtool when needed LIBTOOL_DEPS="$ltmain" # Always use our own libtool. LIBTOOL='$(SHELL) $(top_builddir)/libtool' AC_SUBST(LIBTOOL)dnl _LT_SETUP # Only expand once: m4_define([LT_INIT]) ])# LT_INIT # Old names: AU_ALIAS([AC_PROG_LIBTOOL], [LT_INIT]) AU_ALIAS([AM_PROG_LIBTOOL], [LT_INIT]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_PROG_LIBTOOL], []) dnl AC_DEFUN([AM_PROG_LIBTOOL], []) # _LT_CC_BASENAME(CC) # ------------------- # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. m4_defun([_LT_CC_BASENAME], [for cc_temp in $1""; do case $cc_temp in compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;; distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;; \-*) ;; *) break;; esac done cc_basename=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` ]) # _LT_FILEUTILS_DEFAULTS # ---------------------- # It is okay to use these file commands and assume they have been set # sensibly after `m4_require([_LT_FILEUTILS_DEFAULTS])'. m4_defun([_LT_FILEUTILS_DEFAULTS], [: ${CP="cp -f"} : ${MV="mv -f"} : ${RM="rm -f"} ])# _LT_FILEUTILS_DEFAULTS # _LT_SETUP # --------- m4_defun([_LT_SETUP], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl AC_REQUIRE([_LT_PREPARE_SED_QUOTE_VARS])dnl AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl _LT_DECL([], [PATH_SEPARATOR], [1], [The PATH separator for the build system])dnl dnl _LT_DECL([], [host_alias], [0], [The host system])dnl _LT_DECL([], [host], [0])dnl _LT_DECL([], [host_os], [0])dnl dnl _LT_DECL([], [build_alias], [0], [The build system])dnl _LT_DECL([], [build], [0])dnl _LT_DECL([], [build_os], [0])dnl dnl AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([LT_PATH_LD])dnl AC_REQUIRE([LT_PATH_NM])dnl dnl AC_REQUIRE([AC_PROG_LN_S])dnl test -z "$LN_S" && LN_S="ln -s" _LT_DECL([], [LN_S], [1], [Whether we need soft or hard links])dnl dnl AC_REQUIRE([LT_CMD_MAX_LEN])dnl _LT_DECL([objext], [ac_objext], [0], [Object file suffix (normally "o")])dnl _LT_DECL([], [exeext], [0], [Executable file suffix (normally "")])dnl dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_CHECK_SHELL_FEATURES])dnl m4_require([_LT_PATH_CONVERSION_FUNCTIONS])dnl m4_require([_LT_CMD_RELOAD])dnl m4_require([_LT_CHECK_MAGIC_METHOD])dnl m4_require([_LT_CHECK_SHAREDLIB_FROM_LINKLIB])dnl m4_require([_LT_CMD_OLD_ARCHIVE])dnl m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl m4_require([_LT_WITH_SYSROOT])dnl _LT_CONFIG_LIBTOOL_INIT([ # See if we are running on zsh, and set the options which allow our # commands through without removal of \ escapes INIT. if test -n "\${ZSH_VERSION+set}" ; then setopt NO_GLOB_SUBST fi ]) if test -n "${ZSH_VERSION+set}" ; then setopt NO_GLOB_SUBST fi _LT_CHECK_OBJDIR m4_require([_LT_TAG_COMPILER])dnl case $host_os in aix3*) # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test "X${COLLECT_NAMES+set}" != Xset; then COLLECT_NAMES= export COLLECT_NAMES fi ;; esac # Global variables: ofile=libtool can_build_shared=yes # All known linkers require a `.a' archive for static linking (except MSVC, # which needs '.lib'). libext=a with_gnu_ld="$lt_cv_prog_gnu_ld" old_CC="$CC" old_CFLAGS="$CFLAGS" # Set sane defaults for various variables test -z "$CC" && CC=cc test -z "$LTCC" && LTCC=$CC test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS test -z "$LD" && LD=ld test -z "$ac_objext" && ac_objext=o _LT_CC_BASENAME([$compiler]) # Only perform the check for file, if the check method requires it test -z "$MAGIC_CMD" && MAGIC_CMD=file case $deplibs_check_method in file_magic*) if test "$file_magic_cmd" = '$MAGIC_CMD'; then _LT_PATH_MAGIC fi ;; esac # Use C for the default configuration in the libtool script LT_SUPPORTED_TAG([CC]) _LT_LANG_C_CONFIG _LT_LANG_DEFAULT_CONFIG _LT_CONFIG_COMMANDS ])# _LT_SETUP # _LT_PREPARE_SED_QUOTE_VARS # -------------------------- # Define a few sed substitution that help us do robust quoting. m4_defun([_LT_PREPARE_SED_QUOTE_VARS], [# Backslashify metacharacters that are still active within # double-quoted strings. sed_quote_subst='s/\([["`$\\]]\)/\\\1/g' # Same as above, but do not quote variable references. double_quote_subst='s/\([["`\\]]\)/\\\1/g' # Sed substitution to delay expansion of an escaped shell variable in a # double_quote_subst'ed string. delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' # Sed substitution to delay expansion of an escaped single quote. delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' # Sed substitution to avoid accidental globbing in evaled expressions no_glob_subst='s/\*/\\\*/g' ]) # _LT_PROG_LTMAIN # --------------- # Note that this code is called both from `configure', and `config.status' # now that we use AC_CONFIG_COMMANDS to generate libtool. Notably, # `config.status' has no value for ac_aux_dir unless we are using Automake, # so we pass a copy along to make sure it has a sensible value anyway. m4_defun([_LT_PROG_LTMAIN], [m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([ltmain.sh])])dnl _LT_CONFIG_LIBTOOL_INIT([ac_aux_dir='$ac_aux_dir']) ltmain="$ac_aux_dir/ltmain.sh" ])# _LT_PROG_LTMAIN ## ------------------------------------- ## ## Accumulate code for creating libtool. ## ## ------------------------------------- ## # So that we can recreate a full libtool script including additional # tags, we accumulate the chunks of code to send to AC_CONFIG_COMMANDS # in macros and then make a single call at the end using the `libtool' # label. # _LT_CONFIG_LIBTOOL_INIT([INIT-COMMANDS]) # ---------------------------------------- # Register INIT-COMMANDS to be passed to AC_CONFIG_COMMANDS later. m4_define([_LT_CONFIG_LIBTOOL_INIT], [m4_ifval([$1], [m4_append([_LT_OUTPUT_LIBTOOL_INIT], [$1 ])])]) # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_INIT]) # _LT_CONFIG_LIBTOOL([COMMANDS]) # ------------------------------ # Register COMMANDS to be passed to AC_CONFIG_COMMANDS later. m4_define([_LT_CONFIG_LIBTOOL], [m4_ifval([$1], [m4_append([_LT_OUTPUT_LIBTOOL_COMMANDS], [$1 ])])]) # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS]) # _LT_CONFIG_SAVE_COMMANDS([COMMANDS], [INIT_COMMANDS]) # ----------------------------------------------------- m4_defun([_LT_CONFIG_SAVE_COMMANDS], [_LT_CONFIG_LIBTOOL([$1]) _LT_CONFIG_LIBTOOL_INIT([$2]) ]) # _LT_FORMAT_COMMENT([COMMENT]) # ----------------------------- # Add leading comment marks to the start of each line, and a trailing # full-stop to the whole comment if one is not present already. m4_define([_LT_FORMAT_COMMENT], [m4_ifval([$1], [ m4_bpatsubst([m4_bpatsubst([$1], [^ *], [# ])], [['`$\]], [\\\&])]m4_bmatch([$1], [[!?.]$], [], [.]) )]) ## ------------------------ ## ## FIXME: Eliminate VARNAME ## ## ------------------------ ## # _LT_DECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION], [IS-TAGGED?]) # ------------------------------------------------------------------- # CONFIGNAME is the name given to the value in the libtool script. # VARNAME is the (base) name used in the configure script. # VALUE may be 0, 1 or 2 for a computed quote escaped value based on # VARNAME. Any other value will be used directly. m4_define([_LT_DECL], [lt_if_append_uniq([lt_decl_varnames], [$2], [, ], [lt_dict_add_subkey([lt_decl_dict], [$2], [libtool_name], [m4_ifval([$1], [$1], [$2])]) lt_dict_add_subkey([lt_decl_dict], [$2], [value], [$3]) m4_ifval([$4], [lt_dict_add_subkey([lt_decl_dict], [$2], [description], [$4])]) lt_dict_add_subkey([lt_decl_dict], [$2], [tagged?], [m4_ifval([$5], [yes], [no])])]) ]) # _LT_TAGDECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION]) # -------------------------------------------------------- m4_define([_LT_TAGDECL], [_LT_DECL([$1], [$2], [$3], [$4], [yes])]) # lt_decl_tag_varnames([SEPARATOR], [VARNAME1...]) # ------------------------------------------------ m4_define([lt_decl_tag_varnames], [_lt_decl_filter([tagged?], [yes], $@)]) # _lt_decl_filter(SUBKEY, VALUE, [SEPARATOR], [VARNAME1..]) # --------------------------------------------------------- m4_define([_lt_decl_filter], [m4_case([$#], [0], [m4_fatal([$0: too few arguments: $#])], [1], [m4_fatal([$0: too few arguments: $#: $1])], [2], [lt_dict_filter([lt_decl_dict], [$1], [$2], [], lt_decl_varnames)], [3], [lt_dict_filter([lt_decl_dict], [$1], [$2], [$3], lt_decl_varnames)], [lt_dict_filter([lt_decl_dict], $@)])[]dnl ]) # lt_decl_quote_varnames([SEPARATOR], [VARNAME1...]) # -------------------------------------------------- m4_define([lt_decl_quote_varnames], [_lt_decl_filter([value], [1], $@)]) # lt_decl_dquote_varnames([SEPARATOR], [VARNAME1...]) # --------------------------------------------------- m4_define([lt_decl_dquote_varnames], [_lt_decl_filter([value], [2], $@)]) # lt_decl_varnames_tagged([SEPARATOR], [VARNAME1...]) # --------------------------------------------------- m4_define([lt_decl_varnames_tagged], [m4_assert([$# <= 2])dnl _$0(m4_quote(m4_default([$1], [[, ]])), m4_ifval([$2], [[$2]], [m4_dquote(lt_decl_tag_varnames)]), m4_split(m4_normalize(m4_quote(_LT_TAGS)), [ ]))]) m4_define([_lt_decl_varnames_tagged], [m4_ifval([$3], [lt_combine([$1], [$2], [_], $3)])]) # lt_decl_all_varnames([SEPARATOR], [VARNAME1...]) # ------------------------------------------------ m4_define([lt_decl_all_varnames], [_$0(m4_quote(m4_default([$1], [[, ]])), m4_if([$2], [], m4_quote(lt_decl_varnames), m4_quote(m4_shift($@))))[]dnl ]) m4_define([_lt_decl_all_varnames], [lt_join($@, lt_decl_varnames_tagged([$1], lt_decl_tag_varnames([[, ]], m4_shift($@))))dnl ]) # _LT_CONFIG_STATUS_DECLARE([VARNAME]) # ------------------------------------ # Quote a variable value, and forward it to `config.status' so that its # declaration there will have the same value as in `configure'. VARNAME # must have a single quote delimited value for this to work. m4_define([_LT_CONFIG_STATUS_DECLARE], [$1='`$ECHO "$][$1" | $SED "$delay_single_quote_subst"`']) # _LT_CONFIG_STATUS_DECLARATIONS # ------------------------------ # We delimit libtool config variables with single quotes, so when # we write them to config.status, we have to be sure to quote all # embedded single quotes properly. In configure, this macro expands # each variable declared with _LT_DECL (and _LT_TAGDECL) into: # # ='`$ECHO "$" | $SED "$delay_single_quote_subst"`' m4_defun([_LT_CONFIG_STATUS_DECLARATIONS], [m4_foreach([_lt_var], m4_quote(lt_decl_all_varnames), [m4_n([_LT_CONFIG_STATUS_DECLARE(_lt_var)])])]) # _LT_LIBTOOL_TAGS # ---------------- # Output comment and list of tags supported by the script m4_defun([_LT_LIBTOOL_TAGS], [_LT_FORMAT_COMMENT([The names of the tagged configurations supported by this script])dnl available_tags="_LT_TAGS"dnl ]) # _LT_LIBTOOL_DECLARE(VARNAME, [TAG]) # ----------------------------------- # Extract the dictionary values for VARNAME (optionally with TAG) and # expand to a commented shell variable setting: # # # Some comment about what VAR is for. # visible_name=$lt_internal_name m4_define([_LT_LIBTOOL_DECLARE], [_LT_FORMAT_COMMENT(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [description])))[]dnl m4_pushdef([_libtool_name], m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [libtool_name])))[]dnl m4_case(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [value])), [0], [_libtool_name=[$]$1], [1], [_libtool_name=$lt_[]$1], [2], [_libtool_name=$lt_[]$1], [_libtool_name=lt_dict_fetch([lt_decl_dict], [$1], [value])])[]dnl m4_ifval([$2], [_$2])[]m4_popdef([_libtool_name])[]dnl ]) # _LT_LIBTOOL_CONFIG_VARS # ----------------------- # Produce commented declarations of non-tagged libtool config variables # suitable for insertion in the LIBTOOL CONFIG section of the `libtool' # script. Tagged libtool config variables (even for the LIBTOOL CONFIG # section) are produced by _LT_LIBTOOL_TAG_VARS. m4_defun([_LT_LIBTOOL_CONFIG_VARS], [m4_foreach([_lt_var], m4_quote(_lt_decl_filter([tagged?], [no], [], lt_decl_varnames)), [m4_n([_LT_LIBTOOL_DECLARE(_lt_var)])])]) # _LT_LIBTOOL_TAG_VARS(TAG) # ------------------------- m4_define([_LT_LIBTOOL_TAG_VARS], [m4_foreach([_lt_var], m4_quote(lt_decl_tag_varnames), [m4_n([_LT_LIBTOOL_DECLARE(_lt_var, [$1])])])]) # _LT_TAGVAR(VARNAME, [TAGNAME]) # ------------------------------ m4_define([_LT_TAGVAR], [m4_ifval([$2], [$1_$2], [$1])]) # _LT_CONFIG_COMMANDS # ------------------- # Send accumulated output to $CONFIG_STATUS. Thanks to the lists of # variables for single and double quote escaping we saved from calls # to _LT_DECL, we can put quote escaped variables declarations # into `config.status', and then the shell code to quote escape them in # for loops in `config.status'. Finally, any additional code accumulated # from calls to _LT_CONFIG_LIBTOOL_INIT is expanded. m4_defun([_LT_CONFIG_COMMANDS], [AC_PROVIDE_IFELSE([LT_OUTPUT], dnl If the libtool generation code has been placed in $CONFIG_LT, dnl instead of duplicating it all over again into config.status, dnl then we will have config.status run $CONFIG_LT later, so it dnl needs to know what name is stored there: [AC_CONFIG_COMMANDS([libtool], [$SHELL $CONFIG_LT || AS_EXIT(1)], [CONFIG_LT='$CONFIG_LT'])], dnl If the libtool generation code is destined for config.status, dnl expand the accumulated commands and init code now: [AC_CONFIG_COMMANDS([libtool], [_LT_OUTPUT_LIBTOOL_COMMANDS], [_LT_OUTPUT_LIBTOOL_COMMANDS_INIT])]) ])#_LT_CONFIG_COMMANDS # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS_INIT], [ # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH sed_quote_subst='$sed_quote_subst' double_quote_subst='$double_quote_subst' delay_variable_subst='$delay_variable_subst' _LT_CONFIG_STATUS_DECLARATIONS LTCC='$LTCC' LTCFLAGS='$LTCFLAGS' compiler='$compiler_DEFAULT' # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$[]1 _LTECHO_EOF' } # Quote evaled strings. for var in lt_decl_all_varnames([[ \ ]], lt_decl_quote_varnames); do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[[\\\\\\\`\\"\\\$]]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done # Double-quote double-evaled strings. for var in lt_decl_all_varnames([[ \ ]], lt_decl_dquote_varnames); do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[[\\\\\\\`\\"\\\$]]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done _LT_OUTPUT_LIBTOOL_INIT ]) # _LT_GENERATED_FILE_INIT(FILE, [COMMENT]) # ------------------------------------ # Generate a child script FILE with all initialization necessary to # reuse the environment learned by the parent script, and make the # file executable. If COMMENT is supplied, it is inserted after the # `#!' sequence but before initialization text begins. After this # macro, additional text can be appended to FILE to form the body of # the child script. The macro ends with non-zero status if the # file could not be fully written (such as if the disk is full). m4_ifdef([AS_INIT_GENERATED], [m4_defun([_LT_GENERATED_FILE_INIT],[AS_INIT_GENERATED($@)])], [m4_defun([_LT_GENERATED_FILE_INIT], [m4_require([AS_PREPARE])]dnl [m4_pushdef([AS_MESSAGE_LOG_FD])]dnl [lt_write_fail=0 cat >$1 <<_ASEOF || lt_write_fail=1 #! $SHELL # Generated by $as_me. $2 SHELL=\${CONFIG_SHELL-$SHELL} export SHELL _ASEOF cat >>$1 <<\_ASEOF || lt_write_fail=1 AS_SHELL_SANITIZE _AS_PREPARE exec AS_MESSAGE_FD>&1 _ASEOF test $lt_write_fail = 0 && chmod +x $1[]dnl m4_popdef([AS_MESSAGE_LOG_FD])])])# _LT_GENERATED_FILE_INIT # LT_OUTPUT # --------- # This macro allows early generation of the libtool script (before # AC_OUTPUT is called), incase it is used in configure for compilation # tests. AC_DEFUN([LT_OUTPUT], [: ${CONFIG_LT=./config.lt} AC_MSG_NOTICE([creating $CONFIG_LT]) _LT_GENERATED_FILE_INIT(["$CONFIG_LT"], [# Run this file to recreate a libtool stub with the current configuration.]) cat >>"$CONFIG_LT" <<\_LTEOF lt_cl_silent=false exec AS_MESSAGE_LOG_FD>>config.log { echo AS_BOX([Running $as_me.]) } >&AS_MESSAGE_LOG_FD lt_cl_help="\ \`$as_me' creates a local libtool stub from the current configuration, for use in further configure time tests before the real libtool is generated. Usage: $[0] [[OPTIONS]] -h, --help print this help, then exit -V, --version print version number, then exit -q, --quiet do not print progress messages -d, --debug don't remove temporary files Report bugs to ." lt_cl_version="\ m4_ifset([AC_PACKAGE_NAME], [AC_PACKAGE_NAME ])config.lt[]dnl m4_ifset([AC_PACKAGE_VERSION], [ AC_PACKAGE_VERSION]) configured by $[0], generated by m4_PACKAGE_STRING. Copyright (C) 2011 Free Software Foundation, Inc. This config.lt script is free software; the Free Software Foundation gives unlimited permision to copy, distribute and modify it." while test $[#] != 0 do case $[1] in --version | --v* | -V ) echo "$lt_cl_version"; exit 0 ;; --help | --h* | -h ) echo "$lt_cl_help"; exit 0 ;; --debug | --d* | -d ) debug=: ;; --quiet | --q* | --silent | --s* | -q ) lt_cl_silent=: ;; -*) AC_MSG_ERROR([unrecognized option: $[1] Try \`$[0] --help' for more information.]) ;; *) AC_MSG_ERROR([unrecognized argument: $[1] Try \`$[0] --help' for more information.]) ;; esac shift done if $lt_cl_silent; then exec AS_MESSAGE_FD>/dev/null fi _LTEOF cat >>"$CONFIG_LT" <<_LTEOF _LT_OUTPUT_LIBTOOL_COMMANDS_INIT _LTEOF cat >>"$CONFIG_LT" <<\_LTEOF AC_MSG_NOTICE([creating $ofile]) _LT_OUTPUT_LIBTOOL_COMMANDS AS_EXIT(0) _LTEOF chmod +x "$CONFIG_LT" # configure is writing to config.log, but config.lt does its own redirection, # appending to config.log, which fails on DOS, as config.log is still kept # open by configure. Here we exec the FD to /dev/null, effectively closing # config.log, so it can be properly (re)opened and appended to by config.lt. lt_cl_success=: test "$silent" = yes && lt_config_lt_args="$lt_config_lt_args --quiet" exec AS_MESSAGE_LOG_FD>/dev/null $SHELL "$CONFIG_LT" $lt_config_lt_args || lt_cl_success=false exec AS_MESSAGE_LOG_FD>>config.log $lt_cl_success || AS_EXIT(1) ])# LT_OUTPUT # _LT_CONFIG(TAG) # --------------- # If TAG is the built-in tag, create an initial libtool script with a # default configuration from the untagged config vars. Otherwise add code # to config.status for appending the configuration named by TAG from the # matching tagged config vars. m4_defun([_LT_CONFIG], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl _LT_CONFIG_SAVE_COMMANDS([ m4_define([_LT_TAG], m4_if([$1], [], [C], [$1]))dnl m4_if(_LT_TAG, [C], [ # See if we are running on zsh, and set the options which allow our # commands through without removal of \ escapes. if test -n "${ZSH_VERSION+set}" ; then setopt NO_GLOB_SUBST fi cfgfile="${ofile}T" trap "$RM \"$cfgfile\"; exit 1" 1 2 15 $RM "$cfgfile" cat <<_LT_EOF >> "$cfgfile" #! $SHELL # `$ECHO "$ofile" | sed 's%^.*/%%'` - Provide generalized library-building support services. # Generated automatically by $as_me ($PACKAGE$TIMESTAMP) $VERSION # Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: # NOTE: Changes made to this file will be lost: look at ltmain.sh. # _LT_COPYING _LT_LIBTOOL_TAGS # ### BEGIN LIBTOOL CONFIG _LT_LIBTOOL_CONFIG_VARS _LT_LIBTOOL_TAG_VARS # ### END LIBTOOL CONFIG _LT_EOF case $host_os in aix3*) cat <<\_LT_EOF >> "$cfgfile" # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test "X${COLLECT_NAMES+set}" != Xset; then COLLECT_NAMES= export COLLECT_NAMES fi _LT_EOF ;; esac _LT_PROG_LTMAIN # We use sed instead of cat because bash on DJGPP gets confused if # if finds mixed CR/LF and LF-only lines. Since sed operates in # text mode, it properly converts lines to CR/LF. This bash problem # is reportedly fixed, but why not run on old versions too? sed '$q' "$ltmain" >> "$cfgfile" \ || (rm -f "$cfgfile"; exit 1) _LT_PROG_REPLACE_SHELLFNS mv -f "$cfgfile" "$ofile" || (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") chmod +x "$ofile" ], [cat <<_LT_EOF >> "$ofile" dnl Unfortunately we have to use $1 here, since _LT_TAG is not expanded dnl in a comment (ie after a #). # ### BEGIN LIBTOOL TAG CONFIG: $1 _LT_LIBTOOL_TAG_VARS(_LT_TAG) # ### END LIBTOOL TAG CONFIG: $1 _LT_EOF ])dnl /m4_if ], [m4_if([$1], [], [ PACKAGE='$PACKAGE' VERSION='$VERSION' TIMESTAMP='$TIMESTAMP' RM='$RM' ofile='$ofile'], []) ])dnl /_LT_CONFIG_SAVE_COMMANDS ])# _LT_CONFIG # LT_SUPPORTED_TAG(TAG) # --------------------- # Trace this macro to discover what tags are supported by the libtool # --tag option, using: # autoconf --trace 'LT_SUPPORTED_TAG:$1' AC_DEFUN([LT_SUPPORTED_TAG], []) # C support is built-in for now m4_define([_LT_LANG_C_enabled], []) m4_define([_LT_TAGS], []) # LT_LANG(LANG) # ------------- # Enable libtool support for the given language if not already enabled. AC_DEFUN([LT_LANG], [AC_BEFORE([$0], [LT_OUTPUT])dnl m4_case([$1], [C], [_LT_LANG(C)], [C++], [_LT_LANG(CXX)], [Go], [_LT_LANG(GO)], [Java], [_LT_LANG(GCJ)], [Fortran 77], [_LT_LANG(F77)], [Fortran], [_LT_LANG(FC)], [Windows Resource], [_LT_LANG(RC)], [m4_ifdef([_LT_LANG_]$1[_CONFIG], [_LT_LANG($1)], [m4_fatal([$0: unsupported language: "$1"])])])dnl ])# LT_LANG # _LT_LANG(LANGNAME) # ------------------ m4_defun([_LT_LANG], [m4_ifdef([_LT_LANG_]$1[_enabled], [], [LT_SUPPORTED_TAG([$1])dnl m4_append([_LT_TAGS], [$1 ])dnl m4_define([_LT_LANG_]$1[_enabled], [])dnl _LT_LANG_$1_CONFIG($1)])dnl ])# _LT_LANG m4_ifndef([AC_PROG_GO], [ ############################################################ # NOTE: This macro has been submitted for inclusion into # # GNU Autoconf as AC_PROG_GO. When it is available in # # a released version of Autoconf we should remove this # # macro and use it instead. # ############################################################ m4_defun([AC_PROG_GO], [AC_LANG_PUSH(Go)dnl AC_ARG_VAR([GOC], [Go compiler command])dnl AC_ARG_VAR([GOFLAGS], [Go compiler flags])dnl _AC_ARG_VAR_LDFLAGS()dnl AC_CHECK_TOOL(GOC, gccgo) if test -z "$GOC"; then if test -n "$ac_tool_prefix"; then AC_CHECK_PROG(GOC, [${ac_tool_prefix}gccgo], [${ac_tool_prefix}gccgo]) fi fi if test -z "$GOC"; then AC_CHECK_PROG(GOC, gccgo, gccgo, false) fi ])#m4_defun ])#m4_ifndef # _LT_LANG_DEFAULT_CONFIG # ----------------------- m4_defun([_LT_LANG_DEFAULT_CONFIG], [AC_PROVIDE_IFELSE([AC_PROG_CXX], [LT_LANG(CXX)], [m4_define([AC_PROG_CXX], defn([AC_PROG_CXX])[LT_LANG(CXX)])]) AC_PROVIDE_IFELSE([AC_PROG_F77], [LT_LANG(F77)], [m4_define([AC_PROG_F77], defn([AC_PROG_F77])[LT_LANG(F77)])]) AC_PROVIDE_IFELSE([AC_PROG_FC], [LT_LANG(FC)], [m4_define([AC_PROG_FC], defn([AC_PROG_FC])[LT_LANG(FC)])]) dnl The call to [A][M_PROG_GCJ] is quoted like that to stop aclocal dnl pulling things in needlessly. AC_PROVIDE_IFELSE([AC_PROG_GCJ], [LT_LANG(GCJ)], [AC_PROVIDE_IFELSE([A][M_PROG_GCJ], [LT_LANG(GCJ)], [AC_PROVIDE_IFELSE([LT_PROG_GCJ], [LT_LANG(GCJ)], [m4_ifdef([AC_PROG_GCJ], [m4_define([AC_PROG_GCJ], defn([AC_PROG_GCJ])[LT_LANG(GCJ)])]) m4_ifdef([A][M_PROG_GCJ], [m4_define([A][M_PROG_GCJ], defn([A][M_PROG_GCJ])[LT_LANG(GCJ)])]) m4_ifdef([LT_PROG_GCJ], [m4_define([LT_PROG_GCJ], defn([LT_PROG_GCJ])[LT_LANG(GCJ)])])])])]) AC_PROVIDE_IFELSE([AC_PROG_GO], [LT_LANG(GO)], [m4_define([AC_PROG_GO], defn([AC_PROG_GO])[LT_LANG(GO)])]) AC_PROVIDE_IFELSE([LT_PROG_RC], [LT_LANG(RC)], [m4_define([LT_PROG_RC], defn([LT_PROG_RC])[LT_LANG(RC)])]) ])# _LT_LANG_DEFAULT_CONFIG # Obsolete macros: AU_DEFUN([AC_LIBTOOL_CXX], [LT_LANG(C++)]) AU_DEFUN([AC_LIBTOOL_F77], [LT_LANG(Fortran 77)]) AU_DEFUN([AC_LIBTOOL_FC], [LT_LANG(Fortran)]) AU_DEFUN([AC_LIBTOOL_GCJ], [LT_LANG(Java)]) AU_DEFUN([AC_LIBTOOL_RC], [LT_LANG(Windows Resource)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_CXX], []) dnl AC_DEFUN([AC_LIBTOOL_F77], []) dnl AC_DEFUN([AC_LIBTOOL_FC], []) dnl AC_DEFUN([AC_LIBTOOL_GCJ], []) dnl AC_DEFUN([AC_LIBTOOL_RC], []) # _LT_TAG_COMPILER # ---------------- m4_defun([_LT_TAG_COMPILER], [AC_REQUIRE([AC_PROG_CC])dnl _LT_DECL([LTCC], [CC], [1], [A C compiler])dnl _LT_DECL([LTCFLAGS], [CFLAGS], [1], [LTCC compiler flags])dnl _LT_TAGDECL([CC], [compiler], [1], [A language specific compiler])dnl _LT_TAGDECL([with_gcc], [GCC], [0], [Is the compiler the GNU compiler?])dnl # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC ])# _LT_TAG_COMPILER # _LT_COMPILER_BOILERPLATE # ------------------------ # Check for compiler boilerplate output or warnings with # the simple compiler test code. m4_defun([_LT_COMPILER_BOILERPLATE], [m4_require([_LT_DECL_SED])dnl ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ])# _LT_COMPILER_BOILERPLATE # _LT_LINKER_BOILERPLATE # ---------------------- # Check for linker boilerplate output or warnings with # the simple link test code. m4_defun([_LT_LINKER_BOILERPLATE], [m4_require([_LT_DECL_SED])dnl ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* ])# _LT_LINKER_BOILERPLATE # _LT_REQUIRED_DARWIN_CHECKS # ------------------------- m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[ case $host_os in rhapsody* | darwin*) AC_CHECK_TOOL([DSYMUTIL], [dsymutil], [:]) AC_CHECK_TOOL([NMEDIT], [nmedit], [:]) AC_CHECK_TOOL([LIPO], [lipo], [:]) AC_CHECK_TOOL([OTOOL], [otool], [:]) AC_CHECK_TOOL([OTOOL64], [otool64], [:]) _LT_DECL([], [DSYMUTIL], [1], [Tool to manipulate archived DWARF debug symbol files on Mac OS X]) _LT_DECL([], [NMEDIT], [1], [Tool to change global to local symbols on Mac OS X]) _LT_DECL([], [LIPO], [1], [Tool to manipulate fat objects and archives on Mac OS X]) _LT_DECL([], [OTOOL], [1], [ldd/readelf like tool for Mach-O binaries on Mac OS X]) _LT_DECL([], [OTOOL64], [1], [ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4]) AC_CACHE_CHECK([for -single_module linker flag],[lt_cv_apple_cc_single_mod], [lt_cv_apple_cc_single_mod=no if test -z "${LT_MULTI_MODULE}"; then # By default we will add the -single_module flag. You can override # by either setting the environment variable LT_MULTI_MODULE # non-empty at configure time, or by adding -multi_module to the # link flags. rm -rf libconftest.dylib* echo "int foo(void){return 1;}" > conftest.c echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c 2>conftest.err _lt_result=$? # If there is a non-empty error log, and "single_module" # appears in it, assume the flag caused a linker warning if test -s conftest.err && $GREP single_module conftest.err; then cat conftest.err >&AS_MESSAGE_LOG_FD # Otherwise, if the output was created with a 0 exit code from # the compiler, it worked. elif test -f libconftest.dylib && test $_lt_result -eq 0; then lt_cv_apple_cc_single_mod=yes else cat conftest.err >&AS_MESSAGE_LOG_FD fi rm -rf libconftest.dylib* rm -f conftest.* fi]) AC_CACHE_CHECK([for -exported_symbols_list linker flag], [lt_cv_ld_exported_symbols_list], [lt_cv_ld_exported_symbols_list=no save_LDFLAGS=$LDFLAGS echo "_main" > conftest.sym LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], [lt_cv_ld_exported_symbols_list=yes], [lt_cv_ld_exported_symbols_list=no]) LDFLAGS="$save_LDFLAGS" ]) AC_CACHE_CHECK([for -force_load linker flag],[lt_cv_ld_force_load], [lt_cv_ld_force_load=no cat > conftest.c << _LT_EOF int forced_loaded() { return 2;} _LT_EOF echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&AS_MESSAGE_LOG_FD echo "$AR cru libconftest.a conftest.o" >&AS_MESSAGE_LOG_FD $AR cru libconftest.a conftest.o 2>&AS_MESSAGE_LOG_FD echo "$RANLIB libconftest.a" >&AS_MESSAGE_LOG_FD $RANLIB libconftest.a 2>&AS_MESSAGE_LOG_FD cat > conftest.c << _LT_EOF int main() { return 0;} _LT_EOF echo "$LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a 2>conftest.err _lt_result=$? if test -s conftest.err && $GREP force_load conftest.err; then cat conftest.err >&AS_MESSAGE_LOG_FD elif test -f conftest && test $_lt_result -eq 0 && $GREP forced_load conftest >/dev/null 2>&1 ; then lt_cv_ld_force_load=yes else cat conftest.err >&AS_MESSAGE_LOG_FD fi rm -f conftest.err libconftest.a conftest conftest.c rm -rf conftest.dSYM ]) case $host_os in rhapsody* | darwin1.[[012]]) _lt_dar_allow_undefined='${wl}-undefined ${wl}suppress' ;; darwin1.*) _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;; darwin*) # darwin 5.x on # if running on 10.5 or later, the deployment target defaults # to the OS version, if on x86, and 10.4, the deployment # target defaults to 10.4. Don't you love it? case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in 10.0,*86*-darwin8*|10.0,*-darwin[[91]]*) _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;; 10.[[012]]*) _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;; 10.*) _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;; esac ;; esac if test "$lt_cv_apple_cc_single_mod" = "yes"; then _lt_dar_single_mod='$single_module' fi if test "$lt_cv_ld_exported_symbols_list" = "yes"; then _lt_dar_export_syms=' ${wl}-exported_symbols_list,$output_objdir/${libname}-symbols.expsym' else _lt_dar_export_syms='~$NMEDIT -s $output_objdir/${libname}-symbols.expsym ${lib}' fi if test "$DSYMUTIL" != ":" && test "$lt_cv_ld_force_load" = "no"; then _lt_dsymutil='~$DSYMUTIL $lib || :' else _lt_dsymutil= fi ;; esac ]) # _LT_DARWIN_LINKER_FEATURES([TAG]) # --------------------------------- # Checks for linker and compiler features on darwin m4_defun([_LT_DARWIN_LINKER_FEATURES], [ m4_require([_LT_REQUIRED_DARWIN_CHECKS]) _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported if test "$lt_cv_ld_force_load" = "yes"; then _LT_TAGVAR(whole_archive_flag_spec, $1)='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience ${wl}-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' m4_case([$1], [F77], [_LT_TAGVAR(compiler_needs_object, $1)=yes], [FC], [_LT_TAGVAR(compiler_needs_object, $1)=yes]) else _LT_TAGVAR(whole_archive_flag_spec, $1)='' fi _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)="$_lt_dar_allow_undefined" case $cc_basename in ifort*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test "$_lt_dar_can_shared" = "yes"; then output_verbose_link_cmd=func_echo_all _LT_TAGVAR(archive_cmds, $1)="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}" _LT_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" _LT_TAGVAR(module_expsym_cmds, $1)="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" m4_if([$1], [CXX], [ if test "$lt_cv_apple_cc_single_mod" != "yes"; then _LT_TAGVAR(archive_cmds, $1)="\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dsymutil}" _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dar_export_syms}${_lt_dsymutil}" fi ],[]) else _LT_TAGVAR(ld_shlibs, $1)=no fi ]) # _LT_SYS_MODULE_PATH_AIX([TAGNAME]) # ---------------------------------- # Links a minimal program and checks the executable # for the system default hardcoded library path. In most cases, # this is /usr/lib:/lib, but when the MPI compilers are used # the location of the communication and MPI libs are included too. # If we don't find anything, use the default library path according # to the aix ld manual. # Store the results from the different compilers for each TAGNAME. # Allow to override them for all tags through lt_cv_aix_libpath. m4_defun([_LT_SYS_MODULE_PATH_AIX], [m4_require([_LT_DECL_SED])dnl if test "${lt_cv_aix_libpath+set}" = set; then aix_libpath=$lt_cv_aix_libpath else AC_CACHE_VAL([_LT_TAGVAR([lt_cv_aix_libpath_], [$1])], [AC_LINK_IFELSE([AC_LANG_PROGRAM],[ lt_aix_libpath_sed='[ /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }]' _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi],[]) if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then _LT_TAGVAR([lt_cv_aix_libpath_], [$1])="/usr/lib:/lib" fi ]) aix_libpath=$_LT_TAGVAR([lt_cv_aix_libpath_], [$1]) fi ])# _LT_SYS_MODULE_PATH_AIX # _LT_SHELL_INIT(ARG) # ------------------- m4_define([_LT_SHELL_INIT], [m4_divert_text([M4SH-INIT], [$1 ])])# _LT_SHELL_INIT # _LT_PROG_ECHO_BACKSLASH # ----------------------- # Find how we can fake an echo command that does not interpret backslash. # In particular, with Autoconf 2.60 or later we add some code to the start # of the generated configure script which will find a shell with a builtin # printf (which we can use as an echo command). m4_defun([_LT_PROG_ECHO_BACKSLASH], [ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO AC_MSG_CHECKING([how to print strings]) # Test print first, because it will be a builtin if present. if test "X`( print -r -- -n ) 2>/dev/null`" = X-n && \ test "X`print -r -- $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='print -r --' elif test "X`printf %s $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='printf %s\n' else # Use this function as a fallback that always works. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $[]1 _LTECHO_EOF' } ECHO='func_fallback_echo' fi # func_echo_all arg... # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "$*" } case "$ECHO" in printf*) AC_MSG_RESULT([printf]) ;; print*) AC_MSG_RESULT([print -r]) ;; *) AC_MSG_RESULT([cat]) ;; esac m4_ifdef([_AS_DETECT_SUGGESTED], [_AS_DETECT_SUGGESTED([ test -n "${ZSH_VERSION+set}${BASH_VERSION+set}" || ( ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO PATH=/empty FPATH=/empty; export PATH FPATH test "X`printf %s $ECHO`" = "X$ECHO" \ || test "X`print -r -- $ECHO`" = "X$ECHO" )])]) _LT_DECL([], [SHELL], [1], [Shell to use when invoking shell scripts]) _LT_DECL([], [ECHO], [1], [An echo program that protects backslashes]) ])# _LT_PROG_ECHO_BACKSLASH # _LT_WITH_SYSROOT # ---------------- AC_DEFUN([_LT_WITH_SYSROOT], [AC_MSG_CHECKING([for sysroot]) AC_ARG_WITH([sysroot], [ --with-sysroot[=DIR] Search for dependent libraries within DIR (or the compiler's sysroot if not specified).], [], [with_sysroot=no]) dnl lt_sysroot will always be passed unquoted. We quote it here dnl in case the user passed a directory name. lt_sysroot= case ${with_sysroot} in #( yes) if test "$GCC" = yes; then lt_sysroot=`$CC --print-sysroot 2>/dev/null` fi ;; #( /*) lt_sysroot=`echo "$with_sysroot" | sed -e "$sed_quote_subst"` ;; #( no|'') ;; #( *) AC_MSG_RESULT([${with_sysroot}]) AC_MSG_ERROR([The sysroot must be an absolute path.]) ;; esac AC_MSG_RESULT([${lt_sysroot:-no}]) _LT_DECL([], [lt_sysroot], [0], [The root where to search for ]dnl [dependent libraries, and in which our libraries should be installed.])]) # _LT_ENABLE_LOCK # --------------- m4_defun([_LT_ENABLE_LOCK], [AC_ARG_ENABLE([libtool-lock], [AS_HELP_STRING([--disable-libtool-lock], [avoid locking (might break parallel builds)])]) test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes # Some flags need to be propagated to the compiler or linker for good # libtool support. case $host in ia64-*-hpux*) # Find out which ABI we are using. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `/usr/bin/file conftest.$ac_objext` in *ELF-32*) HPUX_IA64_MODE="32" ;; *ELF-64*) HPUX_IA64_MODE="64" ;; esac fi rm -rf conftest* ;; *-*-irix6*) # Find out which ABI we are using. echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then if test "$lt_cv_prog_gnu_ld" = yes; then case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -melf32bsmip" ;; *N32*) LD="${LD-ld} -melf32bmipn32" ;; *64-bit*) LD="${LD-ld} -melf64bmip" ;; esac else case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -32" ;; *N32*) LD="${LD-ld} -n32" ;; *64-bit*) LD="${LD-ld} -64" ;; esac fi fi rm -rf conftest* ;; x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ s390*-*linux*|s390*-*tpf*|sparc*-*linux*) # Find out which ABI we are using. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `/usr/bin/file conftest.o` in *32-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_i386_fbsd" ;; x86_64-*linux*) case `/usr/bin/file conftest.o` in *x86-64*) LD="${LD-ld} -m elf32_x86_64" ;; *) LD="${LD-ld} -m elf_i386" ;; esac ;; powerpc64le-*) LD="${LD-ld} -m elf32lppclinux" ;; powerpc64-*) LD="${LD-ld} -m elf32ppclinux" ;; s390x-*linux*) LD="${LD-ld} -m elf_s390" ;; sparc64-*linux*) LD="${LD-ld} -m elf32_sparc" ;; esac ;; *64-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_x86_64_fbsd" ;; x86_64-*linux*) LD="${LD-ld} -m elf_x86_64" ;; powerpcle-*) LD="${LD-ld} -m elf64lppc" ;; powerpc-*) LD="${LD-ld} -m elf64ppc" ;; s390*-*linux*|s390*-*tpf*) LD="${LD-ld} -m elf64_s390" ;; sparc*-*linux*) LD="${LD-ld} -m elf64_sparc" ;; esac ;; esac fi rm -rf conftest* ;; *-*-sco3.2v5*) # On SCO OpenServer 5, we need -belf to get full-featured binaries. SAVE_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS -belf" AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf, [AC_LANG_PUSH(C) AC_LINK_IFELSE([AC_LANG_PROGRAM([[]],[[]])],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no]) AC_LANG_POP]) if test x"$lt_cv_cc_needs_belf" != x"yes"; then # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf CFLAGS="$SAVE_CFLAGS" fi ;; *-*solaris*) # Find out which ABI we are using. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `/usr/bin/file conftest.o` in *64-bit*) case $lt_cv_prog_gnu_ld in yes*) case $host in i?86-*-solaris*) LD="${LD-ld} -m elf_x86_64" ;; sparc*-*-solaris*) LD="${LD-ld} -m elf64_sparc" ;; esac # GNU ld 2.21 introduced _sol2 emulations. Use them if available. if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then LD="${LD-ld}_sol2" fi ;; *) if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then LD="${LD-ld} -64" fi ;; esac ;; esac fi rm -rf conftest* ;; esac need_locks="$enable_libtool_lock" ])# _LT_ENABLE_LOCK # _LT_PROG_AR # ----------- m4_defun([_LT_PROG_AR], [AC_CHECK_TOOLS(AR, [ar], false) : ${AR=ar} : ${AR_FLAGS=cru} _LT_DECL([], [AR], [1], [The archiver]) _LT_DECL([], [AR_FLAGS], [1], [Flags to create an archive]) AC_CACHE_CHECK([for archiver @FILE support], [lt_cv_ar_at_file], [lt_cv_ar_at_file=no AC_COMPILE_IFELSE([AC_LANG_PROGRAM], [echo conftest.$ac_objext > conftest.lst lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&AS_MESSAGE_LOG_FD' AC_TRY_EVAL([lt_ar_try]) if test "$ac_status" -eq 0; then # Ensure the archiver fails upon bogus file names. rm -f conftest.$ac_objext libconftest.a AC_TRY_EVAL([lt_ar_try]) if test "$ac_status" -ne 0; then lt_cv_ar_at_file=@ fi fi rm -f conftest.* libconftest.a ]) ]) if test "x$lt_cv_ar_at_file" = xno; then archiver_list_spec= else archiver_list_spec=$lt_cv_ar_at_file fi _LT_DECL([], [archiver_list_spec], [1], [How to feed a file listing to the archiver]) ])# _LT_PROG_AR # _LT_CMD_OLD_ARCHIVE # ------------------- m4_defun([_LT_CMD_OLD_ARCHIVE], [_LT_PROG_AR AC_CHECK_TOOL(STRIP, strip, :) test -z "$STRIP" && STRIP=: _LT_DECL([], [STRIP], [1], [A symbol stripping program]) AC_CHECK_TOOL(RANLIB, ranlib, :) test -z "$RANLIB" && RANLIB=: _LT_DECL([], [RANLIB], [1], [Commands used to install an old-style archive]) # Determine commands to create old-style static archives. old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' old_postinstall_cmds='chmod 644 $oldlib' old_postuninstall_cmds= if test -n "$RANLIB"; then case $host_os in openbsd*) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib" ;; *) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$tool_oldlib" ;; esac old_archive_cmds="$old_archive_cmds~\$RANLIB \$tool_oldlib" fi case $host_os in darwin*) lock_old_archive_extraction=yes ;; *) lock_old_archive_extraction=no ;; esac _LT_DECL([], [old_postinstall_cmds], [2]) _LT_DECL([], [old_postuninstall_cmds], [2]) _LT_TAGDECL([], [old_archive_cmds], [2], [Commands used to build an old-style archive]) _LT_DECL([], [lock_old_archive_extraction], [0], [Whether to use a lock for old archive extraction]) ])# _LT_CMD_OLD_ARCHIVE # _LT_COMPILER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, # [OUTPUT-FILE], [ACTION-SUCCESS], [ACTION-FAILURE]) # ---------------------------------------------------------------- # Check whether the given compiler option works AC_DEFUN([_LT_COMPILER_OPTION], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_SED])dnl AC_CACHE_CHECK([$1], [$2], [$2=no m4_if([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4]) echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$3" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&AS_MESSAGE_LOG_FD echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then $2=yes fi fi $RM conftest* ]) if test x"[$]$2" = xyes; then m4_if([$5], , :, [$5]) else m4_if([$6], , :, [$6]) fi ])# _LT_COMPILER_OPTION # Old name: AU_ALIAS([AC_LIBTOOL_COMPILER_OPTION], [_LT_COMPILER_OPTION]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_COMPILER_OPTION], []) # _LT_LINKER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, # [ACTION-SUCCESS], [ACTION-FAILURE]) # ---------------------------------------------------- # Check whether the given linker option works AC_DEFUN([_LT_LINKER_OPTION], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_SED])dnl AC_CACHE_CHECK([$1], [$2], [$2=no save_LDFLAGS="$LDFLAGS" LDFLAGS="$LDFLAGS $3" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&AS_MESSAGE_LOG_FD $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then $2=yes fi else $2=yes fi fi $RM -r conftest* LDFLAGS="$save_LDFLAGS" ]) if test x"[$]$2" = xyes; then m4_if([$4], , :, [$4]) else m4_if([$5], , :, [$5]) fi ])# _LT_LINKER_OPTION # Old name: AU_ALIAS([AC_LIBTOOL_LINKER_OPTION], [_LT_LINKER_OPTION]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_LINKER_OPTION], []) # LT_CMD_MAX_LEN #--------------- AC_DEFUN([LT_CMD_MAX_LEN], [AC_REQUIRE([AC_CANONICAL_HOST])dnl # find the maximum length of command line arguments AC_MSG_CHECKING([the maximum length of command line arguments]) AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl i=0 teststring="ABCD" case $build_os in msdosdjgpp*) # On DJGPP, this test can blow up pretty badly due to problems in libc # (any single argument exceeding 2000 bytes causes a buffer overrun # during glob expansion). Even if it were fixed, the result of this # check would be larger than it should be. lt_cv_sys_max_cmd_len=12288; # 12K is about right ;; gnu*) # Under GNU Hurd, this test is not required because there is # no limit to the length of command line arguments. # Libtool will interpret -1 as no limit whatsoever lt_cv_sys_max_cmd_len=-1; ;; cygwin* | mingw* | cegcc*) # On Win9x/ME, this test blows up -- it succeeds, but takes # about 5 minutes as the teststring grows exponentially. # Worse, since 9x/ME are not pre-emptively multitasking, # you end up with a "frozen" computer, even though with patience # the test eventually succeeds (with a max line length of 256k). # Instead, let's just punt: use the minimum linelength reported by # all of the supported platforms: 8192 (on NT/2K/XP). lt_cv_sys_max_cmd_len=8192; ;; mint*) # On MiNT this can take a long time and run out of memory. lt_cv_sys_max_cmd_len=8192; ;; amigaos*) # On AmigaOS with pdksh, this test takes hours, literally. # So we just punt and use a minimum line length of 8192. lt_cv_sys_max_cmd_len=8192; ;; netbsd* | freebsd* | openbsd* | darwin* | dragonfly*) # This has been around since 386BSD, at least. Likely further. if test -x /sbin/sysctl; then lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` elif test -x /usr/sbin/sysctl; then lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` else lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs fi # And add a safety zone lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` ;; interix*) # We know the value 262144 and hardcode it with a safety zone (like BSD) lt_cv_sys_max_cmd_len=196608 ;; os2*) # The test takes a long time on OS/2. lt_cv_sys_max_cmd_len=8192 ;; osf*) # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not # nice to cause kernel panics so lets avoid the loop below. # First set a reasonable default. lt_cv_sys_max_cmd_len=16384 # if test -x /sbin/sysconfig; then case `/sbin/sysconfig -q proc exec_disable_arg_limit` in *1*) lt_cv_sys_max_cmd_len=-1 ;; esac fi ;; sco3.2v5*) lt_cv_sys_max_cmd_len=102400 ;; sysv5* | sco5v6* | sysv4.2uw2*) kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` if test -n "$kargmax"; then lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[[ ]]//'` else lt_cv_sys_max_cmd_len=32768 fi ;; *) lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` if test -n "$lt_cv_sys_max_cmd_len" && \ test undefined != "$lt_cv_sys_max_cmd_len"; then lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` else # Make teststring a little bigger before we do anything with it. # a 1K string should be a reasonable start. for i in 1 2 3 4 5 6 7 8 ; do teststring=$teststring$teststring done SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} # If test is not a shell built-in, we'll probably end up computing a # maximum length that is only half of the actual maximum length, but # we can't tell. while { test "X"`env echo "$teststring$teststring" 2>/dev/null` \ = "X$teststring$teststring"; } >/dev/null 2>&1 && test $i != 17 # 1/2 MB should be enough do i=`expr $i + 1` teststring=$teststring$teststring done # Only check the string length outside the loop. lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` teststring= # Add a significant safety factor because C++ compilers can tack on # massive amounts of additional arguments before passing them to the # linker. It appears as though 1/2 is a usable value. lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` fi ;; esac ]) if test -n $lt_cv_sys_max_cmd_len ; then AC_MSG_RESULT($lt_cv_sys_max_cmd_len) else AC_MSG_RESULT(none) fi max_cmd_len=$lt_cv_sys_max_cmd_len _LT_DECL([], [max_cmd_len], [0], [What is the maximum length of a command?]) ])# LT_CMD_MAX_LEN # Old name: AU_ALIAS([AC_LIBTOOL_SYS_MAX_CMD_LEN], [LT_CMD_MAX_LEN]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_SYS_MAX_CMD_LEN], []) # _LT_HEADER_DLFCN # ---------------- m4_defun([_LT_HEADER_DLFCN], [AC_CHECK_HEADERS([dlfcn.h], [], [], [AC_INCLUDES_DEFAULT])dnl ])# _LT_HEADER_DLFCN # _LT_TRY_DLOPEN_SELF (ACTION-IF-TRUE, ACTION-IF-TRUE-W-USCORE, # ACTION-IF-FALSE, ACTION-IF-CROSS-COMPILING) # ---------------------------------------------------------------- m4_defun([_LT_TRY_DLOPEN_SELF], [m4_require([_LT_HEADER_DLFCN])dnl if test "$cross_compiling" = yes; then : [$4] else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF [#line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisbility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined(__GNUC__) && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; }] _LT_EOF if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext} 2>/dev/null; then (./conftest; exit; ) >&AS_MESSAGE_LOG_FD 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) $1 ;; x$lt_dlneed_uscore) $2 ;; x$lt_dlunknown|x*) $3 ;; esac else : # compilation failed $3 fi fi rm -fr conftest* ])# _LT_TRY_DLOPEN_SELF # LT_SYS_DLOPEN_SELF # ------------------ AC_DEFUN([LT_SYS_DLOPEN_SELF], [m4_require([_LT_HEADER_DLFCN])dnl if test "x$enable_dlopen" != xyes; then enable_dlopen=unknown enable_dlopen_self=unknown enable_dlopen_self_static=unknown else lt_cv_dlopen=no lt_cv_dlopen_libs= case $host_os in beos*) lt_cv_dlopen="load_add_on" lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ;; mingw* | pw32* | cegcc*) lt_cv_dlopen="LoadLibrary" lt_cv_dlopen_libs= ;; cygwin*) lt_cv_dlopen="dlopen" lt_cv_dlopen_libs= ;; darwin*) # if libdl is installed we need to link against it AC_CHECK_LIB([dl], [dlopen], [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"],[ lt_cv_dlopen="dyld" lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ]) ;; *) AC_CHECK_FUNC([shl_load], [lt_cv_dlopen="shl_load"], [AC_CHECK_LIB([dld], [shl_load], [lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-ldld"], [AC_CHECK_FUNC([dlopen], [lt_cv_dlopen="dlopen"], [AC_CHECK_LIB([dl], [dlopen], [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"], [AC_CHECK_LIB([svld], [dlopen], [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld"], [AC_CHECK_LIB([dld], [dld_link], [lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-ldld"]) ]) ]) ]) ]) ]) ;; esac if test "x$lt_cv_dlopen" != xno; then enable_dlopen=yes else enable_dlopen=no fi case $lt_cv_dlopen in dlopen) save_CPPFLAGS="$CPPFLAGS" test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" save_LDFLAGS="$LDFLAGS" wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" save_LIBS="$LIBS" LIBS="$lt_cv_dlopen_libs $LIBS" AC_CACHE_CHECK([whether a program can dlopen itself], lt_cv_dlopen_self, [dnl _LT_TRY_DLOPEN_SELF( lt_cv_dlopen_self=yes, lt_cv_dlopen_self=yes, lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross) ]) if test "x$lt_cv_dlopen_self" = xyes; then wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" AC_CACHE_CHECK([whether a statically linked program can dlopen itself], lt_cv_dlopen_self_static, [dnl _LT_TRY_DLOPEN_SELF( lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=no, lt_cv_dlopen_self_static=cross) ]) fi CPPFLAGS="$save_CPPFLAGS" LDFLAGS="$save_LDFLAGS" LIBS="$save_LIBS" ;; esac case $lt_cv_dlopen_self in yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; *) enable_dlopen_self=unknown ;; esac case $lt_cv_dlopen_self_static in yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; *) enable_dlopen_self_static=unknown ;; esac fi _LT_DECL([dlopen_support], [enable_dlopen], [0], [Whether dlopen is supported]) _LT_DECL([dlopen_self], [enable_dlopen_self], [0], [Whether dlopen of programs is supported]) _LT_DECL([dlopen_self_static], [enable_dlopen_self_static], [0], [Whether dlopen of statically linked programs is supported]) ])# LT_SYS_DLOPEN_SELF # Old name: AU_ALIAS([AC_LIBTOOL_DLOPEN_SELF], [LT_SYS_DLOPEN_SELF]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_DLOPEN_SELF], []) # _LT_COMPILER_C_O([TAGNAME]) # --------------------------- # Check to see if options -c and -o are simultaneously supported by compiler. # This macro does not hard code the compiler like AC_PROG_CC_C_O. m4_defun([_LT_COMPILER_C_O], [m4_require([_LT_DECL_SED])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_TAG_COMPILER])dnl AC_CACHE_CHECK([if $compiler supports -c -o file.$ac_objext], [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)], [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&AS_MESSAGE_LOG_FD echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes fi fi chmod u+w . 2>&AS_MESSAGE_LOG_FD $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* ]) _LT_TAGDECL([compiler_c_o], [lt_cv_prog_compiler_c_o], [1], [Does compiler simultaneously support -c and -o options?]) ])# _LT_COMPILER_C_O # _LT_COMPILER_FILE_LOCKS([TAGNAME]) # ---------------------------------- # Check to see if we can do hard links to lock some files if needed m4_defun([_LT_COMPILER_FILE_LOCKS], [m4_require([_LT_ENABLE_LOCK])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl _LT_COMPILER_C_O([$1]) hard_links="nottested" if test "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" = no && test "$need_locks" != no; then # do not overwrite the value of need_locks provided by the user AC_MSG_CHECKING([if we can lock with hard links]) hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no AC_MSG_RESULT([$hard_links]) if test "$hard_links" = no; then AC_MSG_WARN([`$CC' does not support `-c -o', so `make -j' may be unsafe]) need_locks=warn fi else need_locks=no fi _LT_DECL([], [need_locks], [1], [Must we lock files when doing compilation?]) ])# _LT_COMPILER_FILE_LOCKS # _LT_CHECK_OBJDIR # ---------------- m4_defun([_LT_CHECK_OBJDIR], [AC_CACHE_CHECK([for objdir], [lt_cv_objdir], [rm -f .libs 2>/dev/null mkdir .libs 2>/dev/null if test -d .libs; then lt_cv_objdir=.libs else # MS-DOS does not allow filenames that begin with a dot. lt_cv_objdir=_libs fi rmdir .libs 2>/dev/null]) objdir=$lt_cv_objdir _LT_DECL([], [objdir], [0], [The name of the directory that contains temporary libtool files])dnl m4_pattern_allow([LT_OBJDIR])dnl AC_DEFINE_UNQUOTED(LT_OBJDIR, "$lt_cv_objdir/", [Define to the sub-directory in which libtool stores uninstalled libraries.]) ])# _LT_CHECK_OBJDIR # _LT_LINKER_HARDCODE_LIBPATH([TAGNAME]) # -------------------------------------- # Check hardcoding attributes. m4_defun([_LT_LINKER_HARDCODE_LIBPATH], [AC_MSG_CHECKING([how to hardcode library paths into programs]) _LT_TAGVAR(hardcode_action, $1)= if test -n "$_LT_TAGVAR(hardcode_libdir_flag_spec, $1)" || test -n "$_LT_TAGVAR(runpath_var, $1)" || test "X$_LT_TAGVAR(hardcode_automatic, $1)" = "Xyes" ; then # We can hardcode non-existent directories. if test "$_LT_TAGVAR(hardcode_direct, $1)" != no && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" != no && test "$_LT_TAGVAR(hardcode_minus_L, $1)" != no; then # Linking always hardcodes the temporary library directory. _LT_TAGVAR(hardcode_action, $1)=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. _LT_TAGVAR(hardcode_action, $1)=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. _LT_TAGVAR(hardcode_action, $1)=unsupported fi AC_MSG_RESULT([$_LT_TAGVAR(hardcode_action, $1)]) if test "$_LT_TAGVAR(hardcode_action, $1)" = relink || test "$_LT_TAGVAR(inherit_rpath, $1)" = yes; then # Fast installation is not supported enable_fast_install=no elif test "$shlibpath_overrides_runpath" = yes || test "$enable_shared" = no; then # Fast installation is not necessary enable_fast_install=needless fi _LT_TAGDECL([], [hardcode_action], [0], [How to hardcode a shared library path into an executable]) ])# _LT_LINKER_HARDCODE_LIBPATH # _LT_CMD_STRIPLIB # ---------------- m4_defun([_LT_CMD_STRIPLIB], [m4_require([_LT_DECL_EGREP]) striplib= old_striplib= AC_MSG_CHECKING([whether stripping libraries is possible]) if test -n "$STRIP" && $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" test -z "$striplib" && striplib="$STRIP --strip-unneeded" AC_MSG_RESULT([yes]) else # FIXME - insert some real tests, host_os isn't really good enough case $host_os in darwin*) if test -n "$STRIP" ; then striplib="$STRIP -x" old_striplib="$STRIP -S" AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) fi ;; *) AC_MSG_RESULT([no]) ;; esac fi _LT_DECL([], [old_striplib], [1], [Commands to strip libraries]) _LT_DECL([], [striplib], [1]) ])# _LT_CMD_STRIPLIB # _LT_SYS_DYNAMIC_LINKER([TAG]) # ----------------------------- # PORTME Fill in your ld.so characteristics m4_defun([_LT_SYS_DYNAMIC_LINKER], [AC_REQUIRE([AC_CANONICAL_HOST])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_OBJDUMP])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_CHECK_SHELL_FEATURES])dnl AC_MSG_CHECKING([dynamic linker characteristics]) m4_if([$1], [], [ if test "$GCC" = yes; then case $host_os in darwin*) lt_awk_arg="/^libraries:/,/LR/" ;; *) lt_awk_arg="/^libraries:/" ;; esac case $host_os in mingw* | cegcc*) lt_sed_strip_eq="s,=\([[A-Za-z]]:\),\1,g" ;; *) lt_sed_strip_eq="s,=/,/,g" ;; esac lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq` case $lt_search_path_spec in *\;*) # if the path contains ";" then we assume it to be the separator # otherwise default to the standard path separator (i.e. ":") - it is # assumed that no part of a normal pathname contains ";" but that should # okay in the real world where ";" in dirpaths is itself problematic. lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED 's/;/ /g'` ;; *) lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED "s/$PATH_SEPARATOR/ /g"` ;; esac # Ok, now we have the path, separated by spaces, we can step through it # and add multilib dir if necessary. lt_tmp_lt_search_path_spec= lt_multi_os_dir=`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` for lt_sys_path in $lt_search_path_spec; do if test -d "$lt_sys_path/$lt_multi_os_dir"; then lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path/$lt_multi_os_dir" else test -d "$lt_sys_path" && \ lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" fi done lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk ' BEGIN {RS=" "; FS="/|\n";} { lt_foo=""; lt_count=0; for (lt_i = NF; lt_i > 0; lt_i--) { if ($lt_i != "" && $lt_i != ".") { if ($lt_i == "..") { lt_count++; } else { if (lt_count == 0) { lt_foo="/" $lt_i lt_foo; } else { lt_count--; } } } } if (lt_foo != "") { lt_freq[[lt_foo]]++; } if (lt_freq[[lt_foo]] == 1) { print lt_foo; } }'` # AWK program above erroneously prepends '/' to C:/dos/paths # for these hosts. case $host_os in mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\ $SED 's,/\([[A-Za-z]]:\),\1,g'` ;; esac sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP` else sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" fi]) library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=".so" postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='${libname}${release}${shared_ext}$major' ;; aix[[4-9]]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test "$host_cpu" = ia64; then # AIX 5 supports IA64 library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line `#! .'. This would cause the generated library to # depend on `.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[[01]] | aix4.[[01]].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | ${CC} -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # AIX (on Power*) has no versioning support, so currently we can not hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. if test "$aix_use_runtimelinking" = yes; then # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' else # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='${libname}${release}.a $libname.a' soname_spec='${libname}${release}${shared_ext}$major' fi shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; test $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='${libname}${shared_ext}' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[[45]]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=".dll" need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \${file}`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' m4_if([$1], [],[ sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api"]) ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl*) # Native MSVC libname_spec='$name' soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' library_names_spec='${libname}.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([[a-zA-Z]]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec="$LIB" if $ECHO "$sys_lib_search_path_spec" | [$GREP ';[c-zC-Z]:/' >/dev/null]; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \${file}`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC wrapper library_names_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext} $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext' soname_spec='${libname}${release}${major}$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' m4_if([$1], [],[ sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib"]) sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[[23]].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[[01]]* | freebsdelf3.[[01]]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[[2-9]]* | freebsdelf3.[[2-9]]* | \ freebsd4.[[0-5]] | freebsdelf4.[[0-5]] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=yes sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' if test "X$HPUX_IA64_MODE" = X32; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" fi sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[[3-9]]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test "$lt_cv_prog_gnu_ld" = yes; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='${libname}${release}${shared_ext}$major' library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH AC_CACHE_VAL([lt_cv_shlibpath_overrides_runpath], [lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$_LT_TAGVAR(lt_prog_compiler_wl, $1)\"; \ LDFLAGS=\"\$LDFLAGS $_LT_TAGVAR(hardcode_libdir_flag_spec, $1)\"" AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], [AS_IF([ ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null], [lt_cv_shlibpath_overrides_runpath=yes])]) LDFLAGS=$save_LDFLAGS libdir=$save_libdir ]) shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Append ld.so.conf contents to the search path if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \[$]2)); skip = 1; } { if (!skip) print \[$]0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsdelf*-gnu) version_type=linux need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='NetBSD ld.elf_so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd*) version_type=sunos sys_lib_dlsearch_path_spec="/usr/lib" need_lib_prefix=no # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. case $host_os in openbsd3.3 | openbsd3.3.*) need_version=yes ;; *) need_version=no ;; esac library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then case $host_os in openbsd2.[[89]] | openbsd2.[[89]].*) shlibpath_overrides_runpath=no ;; *) shlibpath_overrides_runpath=yes ;; esac else shlibpath_overrides_runpath=yes fi ;; os2*) libname_spec='$name' shrext_cmds=".dll" need_lib_prefix=no library_names_spec='$libname${shared_ext} $libname.a' dynamic_linker='OS/2 ld.exe' shlibpath_var=LIBPATH ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='${libname}${release}${shared_ext}$major' library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test "$with_gnu_ld" = yes; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec ;then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' soname_spec='$libname${shared_ext}.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=freebsd-elf need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test "$with_gnu_ld" = yes; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' soname_spec='${libname}${release}${shared_ext}$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac AC_MSG_RESULT([$dynamic_linker]) test "$dynamic_linker" = no && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test "$GCC" = yes; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec" fi if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec" fi _LT_DECL([], [variables_saved_for_relink], [1], [Variables whose values should be saved in libtool wrapper scripts and restored at link time]) _LT_DECL([], [need_lib_prefix], [0], [Do we need the "lib" prefix for modules?]) _LT_DECL([], [need_version], [0], [Do we need a version for libraries?]) _LT_DECL([], [version_type], [0], [Library versioning type]) _LT_DECL([], [runpath_var], [0], [Shared library runtime path variable]) _LT_DECL([], [shlibpath_var], [0],[Shared library path variable]) _LT_DECL([], [shlibpath_overrides_runpath], [0], [Is shlibpath searched before the hard-coded library search path?]) _LT_DECL([], [libname_spec], [1], [Format of library name prefix]) _LT_DECL([], [library_names_spec], [1], [[List of archive names. First name is the real one, the rest are links. The last name is the one that the linker finds with -lNAME]]) _LT_DECL([], [soname_spec], [1], [[The coded name of the library, if different from the real name]]) _LT_DECL([], [install_override_mode], [1], [Permission mode override for installation of shared libraries]) _LT_DECL([], [postinstall_cmds], [2], [Command to use after installation of a shared archive]) _LT_DECL([], [postuninstall_cmds], [2], [Command to use after uninstallation of a shared archive]) _LT_DECL([], [finish_cmds], [2], [Commands used to finish a libtool library installation in a directory]) _LT_DECL([], [finish_eval], [1], [[As "finish_cmds", except a single script fragment to be evaled but not shown]]) _LT_DECL([], [hardcode_into_libs], [0], [Whether we should hardcode library paths into libraries]) _LT_DECL([], [sys_lib_search_path_spec], [2], [Compile-time system search path for libraries]) _LT_DECL([], [sys_lib_dlsearch_path_spec], [2], [Run-time system search path for libraries]) ])# _LT_SYS_DYNAMIC_LINKER # _LT_PATH_TOOL_PREFIX(TOOL) # -------------------------- # find a file program which can recognize shared library AC_DEFUN([_LT_PATH_TOOL_PREFIX], [m4_require([_LT_DECL_EGREP])dnl AC_MSG_CHECKING([for $1]) AC_CACHE_VAL(lt_cv_path_MAGIC_CMD, [case $MAGIC_CMD in [[\\/*] | ?:[\\/]*]) lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD="$MAGIC_CMD" lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR dnl $ac_dummy forces splitting on constant user-supplied paths. dnl POSIX.2 word splitting is done only on the output of word expansions, dnl not every word. This closes a longstanding sh security hole. ac_dummy="m4_if([$2], , $PATH, [$2])" for ac_dir in $ac_dummy; do IFS="$lt_save_ifs" test -z "$ac_dir" && ac_dir=. if test -f $ac_dir/$1; then lt_cv_path_MAGIC_CMD="$ac_dir/$1" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD="$lt_cv_path_MAGIC_CMD" if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS="$lt_save_ifs" MAGIC_CMD="$lt_save_MAGIC_CMD" ;; esac]) MAGIC_CMD="$lt_cv_path_MAGIC_CMD" if test -n "$MAGIC_CMD"; then AC_MSG_RESULT($MAGIC_CMD) else AC_MSG_RESULT(no) fi _LT_DECL([], [MAGIC_CMD], [0], [Used to examine libraries when file_magic_cmd begins with "file"])dnl ])# _LT_PATH_TOOL_PREFIX # Old name: AU_ALIAS([AC_PATH_TOOL_PREFIX], [_LT_PATH_TOOL_PREFIX]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_PATH_TOOL_PREFIX], []) # _LT_PATH_MAGIC # -------------- # find a file program which can recognize a shared library m4_defun([_LT_PATH_MAGIC], [_LT_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH) if test -z "$lt_cv_path_MAGIC_CMD"; then if test -n "$ac_tool_prefix"; then _LT_PATH_TOOL_PREFIX(file, /usr/bin$PATH_SEPARATOR$PATH) else MAGIC_CMD=: fi fi ])# _LT_PATH_MAGIC # LT_PATH_LD # ---------- # find the pathname to the GNU or non-GNU linker AC_DEFUN([LT_PATH_LD], [AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_PROG_ECHO_BACKSLASH])dnl AC_ARG_WITH([gnu-ld], [AS_HELP_STRING([--with-gnu-ld], [assume the C compiler uses GNU ld @<:@default=no@:>@])], [test "$withval" = no || with_gnu_ld=yes], [with_gnu_ld=no])dnl ac_prog=ld if test "$GCC" = yes; then # Check if gcc -print-prog-name=ld gives a path. AC_MSG_CHECKING([for ld used by $CC]) case $host in *-*-mingw*) # gcc leaves a trailing carriage return which upsets mingw ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; esac case $ac_prog in # Accept absolute paths. [[\\/]]* | ?:[[\\/]]*) re_direlt='/[[^/]][[^/]]*/\.\./' # Canonicalize the pathname of ld ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` done test -z "$LD" && LD="$ac_prog" ;; "") # If it fails, then pretend we aren't using GCC. ac_prog=ld ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac elif test "$with_gnu_ld" = yes; then AC_MSG_CHECKING([for GNU ld]) else AC_MSG_CHECKING([for non-GNU ld]) fi AC_CACHE_VAL(lt_cv_path_LD, [if test -z "$LD"; then lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS="$lt_save_ifs" test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then lt_cv_path_LD="$ac_dir/$ac_prog" # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$lt_cv_path_LD" -v 2>&1 &1 /dev/null 2>&1; then lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' else # Keep this pattern in sync with the one in func_win32_libid. lt_cv_deplibs_check_method='file_magic file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' lt_cv_file_magic_cmd='$OBJDUMP -f' fi ;; cegcc*) # use the weaker test based on 'objdump'. See mingw*. lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' lt_cv_file_magic_cmd='$OBJDUMP -f' ;; darwin* | rhapsody*) lt_cv_deplibs_check_method=pass_all ;; freebsd* | dragonfly*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then case $host_cpu in i*86 ) # Not sure whether the presence of OpenBSD here was a mistake. # Let's accept both of them until this is cleared up. lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[[3-9]]86 (compact )?demand paged shared library' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` ;; esac else lt_cv_deplibs_check_method=pass_all fi ;; haiku*) lt_cv_deplibs_check_method=pass_all ;; hpux10.20* | hpux11*) lt_cv_file_magic_cmd=/usr/bin/file case $host_cpu in ia64*) lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|ELF-[[0-9]][[0-9]]) shared object file - IA64' lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so ;; hppa*64*) [lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF[ -][0-9][0-9])(-bit)?( [LM]SB)? shared object( file)?[, -]* PA-RISC [0-9]\.[0-9]'] lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl ;; *) lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|PA-RISC[[0-9]]\.[[0-9]]) shared library' lt_cv_file_magic_test_file=/usr/lib/libc.sl ;; esac ;; interix[[3-9]]*) # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|\.a)$' ;; irix5* | irix6* | nonstopux*) case $LD in *-32|*"-32 ") libmagic=32-bit;; *-n32|*"-n32 ") libmagic=N32;; *-64|*"-64 ") libmagic=64-bit;; *) libmagic=never-match;; esac lt_cv_deplibs_check_method=pass_all ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) lt_cv_deplibs_check_method=pass_all ;; netbsd* | netbsdelf*-gnu) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|_pic\.a)$' fi ;; newos6*) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (executable|dynamic lib)' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=/usr/lib/libnls.so ;; *nto* | *qnx*) lt_cv_deplibs_check_method=pass_all ;; openbsd*) if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|\.so|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' fi ;; osf3* | osf4* | osf5*) lt_cv_deplibs_check_method=pass_all ;; rdos*) lt_cv_deplibs_check_method=pass_all ;; solaris*) lt_cv_deplibs_check_method=pass_all ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) lt_cv_deplibs_check_method=pass_all ;; sysv4 | sysv4.3*) case $host_vendor in motorola) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib) M[[0-9]][[0-9]]* Version [[0-9]]' lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` ;; ncr) lt_cv_deplibs_check_method=pass_all ;; sequent) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB (shared object|dynamic lib )' ;; sni) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method="file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB dynamic lib" lt_cv_file_magic_test_file=/lib/libc.so ;; siemens) lt_cv_deplibs_check_method=pass_all ;; pc) lt_cv_deplibs_check_method=pass_all ;; esac ;; tpf*) lt_cv_deplibs_check_method=pass_all ;; esac ]) file_magic_glob= want_nocaseglob=no if test "$build" = "$host"; then case $host_os in mingw* | pw32*) if ( shopt | grep nocaseglob ) >/dev/null 2>&1; then want_nocaseglob=yes else file_magic_glob=`echo aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ | $SED -e "s/\(..\)/s\/[[\1]]\/[[\1]]\/g;/g"` fi ;; esac fi file_magic_cmd=$lt_cv_file_magic_cmd deplibs_check_method=$lt_cv_deplibs_check_method test -z "$deplibs_check_method" && deplibs_check_method=unknown _LT_DECL([], [deplibs_check_method], [1], [Method to check whether dependent libraries are shared objects]) _LT_DECL([], [file_magic_cmd], [1], [Command to use when deplibs_check_method = "file_magic"]) _LT_DECL([], [file_magic_glob], [1], [How to find potential files when deplibs_check_method = "file_magic"]) _LT_DECL([], [want_nocaseglob], [1], [Find potential files using nocaseglob when deplibs_check_method = "file_magic"]) ])# _LT_CHECK_MAGIC_METHOD # LT_PATH_NM # ---------- # find the pathname to a BSD- or MS-compatible name lister AC_DEFUN([LT_PATH_NM], [AC_REQUIRE([AC_PROG_CC])dnl AC_CACHE_CHECK([for BSD- or MS-compatible name lister (nm)], lt_cv_path_NM, [if test -n "$NM"; then # Let the user override the test. lt_cv_path_NM="$NM" else lt_nm_to_check="${ac_tool_prefix}nm" if test -n "$ac_tool_prefix" && test "$build" = "$host"; then lt_nm_to_check="$lt_nm_to_check nm" fi for lt_tmp_nm in $lt_nm_to_check; do lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do IFS="$lt_save_ifs" test -z "$ac_dir" && ac_dir=. tmp_nm="$ac_dir/$lt_tmp_nm" if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then # Check to see if the nm accepts a BSD-compat flag. # Adding the `sed 1q' prevents false positives on HP-UX, which says: # nm: unknown option "B" ignored # Tru64's nm complains that /dev/null is an invalid object file case `"$tmp_nm" -B /dev/null 2>&1 | sed '1q'` in */dev/null* | *'Invalid file or object type'*) lt_cv_path_NM="$tmp_nm -B" break ;; *) case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in */dev/null*) lt_cv_path_NM="$tmp_nm -p" break ;; *) lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but continue # so that we can try to find one that supports BSD flags ;; esac ;; esac fi done IFS="$lt_save_ifs" done : ${lt_cv_path_NM=no} fi]) if test "$lt_cv_path_NM" != "no"; then NM="$lt_cv_path_NM" else # Didn't find any BSD compatible name lister, look for dumpbin. if test -n "$DUMPBIN"; then : # Let the user override the test. else AC_CHECK_TOOLS(DUMPBIN, [dumpbin "link -dump"], :) case `$DUMPBIN -symbols /dev/null 2>&1 | sed '1q'` in *COFF*) DUMPBIN="$DUMPBIN -symbols" ;; *) DUMPBIN=: ;; esac fi AC_SUBST([DUMPBIN]) if test "$DUMPBIN" != ":"; then NM="$DUMPBIN" fi fi test -z "$NM" && NM=nm AC_SUBST([NM]) _LT_DECL([], [NM], [1], [A BSD- or MS-compatible name lister])dnl AC_CACHE_CHECK([the name lister ($NM) interface], [lt_cv_nm_interface], [lt_cv_nm_interface="BSD nm" echo "int some_variable = 0;" > conftest.$ac_ext (eval echo "\"\$as_me:$LINENO: $ac_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$ac_compile" 2>conftest.err) cat conftest.err >&AS_MESSAGE_LOG_FD (eval echo "\"\$as_me:$LINENO: $NM \\\"conftest.$ac_objext\\\"\"" >&AS_MESSAGE_LOG_FD) (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) cat conftest.err >&AS_MESSAGE_LOG_FD (eval echo "\"\$as_me:$LINENO: output\"" >&AS_MESSAGE_LOG_FD) cat conftest.out >&AS_MESSAGE_LOG_FD if $GREP 'External.*some_variable' conftest.out > /dev/null; then lt_cv_nm_interface="MS dumpbin" fi rm -f conftest*]) ])# LT_PATH_NM # Old names: AU_ALIAS([AM_PROG_NM], [LT_PATH_NM]) AU_ALIAS([AC_PROG_NM], [LT_PATH_NM]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_PROG_NM], []) dnl AC_DEFUN([AC_PROG_NM], []) # _LT_CHECK_SHAREDLIB_FROM_LINKLIB # -------------------------------- # how to determine the name of the shared library # associated with a specific link library. # -- PORTME fill in with the dynamic library characteristics m4_defun([_LT_CHECK_SHAREDLIB_FROM_LINKLIB], [m4_require([_LT_DECL_EGREP]) m4_require([_LT_DECL_OBJDUMP]) m4_require([_LT_DECL_DLLTOOL]) AC_CACHE_CHECK([how to associate runtime and link libraries], lt_cv_sharedlib_from_linklib_cmd, [lt_cv_sharedlib_from_linklib_cmd='unknown' case $host_os in cygwin* | mingw* | pw32* | cegcc*) # two different shell functions defined in ltmain.sh # decide which to use based on capabilities of $DLLTOOL case `$DLLTOOL --help 2>&1` in *--identify-strict*) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib ;; *) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib_fallback ;; esac ;; *) # fallback: assume linklib IS sharedlib lt_cv_sharedlib_from_linklib_cmd="$ECHO" ;; esac ]) sharedlib_from_linklib_cmd=$lt_cv_sharedlib_from_linklib_cmd test -z "$sharedlib_from_linklib_cmd" && sharedlib_from_linklib_cmd=$ECHO _LT_DECL([], [sharedlib_from_linklib_cmd], [1], [Command to associate shared and link libraries]) ])# _LT_CHECK_SHAREDLIB_FROM_LINKLIB # _LT_PATH_MANIFEST_TOOL # ---------------------- # locate the manifest tool m4_defun([_LT_PATH_MANIFEST_TOOL], [AC_CHECK_TOOL(MANIFEST_TOOL, mt, :) test -z "$MANIFEST_TOOL" && MANIFEST_TOOL=mt AC_CACHE_CHECK([if $MANIFEST_TOOL is a manifest tool], [lt_cv_path_mainfest_tool], [lt_cv_path_mainfest_tool=no echo "$as_me:$LINENO: $MANIFEST_TOOL '-?'" >&AS_MESSAGE_LOG_FD $MANIFEST_TOOL '-?' 2>conftest.err > conftest.out cat conftest.err >&AS_MESSAGE_LOG_FD if $GREP 'Manifest Tool' conftest.out > /dev/null; then lt_cv_path_mainfest_tool=yes fi rm -f conftest*]) if test "x$lt_cv_path_mainfest_tool" != xyes; then MANIFEST_TOOL=: fi _LT_DECL([], [MANIFEST_TOOL], [1], [Manifest tool])dnl ])# _LT_PATH_MANIFEST_TOOL # LT_LIB_M # -------- # check for math library AC_DEFUN([LT_LIB_M], [AC_REQUIRE([AC_CANONICAL_HOST])dnl LIBM= case $host in *-*-beos* | *-*-cegcc* | *-*-cygwin* | *-*-haiku* | *-*-pw32* | *-*-darwin*) # These system don't have libm, or don't need it ;; *-ncr-sysv4.3*) AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM="-lmw") AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm") ;; *) AC_CHECK_LIB(m, cos, LIBM="-lm") ;; esac AC_SUBST([LIBM]) ])# LT_LIB_M # Old name: AU_ALIAS([AC_CHECK_LIBM], [LT_LIB_M]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_CHECK_LIBM], []) # _LT_COMPILER_NO_RTTI([TAGNAME]) # ------------------------------- m4_defun([_LT_COMPILER_NO_RTTI], [m4_require([_LT_TAG_COMPILER])dnl _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= if test "$GCC" = yes; then case $cc_basename in nvcc*) _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -Xcompiler -fno-builtin' ;; *) _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' ;; esac _LT_COMPILER_OPTION([if $compiler supports -fno-rtti -fno-exceptions], lt_cv_prog_compiler_rtti_exceptions, [-fno-rtti -fno-exceptions], [], [_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)="$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) -fno-rtti -fno-exceptions"]) fi _LT_TAGDECL([no_builtin_flag], [lt_prog_compiler_no_builtin_flag], [1], [Compiler flag to turn off builtin functions]) ])# _LT_COMPILER_NO_RTTI # _LT_CMD_GLOBAL_SYMBOLS # ---------------------- m4_defun([_LT_CMD_GLOBAL_SYMBOLS], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([AC_PROG_AWK])dnl AC_REQUIRE([LT_PATH_NM])dnl AC_REQUIRE([LT_PATH_LD])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_TAG_COMPILER])dnl # Check for command to grab the raw symbol name followed by C symbol from nm. AC_MSG_CHECKING([command to parse $NM output from $compiler object]) AC_CACHE_VAL([lt_cv_sys_global_symbol_pipe], [ # These are sane defaults that work on at least a few old systems. # [They come from Ultrix. What could be older than Ultrix?!! ;)] # Character class describing NM global symbol codes. symcode='[[BCDEGRST]]' # Regexp to match symbols that can be accessed directly from C. sympat='\([[_A-Za-z]][[_A-Za-z0-9]]*\)' # Define system-specific variables. case $host_os in aix*) symcode='[[BCDT]]' ;; cygwin* | mingw* | pw32* | cegcc*) symcode='[[ABCDGISTW]]' ;; hpux*) if test "$host_cpu" = ia64; then symcode='[[ABCDEGRST]]' fi ;; irix* | nonstopux*) symcode='[[BCDEGRST]]' ;; osf*) symcode='[[BCDEGQRST]]' ;; solaris*) symcode='[[BDRT]]' ;; sco3.2v5*) symcode='[[DT]]' ;; sysv4.2uw2*) symcode='[[DT]]' ;; sysv5* | sco5v6* | unixware* | OpenUNIX*) symcode='[[ABDT]]' ;; sysv4) symcode='[[DFNSTU]]' ;; esac # If we're using GNU nm, then use its standard symbol codes. case `$NM -V 2>&1` in *GNU* | *'with BFD'*) symcode='[[ABCDGIRSTW]]' ;; esac # Transform an extracted symbol line into a proper C declaration. # Some systems (esp. on ia64) link data and code symbols differently, # so use this general approach. lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'" # Transform an extracted symbol line into symbol name and symbol address lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([[^ ]]*\)[[ ]]*$/ {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/ {\"\2\", (void *) \&\2},/p'" lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n -e 's/^: \([[^ ]]*\)[[ ]]*$/ {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \(lib[[^ ]]*\)$/ {\"\2\", (void *) \&\2},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/ {\"lib\2\", (void *) \&\2},/p'" # Handle CRLF in mingw tool chain opt_cr= case $build_os in mingw*) opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp ;; esac # Try without a prefix underscore, then with it. for ac_symprfx in "" "_"; do # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. symxfrm="\\1 $ac_symprfx\\2 \\2" # Write the raw and C identifiers. if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Fake it for dumpbin and say T for any non-static function # and D for any global variable. # Also find C++ and __fastcall symbols from MSVC++, # which start with @ or ?. lt_cv_sys_global_symbol_pipe="$AWK ['"\ " {last_section=section; section=\$ 3};"\ " /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\ " /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ " \$ 0!~/External *\|/{next};"\ " / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ " {if(hide[section]) next};"\ " {f=0}; \$ 0~/\(\).*\|/{f=1}; {printf f ? \"T \" : \"D \"};"\ " {split(\$ 0, a, /\||\r/); split(a[2], s)};"\ " s[1]~/^[@?]/{print s[1], s[1]; next};"\ " s[1]~prfx {split(s[1],t,\"@\"); print t[1], substr(t[1],length(prfx))}"\ " ' prfx=^$ac_symprfx]" else lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[[ ]]\($symcode$symcode*\)[[ ]][[ ]]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" fi lt_cv_sys_global_symbol_pipe="$lt_cv_sys_global_symbol_pipe | sed '/ __gnu_lto/d'" # Check to see that the pipe works correctly. pipe_works=no rm -f conftest* cat > conftest.$ac_ext <<_LT_EOF #ifdef __cplusplus extern "C" { #endif char nm_test_var; void nm_test_func(void); void nm_test_func(void){} #ifdef __cplusplus } #endif int main(){nm_test_var='a';nm_test_func();return(0);} _LT_EOF if AC_TRY_EVAL(ac_compile); then # Now try to grab the symbols. nlist=conftest.nm if AC_TRY_EVAL(NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) && test -s "$nlist"; then # Try sorting and uniquifying the output. if sort "$nlist" | uniq > "$nlist"T; then mv -f "$nlist"T "$nlist" else rm -f "$nlist"T fi # Make sure that we snagged all the symbols we need. if $GREP ' nm_test_var$' "$nlist" >/dev/null; then if $GREP ' nm_test_func$' "$nlist" >/dev/null; then cat <<_LT_EOF > conftest.$ac_ext /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined(_WIN32) || defined(__CYGWIN__) || defined(_WIN32_WCE) /* DATA imports from DLLs on WIN32 con't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT@&t@_DLSYM_CONST #elif defined(__osf__) /* This system does not cope well with relocations in const data. */ # define LT@&t@_DLSYM_CONST #else # define LT@&t@_DLSYM_CONST const #endif #ifdef __cplusplus extern "C" { #endif _LT_EOF # Now generate the symbol file. eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' cat <<_LT_EOF >> conftest.$ac_ext /* The mapping between symbol names and symbols. */ LT@&t@_DLSYM_CONST struct { const char *name; void *address; } lt__PROGRAM__LTX_preloaded_symbols[[]] = { { "@PROGRAM@", (void *) 0 }, _LT_EOF $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/ {\"\2\", (void *) \&\2},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext cat <<\_LT_EOF >> conftest.$ac_ext {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt__PROGRAM__LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif _LT_EOF # Now try linking the two files. mv conftest.$ac_objext conftstm.$ac_objext lt_globsym_save_LIBS=$LIBS lt_globsym_save_CFLAGS=$CFLAGS LIBS="conftstm.$ac_objext" CFLAGS="$CFLAGS$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)" if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext}; then pipe_works=yes fi LIBS=$lt_globsym_save_LIBS CFLAGS=$lt_globsym_save_CFLAGS else echo "cannot find nm_test_func in $nlist" >&AS_MESSAGE_LOG_FD fi else echo "cannot find nm_test_var in $nlist" >&AS_MESSAGE_LOG_FD fi else echo "cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD fi else echo "$progname: failed program was:" >&AS_MESSAGE_LOG_FD cat conftest.$ac_ext >&5 fi rm -rf conftest* conftst* # Do not use the global_symbol_pipe unless it works. if test "$pipe_works" = yes; then break else lt_cv_sys_global_symbol_pipe= fi done ]) if test -z "$lt_cv_sys_global_symbol_pipe"; then lt_cv_sys_global_symbol_to_cdecl= fi if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then AC_MSG_RESULT(failed) else AC_MSG_RESULT(ok) fi # Response file support. if test "$lt_cv_nm_interface" = "MS dumpbin"; then nm_file_list_spec='@' elif $NM --help 2>/dev/null | grep '[[@]]FILE' >/dev/null; then nm_file_list_spec='@' fi _LT_DECL([global_symbol_pipe], [lt_cv_sys_global_symbol_pipe], [1], [Take the output of nm and produce a listing of raw symbols and C names]) _LT_DECL([global_symbol_to_cdecl], [lt_cv_sys_global_symbol_to_cdecl], [1], [Transform the output of nm in a proper C declaration]) _LT_DECL([global_symbol_to_c_name_address], [lt_cv_sys_global_symbol_to_c_name_address], [1], [Transform the output of nm in a C name address pair]) _LT_DECL([global_symbol_to_c_name_address_lib_prefix], [lt_cv_sys_global_symbol_to_c_name_address_lib_prefix], [1], [Transform the output of nm in a C name address pair when lib prefix is needed]) _LT_DECL([], [nm_file_list_spec], [1], [Specify filename containing input files for $NM]) ]) # _LT_CMD_GLOBAL_SYMBOLS # _LT_COMPILER_PIC([TAGNAME]) # --------------------------- m4_defun([_LT_COMPILER_PIC], [m4_require([_LT_TAG_COMPILER])dnl _LT_TAGVAR(lt_prog_compiler_wl, $1)= _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)= m4_if([$1], [CXX], [ # C++ specific cases for pic, static, wl, etc. if test "$GXX" = yes; then _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' case $host_os in aix*) # All AIX code is PIC. if test "$host_cpu" = ia64; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the `-m68020' flag to GCC prevents building anything better, # like `-m68040'. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' ;; *djgpp*) # DJGPP does not support shared libraries at all _LT_TAGVAR(lt_prog_compiler_pic, $1)= ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. _LT_TAGVAR(lt_prog_compiler_static, $1)= ;; interix[[3-9]]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic fi ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac else case $host_os in aix[[4-9]]*) # All AIX code is PIC. if test "$host_cpu" = ia64; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' else _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' fi ;; chorus*) case $cc_basename in cxch68*) # Green Hills C++ Compiler # _LT_TAGVAR(lt_prog_compiler_static, $1)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" ;; esac ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) ;; dgux*) case $cc_basename in ec++*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' ;; ghcx*) # Green Hills C++ Compiler _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; *) ;; esac ;; freebsd* | dragonfly*) # FreeBSD uses GNU C++ ;; hpux9* | hpux10* | hpux11*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive' if test "$host_cpu" != ia64; then _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' fi ;; aCC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive' case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' ;; esac ;; *) ;; esac ;; interix*) # This is c89, which is MS Visual C++ (no shared libs) # Anyone wants to do a port? ;; irix5* | irix6* | nonstopux*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' # CC pic flag -KPIC is the default. ;; *) ;; esac ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # KAI C++ Compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; ecpc* ) # old Intel C++ for x86_64 which still supported -KPIC. _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; icpc* ) # Intel C++, used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; pgCC* | pgcpp*) # Portland Group C++ compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; cxx*) # Compaq C++ # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; xlc* | xlC* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL 8.0, 9.0 on PPC and BlueGene _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; esac ;; esac ;; lynxos*) ;; m88k*) ;; mvs*) case $cc_basename in cxx*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-W c,exportall' ;; *) ;; esac ;; netbsd* | netbsdelf*-gnu) ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' ;; RCC*) # Rational C++ 2.4.1 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; cxx*) # Digital/Compaq C++ _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; *) ;; esac ;; psos*) ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; gcx*) # Green Hills C++ Compiler _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' ;; *) ;; esac ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; lcc*) # Lucid _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; *) ;; esac ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' ;; *) ;; esac ;; vxworks*) ;; *) _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; esac fi ], [ if test "$GCC" = yes; then _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' case $host_os in aix*) # All AIX code is PIC. if test "$host_cpu" = ia64; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the `-m68020' flag to GCC prevents building anything better, # like `-m68040'. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. _LT_TAGVAR(lt_prog_compiler_static, $1)= ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac ;; interix[[3-9]]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; msdosdjgpp*) # Just because we use GCC doesn't mean we suddenly get shared libraries # on systems that don't support them. _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no enable_shared=no ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic fi ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac case $cc_basename in nvcc*) # Cuda Compiler Driver 2.2 _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Xlinker ' if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then _LT_TAGVAR(lt_prog_compiler_pic, $1)="-Xcompiler $_LT_TAGVAR(lt_prog_compiler_pic, $1)" fi ;; esac else # PORTME Check for flag to pass linker flags through the system compiler. case $host_os in aix*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' if test "$host_cpu" = ia64; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' else _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' fi ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) ;; hpux9* | hpux10* | hpux11*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but # not for PA HP-UX. case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' ;; esac # Is there a better lt_prog_compiler_static that works with the bundled CC? _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive' ;; irix5* | irix6* | nonstopux*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # PIC (with -KPIC) is the default. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in # old Intel for x86_64 which still supported -KPIC. ecc*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; # icc used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. icc* | ifort*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; # Lahey Fortran 8.1. lf95*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='--shared' _LT_TAGVAR(lt_prog_compiler_static, $1)='--static' ;; nagfor*) # NAG Fortran compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group compilers (*not* the Pentium gcc compiler, # which looks to be a dead project) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; ccc*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # All Alpha code is PIC. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; xl* | bgxl* | bgf* | mpixl*) # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [[1-7]].* | *Sun*Fortran*\ 8.[[0-3]]*) # Sun Fortran 8.3 passes all unrecognized flags to the linker _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='' ;; *Sun\ F* | *Sun*Fortran*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; *Sun\ C*) # Sun C 5.9 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' ;; *Intel*\ [[CF]]*Compiler*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; *Portland\ Group*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; esac ;; newsos6) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; osf3* | osf4* | osf5*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # All OSF/1 code is PIC. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; rdos*) _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; solaris*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ';; *) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,';; esac ;; sunos4*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; sysv4 | sysv4.2uw2* | sysv4.3*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; sysv4*MP*) if test -d /usr/nec ;then _LT_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; unicos*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; uts4*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; *) _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; esac fi ]) case $host_os in # For platforms which do not support PIC, -DPIC is meaningless: *djgpp*) _LT_TAGVAR(lt_prog_compiler_pic, $1)= ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)="$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])" ;; esac AC_CACHE_CHECK([for $compiler option to produce PIC], [_LT_TAGVAR(lt_cv_prog_compiler_pic, $1)], [_LT_TAGVAR(lt_cv_prog_compiler_pic, $1)=$_LT_TAGVAR(lt_prog_compiler_pic, $1)]) _LT_TAGVAR(lt_prog_compiler_pic, $1)=$_LT_TAGVAR(lt_cv_prog_compiler_pic, $1) # # Check to make sure the PIC flag actually works. # if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then _LT_COMPILER_OPTION([if $compiler PIC flag $_LT_TAGVAR(lt_prog_compiler_pic, $1) works], [_LT_TAGVAR(lt_cv_prog_compiler_pic_works, $1)], [$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])], [], [case $_LT_TAGVAR(lt_prog_compiler_pic, $1) in "" | " "*) ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)=" $_LT_TAGVAR(lt_prog_compiler_pic, $1)" ;; esac], [_LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no]) fi _LT_TAGDECL([pic_flag], [lt_prog_compiler_pic], [1], [Additional compiler flags for building library objects]) _LT_TAGDECL([wl], [lt_prog_compiler_wl], [1], [How to pass a linker flag through the compiler]) # # Check to make sure the static flag actually works. # wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) eval lt_tmp_static_flag=\"$_LT_TAGVAR(lt_prog_compiler_static, $1)\" _LT_LINKER_OPTION([if $compiler static flag $lt_tmp_static_flag works], _LT_TAGVAR(lt_cv_prog_compiler_static_works, $1), $lt_tmp_static_flag, [], [_LT_TAGVAR(lt_prog_compiler_static, $1)=]) _LT_TAGDECL([link_static_flag], [lt_prog_compiler_static], [1], [Compiler flag to prevent dynamic linking]) ])# _LT_COMPILER_PIC # _LT_LINKER_SHLIBS([TAGNAME]) # ---------------------------- # See if the linker supports building shared libraries. m4_defun([_LT_LINKER_SHLIBS], [AC_REQUIRE([LT_PATH_LD])dnl AC_REQUIRE([LT_PATH_NM])dnl m4_require([_LT_PATH_MANIFEST_TOOL])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl m4_require([_LT_TAG_COMPILER])dnl AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) m4_if([$1], [CXX], [ _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] case $host_os in aix[[4-9]]*) # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to AIX nm, but means don't demangle with GNU nm # Also, AIX nm treats weak defined symbols like other global defined # symbols, whereas GNU nm marks them as "W". if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' else _LT_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' fi ;; pw32*) _LT_TAGVAR(export_symbols_cmds, $1)="$ltdll_cmds" ;; cygwin* | mingw* | cegcc*) case $cc_basename in cl*) _LT_TAGVAR(exclude_expsyms, $1)='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' ;; *) _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'] ;; esac ;; linux* | k*bsd*-gnu | gnu*) _LT_TAGVAR(link_all_deplibs, $1)=no ;; *) _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' ;; esac ], [ runpath_var= _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_cmds, $1)= _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(compiler_needs_object, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(old_archive_from_new_cmds, $1)= _LT_TAGVAR(old_archive_from_expsyms_cmds, $1)= _LT_TAGVAR(thread_safe_flag_spec, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= # include_expsyms should be a list of space-separated symbols to be *always* # included in the symbol list _LT_TAGVAR(include_expsyms, $1)= # exclude_expsyms can be an extended regexp of symbols to exclude # it will be wrapped by ` (' and `)$', so one must not match beginning or # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', # as well as any symbol that contains `d'. _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out # platforms (ab)use it in PIC code, but their linkers get confused if # the symbol is explicitly referenced. Since portable code cannot # rely on this symbol name, it's probably fine to never include it in # preloaded symbol tables. # Exclude shared library initialization/finalization symbols. dnl Note also adjust exclude_expsyms for C++ above. extract_expsyms_cmds= case $host_os in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++. if test "$GCC" != yes; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++) with_gnu_ld=yes ;; openbsd*) with_gnu_ld=no ;; linux* | k*bsd*-gnu | gnu*) _LT_TAGVAR(link_all_deplibs, $1)=no ;; esac _LT_TAGVAR(ld_shlibs, $1)=yes # On some targets, GNU ld is compatible enough with the native linker # that we're better off using the native interface for both. lt_use_gnu_ld_interface=no if test "$with_gnu_ld" = yes; then case $host_os in aix*) # The AIX port of GNU ld has always aspired to compatibility # with the native linker. However, as the warning in the GNU ld # block says, versions before 2.19.5* couldn't really create working # shared libraries, regardless of the interface used. case `$LD -v 2>&1` in *\ \(GNU\ Binutils\)\ 2.19.5*) ;; *\ \(GNU\ Binutils\)\ 2.[[2-9]]*) ;; *\ \(GNU\ Binutils\)\ [[3-9]]*) ;; *) lt_use_gnu_ld_interface=yes ;; esac ;; *) lt_use_gnu_ld_interface=yes ;; esac fi if test "$lt_use_gnu_ld_interface" = yes; then # If archive_cmds runs LD, not CC, wlarc should be empty wlarc='${wl}' # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. runpath_var=LD_RUN_PATH _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' # ancient GNU ld didn't support --whole-archive et. al. if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' else _LT_TAGVAR(whole_archive_flag_spec, $1)= fi supports_anon_versioning=no case `$LD -v 2>&1` in *GNU\ gold*) supports_anon_versioning=yes ;; *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.10.*) ;; # catch versions < 2.11 *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... *\ 2.11.*) ;; # other 2.11 versions *) supports_anon_versioning=yes ;; esac # See if GNU ld supports shared libraries. case $host_os in aix[[3-9]]*) # On AIX/PPC, the GNU linker is very broken if test "$host_cpu" != ia64; then _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: the GNU linker, at least up to release 2.19, is reported *** to be unable to reliably create shared libraries on AIX. *** Therefore, libtool is disabling shared libraries support. If you *** really care for shared libraries, you may want to install binutils *** 2.20 or above, or modify your PATH so that a non-GNU linker is found. *** You will then need to restart the configuration process. _LT_EOF fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='' ;; m68k) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, # as there is no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-all-symbols' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'] if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file (1st line # is EXPORTS), use it as is; otherwise, prepend... _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; haiku*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' _LT_TAGVAR(link_all_deplibs, $1)=yes ;; interix[[3-9]]*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) tmp_diet=no if test "$host_os" = linux-dietlibc; then case $cc_basename in diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) esac fi if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ && test "$tmp_diet" = no then tmp_addflag=' $pic_flag' tmp_sharedflag='-shared' case $cc_basename,$host_cpu in pgcc*) # Portland Group C compiler _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' tmp_addflag=' $pic_flag' ;; pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group f77 and f90 compilers _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' tmp_addflag=' $pic_flag -Mnomain' ;; ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 tmp_addflag=' -i_dynamic' ;; efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 tmp_addflag=' -i_dynamic -nofor_main' ;; ifc* | ifort*) # Intel Fortran compiler tmp_addflag=' -nofor_main' ;; lf95*) # Lahey Fortran 8.1 _LT_TAGVAR(whole_archive_flag_spec, $1)= tmp_sharedflag='--shared' ;; xl[[cC]]* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL C 8.0 on PPC (deal with xlf below) tmp_sharedflag='-qmkshrobj' tmp_addflag= ;; nvcc*) # Cuda Compiler Driver 2.2 _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes ;; esac case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C 5.9 _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes tmp_sharedflag='-G' ;; *Sun\ F*) # Sun Fortran 8.3 tmp_sharedflag='-G' ;; esac _LT_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' if test "x$supports_anon_versioning" = xyes; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' fi case $cc_basename in xlf* | bgf* | bgxlf* | mpixlf*) # IBM XL Fortran 10.1 on PPC cannot create shared libs itself _LT_TAGVAR(whole_archive_flag_spec, $1)='--whole-archive$convenience --no-whole-archive' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' _LT_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' if test "x$supports_anon_versioning" = xyes; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' fi ;; esac else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; netbsd* | netbsdelf*-gnu) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' wlarc= else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' fi ;; solaris*) if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: The releases 2.8.* of the GNU linker cannot reliably *** create shared libraries on Solaris systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.9.1 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.1[[0-5]].*) _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not *** reliably create shared libraries on SCO systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.16.91.0.3 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF ;; *) # For security reasons, it is highly recommended that you always # use absolute paths for naming shared libraries, and exclude the # DT_RUNPATH tag from executables and libraries. But doing so # requires that you compile everything twice, which is a pain. if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; sunos4*) _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' wlarc= _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac if test "$_LT_TAGVAR(ld_shlibs, $1)" = no; then runpath_var= _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= fi else # PORTME fill in a description of your system's linker (not GNU ld) case $host_os in aix3*) _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. _LT_TAGVAR(hardcode_minus_L, $1)=yes if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. _LT_TAGVAR(hardcode_direct, $1)=unsupported fi ;; aix[[4-9]]*) if test "$host_cpu" = ia64; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag="" else # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to AIX nm, but means don't demangle with GNU nm # Also, AIX nm treats weak defined symbols like other global # defined symbols, whereas GNU nm marks them as "W". if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' else _LT_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' fi aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # need to do runtime linking. case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) for ld_flag in $LDFLAGS; do if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then aix_use_runtimelinking=yes break fi done ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. _LT_TAGVAR(archive_cmds, $1)='' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(file_list_spec, $1)='${wl}-f,' if test "$GCC" = yes; then case $host_os in aix4.[[012]]|aix4.[[012]].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`${CC} -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 _LT_TAGVAR(hardcode_direct, $1)=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)= fi ;; esac shared_flag='-shared' if test "$aix_use_runtimelinking" = yes; then shared_flag="$shared_flag "'${wl}-G' fi _LT_TAGVAR(link_all_deplibs, $1)=no else # not using gcc if test "$host_cpu" = ia64; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test "$aix_use_runtimelinking" = yes; then shared_flag='${wl}-G' else shared_flag='${wl}-bM:SRE' fi fi fi _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to export. _LT_TAGVAR(always_export_symbols, $1)=yes if test "$aix_use_runtimelinking" = yes; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. _LT_TAGVAR(allow_undefined_flag, $1)='-berok' # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then func_echo_all "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" else if test "$host_cpu" = ia64; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib' _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. _LT_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok' _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok' if test "$with_gnu_ld" = yes; then # We only use this code for GNU lds that support --whole-archive. _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' fi _LT_TAGVAR(archive_cmds_need_lc, $1)=yes # This is similar to how AIX traditionally builds its shared libraries. _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' fi fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='' ;; m68k) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac ;; bsdi[[45]]*) _LT_TAGVAR(export_dynamic_flag_spec, $1)=-rdynamic ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. case $cc_basename in cl*) # Native MSVC _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=".dll" # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-dll~linknames=' _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then sed -n -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' -e '1\\\!p' < $export_symbols > $output_objdir/$soname.exp; else sed -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(exclude_expsyms, $1)='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1,DATA/'\'' | $SED -e '\''/^[[AITW]][[ ]]/s/.*[[ ]]//'\'' | sort | uniq > $export_symbols' # Don't use ranlib _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib' _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile="$lt_outputfile.exe" lt_tool_outputfile="$lt_tool_outputfile.exe" ;; esac~ if test "$MANIFEST_TOOL" != ":" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # Assume MSVC wrapper _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=".dll" # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' # The linker will automatically build a .lib file if we build a DLL. _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' # FIXME: Should let the user specify the lib program. _LT_TAGVAR(old_archive_cmds, $1)='lib -OUT:$oldlib$oldobjs$old_deplibs' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; esac ;; darwin* | rhapsody*) _LT_DARWIN_LINKER_FEATURES($1) ;; dgux*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor # support. Future versions do this automatically, but an explicit c++rt0.o # does not break anything, and helps significantly (at the cost of a little # extra space). freebsd2.2*) _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # Unfortunately, older versions of FreeBSD 2 do not have this feature. freebsd2.*) _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # FreeBSD 3 and greater uses gcc -shared to do shared libraries. freebsd* | dragonfly*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; hpux9*) if test "$GCC" = yes; then _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared $pic_flag ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' else _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_direct, $1)=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' ;; hpux10*) if test "$GCC" = yes && test "$with_gnu_ld" = no; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi if test "$with_gnu_ld" = no; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes fi ;; hpux11*) if test "$GCC" = yes && test "$with_gnu_ld" = no; then case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' ;; esac else case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) m4_if($1, [], [ # Older versions of the 11.00 compiler do not understand -b yet # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does) _LT_LINKER_OPTION([if $CC understands -b], _LT_TAGVAR(lt_cv_prog_compiler__b, $1), [-b], [_LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'], [_LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'])], [_LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags']) ;; esac fi if test "$with_gnu_ld" = no; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: case $host_cpu in hppa*64*|ia64*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) if test "$GCC" = yes; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' # Try to use the -exported_symbol ld option, if it does not # work, assume that -exports_file does not work either and # implicitly export all symbols. # This should be the same for all languages, so no per-tag cache variable. AC_CACHE_CHECK([whether the $host_os linker accepts -exported_symbol], [lt_cv_irix_exported_symbol], [save_LDFLAGS="$LDFLAGS" LDFLAGS="$LDFLAGS -shared ${wl}-exported_symbol ${wl}foo ${wl}-update_registry ${wl}/dev/null" AC_LINK_IFELSE( [AC_LANG_SOURCE( [AC_LANG_CASE([C], [[int foo (void) { return 0; }]], [C++], [[int foo (void) { return 0; }]], [Fortran 77], [[ subroutine foo end]], [Fortran], [[ subroutine foo end]])])], [lt_cv_irix_exported_symbol=yes], [lt_cv_irix_exported_symbol=no]) LDFLAGS="$save_LDFLAGS"]) if test "$lt_cv_irix_exported_symbol" = yes; then _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations ${wl}-exports_file ${wl}$export_symbols -o $lib' fi else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -exports_file $export_symbols -o $lib' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(inherit_rpath, $1)=yes _LT_TAGVAR(link_all_deplibs, $1)=yes ;; netbsd* | netbsdelf*-gnu) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out else _LT_TAGVAR(archive_cmds, $1)='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; newsos6) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *nto* | *qnx*) ;; openbsd*) if test -f /usr/libexec/ld.so; then _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=yes if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' else case $host_os in openbsd[[01]].* | openbsd2.[[0-7]] | openbsd2.[[0-7]].*) _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' ;; esac fi else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~echo DATA >> $output_objdir/$libname.def~echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' _LT_TAGVAR(old_archive_from_new_cmds, $1)='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' ;; osf3*) if test "$GCC" = yes; then _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' else _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: ;; osf4* | osf5*) # as osf3* with the addition of -msym flag if test "$GCC" = yes; then _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $pic_flag $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' else _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ $CC -shared${allow_undefined_flag} ${wl}-input ${wl}$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib~$RM $lib.exp' # Both c and cxx compiler support -rpath directly _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_separator, $1)=: ;; solaris*) _LT_TAGVAR(no_undefined_flag, $1)=' -z defs' if test "$GCC" = yes; then wlarc='${wl}' _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' else case `$CC -V 2>&1` in *"Compilers 5.0"*) wlarc='' _LT_TAGVAR(archive_cmds, $1)='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' ;; *) wlarc='${wl}' _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' ;; esac fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands `-z linker_flag'. GCC discards it without `$wl', # but is careful enough not to reorder. # Supported since Solaris 2.6 (maybe 2.5.1?) if test "$GCC" = yes; then _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' else _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' fi ;; esac _LT_TAGVAR(link_all_deplibs, $1)=yes ;; sunos4*) if test "x$host_vendor" = xsequent; then # Use $CC to link under sequent, because it throws in some extra .o # files that make .init and .fini sections work. _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; sysv4) case $host_vendor in sni) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes # is this really true??? ;; siemens) ## LD is ld it makes a PLAMLIB ## CC just makes a GrossModule. _LT_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(reload_cmds, $1)='$CC -r -o $output$reload_objs' _LT_TAGVAR(hardcode_direct, $1)=no ;; motorola) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=no #Motorola manual says yes, but my tests say they lie ;; esac runpath_var='LD_RUN_PATH' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; sysv4.3*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)='-Bexport' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var=LD_RUN_PATH hardcode_runpath_var=yes _LT_TAGVAR(ld_shlibs, $1)=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var='LD_RUN_PATH' if test "$GCC" = yes; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We can NOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text' _LT_TAGVAR(allow_undefined_flag, $1)='${wl}-z,nodefs' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport' runpath_var='LD_RUN_PATH' if test "$GCC" = yes; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; uts4*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(ld_shlibs, $1)=no ;; esac if test x$host_vendor = xsni; then case $host in sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Blargedynsym' ;; esac fi fi ]) AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) test "$_LT_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no _LT_TAGVAR(with_gnu_ld, $1)=$with_gnu_ld _LT_DECL([], [libext], [0], [Old archive suffix (normally "a")])dnl _LT_DECL([], [shrext_cmds], [1], [Shared library suffix (normally ".so")])dnl _LT_DECL([], [extract_expsyms_cmds], [2], [The commands to extract the exported symbol list from a shared archive]) # # Do we need to explicitly link libc? # case "x$_LT_TAGVAR(archive_cmds_need_lc, $1)" in x|xyes) # Assume -lc should be added _LT_TAGVAR(archive_cmds_need_lc, $1)=yes if test "$enable_shared" = yes && test "$GCC" = yes; then case $_LT_TAGVAR(archive_cmds, $1) in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. AC_CACHE_CHECK([whether -lc should be explicitly linked in], [lt_cv_]_LT_TAGVAR(archive_cmds_need_lc, $1), [$RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if AC_TRY_EVAL(ac_compile) 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) pic_flag=$_LT_TAGVAR(lt_prog_compiler_pic, $1) compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$_LT_TAGVAR(allow_undefined_flag, $1) _LT_TAGVAR(allow_undefined_flag, $1)= if AC_TRY_EVAL(_LT_TAGVAR(archive_cmds, $1) 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) then lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1)=no else lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1)=yes fi _LT_TAGVAR(allow_undefined_flag, $1)=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* ]) _LT_TAGVAR(archive_cmds_need_lc, $1)=$lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1) ;; esac fi ;; esac _LT_TAGDECL([build_libtool_need_lc], [archive_cmds_need_lc], [0], [Whether or not to add -lc for building shared libraries]) _LT_TAGDECL([allow_libtool_libs_with_static_runtimes], [enable_shared_with_static_runtimes], [0], [Whether or not to disallow shared libs when runtime libs are static]) _LT_TAGDECL([], [export_dynamic_flag_spec], [1], [Compiler flag to allow reflexive dlopens]) _LT_TAGDECL([], [whole_archive_flag_spec], [1], [Compiler flag to generate shared objects directly from archives]) _LT_TAGDECL([], [compiler_needs_object], [1], [Whether the compiler copes with passing no objects directly]) _LT_TAGDECL([], [old_archive_from_new_cmds], [2], [Create an old-style archive from a shared archive]) _LT_TAGDECL([], [old_archive_from_expsyms_cmds], [2], [Create a temporary old-style archive to link instead of a shared archive]) _LT_TAGDECL([], [archive_cmds], [2], [Commands used to build a shared archive]) _LT_TAGDECL([], [archive_expsym_cmds], [2]) _LT_TAGDECL([], [module_cmds], [2], [Commands used to build a loadable module if different from building a shared archive.]) _LT_TAGDECL([], [module_expsym_cmds], [2]) _LT_TAGDECL([], [with_gnu_ld], [1], [Whether we are building with GNU ld or not]) _LT_TAGDECL([], [allow_undefined_flag], [1], [Flag that allows shared libraries with undefined symbols to be built]) _LT_TAGDECL([], [no_undefined_flag], [1], [Flag that enforces no undefined symbols]) _LT_TAGDECL([], [hardcode_libdir_flag_spec], [1], [Flag to hardcode $libdir into a binary during linking. This must work even if $libdir does not exist]) _LT_TAGDECL([], [hardcode_libdir_separator], [1], [Whether we need a single "-rpath" flag with a separated argument]) _LT_TAGDECL([], [hardcode_direct], [0], [Set to "yes" if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_direct_absolute], [0], [Set to "yes" if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the resulting binary and the resulting library dependency is "absolute", i.e impossible to change by setting ${shlibpath_var} if the library is relocated]) _LT_TAGDECL([], [hardcode_minus_L], [0], [Set to "yes" if using the -LDIR flag during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_shlibpath_var], [0], [Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_automatic], [0], [Set to "yes" if building a shared library automatically hardcodes DIR into the library and all subsequent libraries and executables linked against it]) _LT_TAGDECL([], [inherit_rpath], [0], [Set to yes if linker adds runtime paths of dependent libraries to runtime path list]) _LT_TAGDECL([], [link_all_deplibs], [0], [Whether libtool must link a program against all its dependency libraries]) _LT_TAGDECL([], [always_export_symbols], [0], [Set to "yes" if exported symbols are required]) _LT_TAGDECL([], [export_symbols_cmds], [2], [The commands to list exported symbols]) _LT_TAGDECL([], [exclude_expsyms], [1], [Symbols that should not be listed in the preloaded symbols]) _LT_TAGDECL([], [include_expsyms], [1], [Symbols that must always be exported]) _LT_TAGDECL([], [prelink_cmds], [2], [Commands necessary for linking programs (against libraries) with templates]) _LT_TAGDECL([], [postlink_cmds], [2], [Commands necessary for finishing linking programs]) _LT_TAGDECL([], [file_list_spec], [1], [Specify filename containing input files]) dnl FIXME: Not yet implemented dnl _LT_TAGDECL([], [thread_safe_flag_spec], [1], dnl [Compiler flag to generate thread safe objects]) ])# _LT_LINKER_SHLIBS # _LT_LANG_C_CONFIG([TAG]) # ------------------------ # Ensure that the configuration variables for a C compiler are suitably # defined. These variables are subsequently used by _LT_CONFIG to write # the compiler configuration to `libtool'. m4_defun([_LT_LANG_C_CONFIG], [m4_require([_LT_DECL_EGREP])dnl lt_save_CC="$CC" AC_LANG_PUSH(C) # Source file extension for C test sources. ac_ext=c # Object file extension for compiled C test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(){return(0);}' _LT_TAG_COMPILER # Save the default compiler, since it gets overwritten when the other # tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. compiler_DEFAULT=$CC # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) LT_SYS_DLOPEN_SELF _LT_CMD_STRIPLIB # Report which library types will actually be built AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test "$can_build_shared" = "no" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test "$enable_shared" = yes && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then test "$enable_shared" = yes && enable_static=no fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test "$enable_shared" = yes || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_CONFIG($1) fi AC_LANG_POP CC="$lt_save_CC" ])# _LT_LANG_C_CONFIG # _LT_LANG_CXX_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for a C++ compiler are suitably # defined. These variables are subsequently used by _LT_CONFIG to write # the compiler configuration to `libtool'. m4_defun([_LT_LANG_CXX_CONFIG], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_PATH_MANIFEST_TOOL])dnl if test -n "$CXX" && ( test "X$CXX" != "Xno" && ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) || (test "X$CXX" != "Xg++"))) ; then AC_PROG_CXXCPP else _lt_caught_CXX_error=yes fi AC_LANG_PUSH(C++) _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(compiler_needs_object, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for C++ test sources. ac_ext=cpp # Object file extension for compiled C++ test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the CXX compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test "$_lt_caught_CXX_error" != yes; then # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(int, char *[[]]) { return(0); }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_LD=$LD lt_save_GCC=$GCC GCC=$GXX lt_save_with_gnu_ld=$with_gnu_ld lt_save_path_LD=$lt_cv_path_LD if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx else $as_unset lt_cv_prog_gnu_ld fi if test -n "${lt_cv_path_LDCXX+set}"; then lt_cv_path_LD=$lt_cv_path_LDCXX else $as_unset lt_cv_path_LD fi test -z "${LDCXX+set}" || LD=$LDCXX CC=${CXX-"c++"} CFLAGS=$CXXFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) if test -n "$compiler"; then # We don't want -fno-exception when compiling C++ code, so set the # no_builtin_flag separately if test "$GXX" = yes; then _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' else _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= fi if test "$GXX" = yes; then # Set up default GNU C++ configuration LT_PATH_LD # Check if GNU C++ uses GNU ld as the underlying linker, since the # archiving commands below assume that GNU ld is being used. if test "$with_gnu_ld" = yes; then _LT_TAGVAR(archive_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' # If archive_cmds runs LD, not CC, wlarc should be empty # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to # investigate it a little bit more. (MM) wlarc='${wl}' # ancient GNU ld didn't support --whole-archive et. al. if eval "`$CC -print-prog-name=ld` --help 2>&1" | $GREP 'no-whole-archive' > /dev/null; then _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' else _LT_TAGVAR(whole_archive_flag_spec, $1)= fi else with_gnu_ld=no wlarc= # A generic and very simple default shared library creation # command for GNU C++ for the case where it uses the native # linker, instead of GNU ld. If possible, this setting should # overridden to take advantage of the native linker features on # the platform it is being used on. _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' fi # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else GXX=no with_gnu_ld=no wlarc= fi # PORTME: fill in a description of your system's C++ link characteristics AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) _LT_TAGVAR(ld_shlibs, $1)=yes case $host_os in aix3*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aix[[4-9]]*) if test "$host_cpu" = ia64; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag="" else aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # need to do runtime linking. case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) for ld_flag in $LDFLAGS; do case $ld_flag in *-brtl*) aix_use_runtimelinking=yes break ;; esac done ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. _LT_TAGVAR(archive_cmds, $1)='' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(file_list_spec, $1)='${wl}-f,' if test "$GXX" = yes; then case $host_os in aix4.[[012]]|aix4.[[012]].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`${CC} -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 _LT_TAGVAR(hardcode_direct, $1)=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)= fi esac shared_flag='-shared' if test "$aix_use_runtimelinking" = yes; then shared_flag="$shared_flag "'${wl}-G' fi else # not using gcc if test "$host_cpu" = ia64; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test "$aix_use_runtimelinking" = yes; then shared_flag='${wl}-G' else shared_flag='${wl}-bM:SRE' fi fi fi _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to # export. _LT_TAGVAR(always_export_symbols, $1)=yes if test "$aix_use_runtimelinking" = yes; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. _LT_TAGVAR(allow_undefined_flag, $1)='-berok' # Determine the default libpath from the value encoded in an empty # executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then func_echo_all "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" else if test "$host_cpu" = ia64; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib' _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. _LT_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok' _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok' if test "$with_gnu_ld" = yes; then # We only use this code for GNU lds that support --whole-archive. _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' fi _LT_TAGVAR(archive_cmds_need_lc, $1)=yes # This is similar to how AIX traditionally builds its shared # libraries. _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' fi fi ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; chorus*) case $cc_basename in *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; cygwin* | mingw* | pw32* | cegcc*) case $GXX,$cc_basename in ,cl* | no,cl*) # Native MSVC # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=".dll" # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-dll~linknames=' _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then $SED -n -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' -e '1\\\!p' < $export_symbols > $output_objdir/$soname.exp; else $SED -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes # Don't use ranlib _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib' _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile="$lt_outputfile.exe" lt_tool_outputfile="$lt_tool_outputfile.exe" ;; esac~ func_to_tool_file "$lt_outputfile"~ if test "$MANIFEST_TOOL" != ":" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # g++ # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, # as there is no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-all-symbols' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file (1st line # is EXPORTS), use it as is; otherwise, prepend... _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; darwin* | rhapsody*) _LT_DARWIN_LINKER_FEATURES($1) ;; dgux*) case $cc_basename in ec++*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; ghcx*) # Green Hills C++ Compiler # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; freebsd2.*) # C++ shared libraries reported to be fairly broken before # switch to ELF _LT_TAGVAR(ld_shlibs, $1)=no ;; freebsd-elf*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;; freebsd* | dragonfly*) # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF # conventions _LT_TAGVAR(ld_shlibs, $1)=yes ;; haiku*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' _LT_TAGVAR(link_all_deplibs, $1)=yes ;; hpux9*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, # but as the default # location of the library. case $cc_basename in CC*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aCC*) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -b ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test "$GXX" = yes; then _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; hpux10*|hpux11*) if test $with_gnu_ld = no; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: case $host_cpu in hppa*64*|ia64*) ;; *) _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' ;; esac fi case $host_cpu in hppa*64*|ia64*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, # but as the default # location of the library. ;; esac case $cc_basename in CC*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aCC*) case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test "$GXX" = yes; then if test $with_gnu_ld = no; then case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac fi else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; interix[[3-9]]*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; irix5* | irix6*) case $cc_basename in CC*) # SGI C++ _LT_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' # Archives containing C++ object files must be created using # "CC -ar", where "CC" is the IRIX C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -ar -WR,-u -o $oldlib $oldobjs' ;; *) if test "$GXX" = yes; then if test "$with_gnu_ld" = no; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` -o $lib' fi fi _LT_TAGVAR(link_all_deplibs, $1)=yes ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(inherit_rpath, $1)=yes ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib ${wl}-retain-symbols-file,$export_symbols; mv \$templib $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' # Archives containing C++ object files must be created using # "CC -Bstatic", where "CC" is the KAI C++ compiler. _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;; icpc* | ecpc* ) # Intel C++ with_gnu_ld=yes # version 8.0 and above of icpc choke on multiply defined symbols # if we add $predep_objects and $postdep_objects, however 7.1 and # earlier do not add the objects themselves. case `$CC -V 2>&1` in *"Version 7."*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' ;; *) # Version 8.0 or newer tmp_idyn= case $host_cpu in ia64*) tmp_idyn=' -i_dynamic';; esac _LT_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' ;; esac _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive' ;; pgCC* | pgcpp*) # Portland Group C++ compiler case `$CC -V` in *pgCC\ [[1-5]].* | *pgcpp\ [[1-5]].*) _LT_TAGVAR(prelink_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~ compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"' _LT_TAGVAR(old_archive_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~ $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~ $RANLIB $oldlib' _LT_TAGVAR(archive_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib' ;; *) # Version 6 and above use weak symbols _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib' ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' ;; cxx*) # Compaq C++ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib ${wl}-retain-symbols-file $wl$export_symbols' runpath_var=LD_RUN_PATH _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed' ;; xl* | mpixl* | bgxl*) # IBM XL 8.0 on PPC, with GNU ld _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' _LT_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' if test "x$supports_anon_versioning" = xyes; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' fi ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file ${wl}$export_symbols' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes # Not sure whether something based on # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 # would be better. output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' ;; esac ;; esac ;; lynxos*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; m88k*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; mvs*) case $cc_basename in cxx*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' wlarc= _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no fi # Workaround some broken pre-1.5 toolchains output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' ;; *nto* | *qnx*) _LT_TAGVAR(ld_shlibs, $1)=yes ;; openbsd2*) # C++ shared libraries are fairly broken _LT_TAGVAR(ld_shlibs, $1)=no ;; openbsd*) if test -f /usr/libexec/ld.so; then _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file,$export_symbols -o $lib' _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' fi output_verbose_link_cmd=func_echo_all else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Archives containing C++ object files must be created using # the KAI C++ compiler. case $host in osf3*) _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;; *) _LT_TAGVAR(old_archive_cmds, $1)='$CC -o $oldlib $oldobjs' ;; esac ;; RCC*) # Rational C++ 2.4.1 # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; cxx*) case $host in osf3*) _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && func_echo_all "${wl}-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' ;; *) _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ echo "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname ${wl}-input ${wl}$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib~ $RM $lib.exp' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' ;; esac _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test "$GXX" = yes && test "$with_gnu_ld" = no; then _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' case $host in osf3*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; psos*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; lcc*) # Lucid # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ _LT_TAGVAR(archive_cmds_need_lc,$1)=yes _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G${allow_undefined_flag} ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands `-z linker_flag'. # Supported since Solaris 2.6 (maybe 2.5.1?) _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' ;; esac _LT_TAGVAR(link_all_deplibs, $1)=yes output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' ;; gcx*) # Green Hills C++ Compiler _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' # The C++ compiler must be used to create the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs' ;; *) # GNU C++ compiler with Solaris linker if test "$GXX" = yes && test "$with_gnu_ld" = no; then _LT_TAGVAR(no_undefined_flag, $1)=' ${wl}-z ${wl}defs' if $CC --version | $GREP -v '^2\.7' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # g++ 2.7 appears to require `-G' NOT `-shared' on this # platform. _LT_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $wl$libdir' case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' ;; esac fi ;; esac ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var='LD_RUN_PATH' case $cc_basename in CC*) _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We can NOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text' _LT_TAGVAR(allow_undefined_flag, $1)='${wl}-z,nodefs' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport' runpath_var='LD_RUN_PATH' case $cc_basename in CC*) _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(old_archive_cmds, $1)='$CC -Tprelink_objects $oldobjs~ '"$_LT_TAGVAR(old_archive_cmds, $1)" _LT_TAGVAR(reload_cmds, $1)='$CC -Tprelink_objects $reload_objs~ '"$_LT_TAGVAR(reload_cmds, $1)" ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; vxworks*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) test "$_LT_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no _LT_TAGVAR(GCC, $1)="$GXX" _LT_TAGVAR(LD, $1)="$LD" ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_SYS_HIDDEN_LIBDEPS($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS LDCXX=$LD LD=$lt_save_LD GCC=$lt_save_GCC with_gnu_ld=$lt_save_with_gnu_ld lt_cv_path_LDCXX=$lt_cv_path_LD lt_cv_path_LD=$lt_save_path_LD lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld fi # test "$_lt_caught_CXX_error" != yes AC_LANG_POP ])# _LT_LANG_CXX_CONFIG # _LT_FUNC_STRIPNAME_CNF # ---------------------- # func_stripname_cnf prefix suffix name # strip PREFIX and SUFFIX off of NAME. # PREFIX and SUFFIX must not contain globbing or regex special # characters, hashes, percent signs, but SUFFIX may contain a leading # dot (in which case that matches only a dot). # # This function is identical to the (non-XSI) version of func_stripname, # except this one can be used by m4 code that may be executed by configure, # rather than the libtool script. m4_defun([_LT_FUNC_STRIPNAME_CNF],[dnl AC_REQUIRE([_LT_DECL_SED]) AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH]) func_stripname_cnf () { case ${2} in .*) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%\\\\${2}\$%%"`;; *) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%${2}\$%%"`;; esac } # func_stripname_cnf ])# _LT_FUNC_STRIPNAME_CNF # _LT_SYS_HIDDEN_LIBDEPS([TAGNAME]) # --------------------------------- # Figure out "hidden" library dependencies from verbose # compiler output when linking a shared library. # Parse the compiler output and extract the necessary # objects, libraries and library flags. m4_defun([_LT_SYS_HIDDEN_LIBDEPS], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl AC_REQUIRE([_LT_FUNC_STRIPNAME_CNF])dnl # Dependencies to place before and after the object being linked: _LT_TAGVAR(predep_objects, $1)= _LT_TAGVAR(postdep_objects, $1)= _LT_TAGVAR(predeps, $1)= _LT_TAGVAR(postdeps, $1)= _LT_TAGVAR(compiler_lib_search_path, $1)= dnl we can't use the lt_simple_compile_test_code here, dnl because it contains code intended for an executable, dnl not a library. It's possible we should let each dnl tag define a new lt_????_link_test_code variable, dnl but it's only used here... m4_if([$1], [], [cat > conftest.$ac_ext <<_LT_EOF int a; void foo (void) { a = 0; } _LT_EOF ], [$1], [CXX], [cat > conftest.$ac_ext <<_LT_EOF class Foo { public: Foo (void) { a = 0; } private: int a; }; _LT_EOF ], [$1], [F77], [cat > conftest.$ac_ext <<_LT_EOF subroutine foo implicit none integer*4 a a=0 return end _LT_EOF ], [$1], [FC], [cat > conftest.$ac_ext <<_LT_EOF subroutine foo implicit none integer a a=0 return end _LT_EOF ], [$1], [GCJ], [cat > conftest.$ac_ext <<_LT_EOF public class foo { private int a; public void bar (void) { a = 0; } }; _LT_EOF ], [$1], [GO], [cat > conftest.$ac_ext <<_LT_EOF package foo func foo() { } _LT_EOF ]) _lt_libdeps_save_CFLAGS=$CFLAGS case "$CC $CFLAGS " in #( *\ -flto*\ *) CFLAGS="$CFLAGS -fno-lto" ;; *\ -fwhopr*\ *) CFLAGS="$CFLAGS -fno-whopr" ;; *\ -fuse-linker-plugin*\ *) CFLAGS="$CFLAGS -fno-use-linker-plugin" ;; esac dnl Parse the compiler output and extract the necessary dnl objects, libraries and library flags. if AC_TRY_EVAL(ac_compile); then # Parse the compiler output and extract the necessary # objects, libraries and library flags. # Sentinel used to keep track of whether or not we are before # the conftest object file. pre_test_object_deps_done=no for p in `eval "$output_verbose_link_cmd"`; do case ${prev}${p} in -L* | -R* | -l*) # Some compilers place space between "-{L,R}" and the path. # Remove the space. if test $p = "-L" || test $p = "-R"; then prev=$p continue fi # Expand the sysroot to ease extracting the directories later. if test -z "$prev"; then case $p in -L*) func_stripname_cnf '-L' '' "$p"; prev=-L; p=$func_stripname_result ;; -R*) func_stripname_cnf '-R' '' "$p"; prev=-R; p=$func_stripname_result ;; -l*) func_stripname_cnf '-l' '' "$p"; prev=-l; p=$func_stripname_result ;; esac fi case $p in =*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;; esac if test "$pre_test_object_deps_done" = no; then case ${prev} in -L | -R) # Internal compiler library paths should come after those # provided the user. The postdeps already come after the # user supplied libs so there is no need to process them. if test -z "$_LT_TAGVAR(compiler_lib_search_path, $1)"; then _LT_TAGVAR(compiler_lib_search_path, $1)="${prev}${p}" else _LT_TAGVAR(compiler_lib_search_path, $1)="${_LT_TAGVAR(compiler_lib_search_path, $1)} ${prev}${p}" fi ;; # The "-l" case would never come before the object being # linked, so don't bother handling this case. esac else if test -z "$_LT_TAGVAR(postdeps, $1)"; then _LT_TAGVAR(postdeps, $1)="${prev}${p}" else _LT_TAGVAR(postdeps, $1)="${_LT_TAGVAR(postdeps, $1)} ${prev}${p}" fi fi prev= ;; *.lto.$objext) ;; # Ignore GCC LTO objects *.$objext) # This assumes that the test object file only shows up # once in the compiler output. if test "$p" = "conftest.$objext"; then pre_test_object_deps_done=yes continue fi if test "$pre_test_object_deps_done" = no; then if test -z "$_LT_TAGVAR(predep_objects, $1)"; then _LT_TAGVAR(predep_objects, $1)="$p" else _LT_TAGVAR(predep_objects, $1)="$_LT_TAGVAR(predep_objects, $1) $p" fi else if test -z "$_LT_TAGVAR(postdep_objects, $1)"; then _LT_TAGVAR(postdep_objects, $1)="$p" else _LT_TAGVAR(postdep_objects, $1)="$_LT_TAGVAR(postdep_objects, $1) $p" fi fi ;; *) ;; # Ignore the rest. esac done # Clean up. rm -f a.out a.exe else echo "libtool.m4: error: problem compiling $1 test program" fi $RM -f confest.$objext CFLAGS=$_lt_libdeps_save_CFLAGS # PORTME: override above test on systems where it is broken m4_if([$1], [CXX], [case $host_os in interix[[3-9]]*) # Interix 3.5 installs completely hosed .la files for C++, so rather than # hack all around it, let's just trust "g++" to DTRT. _LT_TAGVAR(predep_objects,$1)= _LT_TAGVAR(postdep_objects,$1)= _LT_TAGVAR(postdeps,$1)= ;; linux*) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 # The more standards-conforming stlport4 library is # incompatible with the Cstd library. Avoid specifying # it if it's in CXXFLAGS. Ignore libCrun as # -library=stlport4 depends on it. case " $CXX $CXXFLAGS " in *" -library=stlport4 "*) solaris_use_stlport4=yes ;; esac if test "$solaris_use_stlport4" != yes; then _LT_TAGVAR(postdeps,$1)='-library=Cstd -library=Crun' fi ;; esac ;; solaris*) case $cc_basename in CC* | sunCC*) # The more standards-conforming stlport4 library is # incompatible with the Cstd library. Avoid specifying # it if it's in CXXFLAGS. Ignore libCrun as # -library=stlport4 depends on it. case " $CXX $CXXFLAGS " in *" -library=stlport4 "*) solaris_use_stlport4=yes ;; esac # Adding this requires a known-good setup of shared libraries for # Sun compiler versions before 5.6, else PIC objects from an old # archive will be linked into the output, leading to subtle bugs. if test "$solaris_use_stlport4" != yes; then _LT_TAGVAR(postdeps,$1)='-library=Cstd -library=Crun' fi ;; esac ;; esac ]) case " $_LT_TAGVAR(postdeps, $1) " in *" -lc "*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;; esac _LT_TAGVAR(compiler_lib_search_dirs, $1)= if test -n "${_LT_TAGVAR(compiler_lib_search_path, $1)}"; then _LT_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_TAGVAR(compiler_lib_search_path, $1)}" | ${SED} -e 's! -L! !g' -e 's!^ !!'` fi _LT_TAGDECL([], [compiler_lib_search_dirs], [1], [The directories searched by this compiler when creating a shared library]) _LT_TAGDECL([], [predep_objects], [1], [Dependencies to place before and after the objects being linked to create a shared library]) _LT_TAGDECL([], [postdep_objects], [1]) _LT_TAGDECL([], [predeps], [1]) _LT_TAGDECL([], [postdeps], [1]) _LT_TAGDECL([], [compiler_lib_search_path], [1], [The library search path used internally by the compiler when linking a shared library]) ])# _LT_SYS_HIDDEN_LIBDEPS # _LT_LANG_F77_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for a Fortran 77 compiler are # suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to `libtool'. m4_defun([_LT_LANG_F77_CONFIG], [AC_LANG_PUSH(Fortran 77) if test -z "$F77" || test "X$F77" = "Xno"; then _lt_disable_F77=yes fi _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for f77 test sources. ac_ext=f # Object file extension for compiled f77 test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the F77 compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test "$_lt_disable_F77" != yes; then # Code to be used in simple compile tests lt_simple_compile_test_code="\ subroutine t return end " # Code to be used in simple link tests lt_simple_link_test_code="\ program t end " # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC="$CC" lt_save_GCC=$GCC lt_save_CFLAGS=$CFLAGS CC=${F77-"f77"} CFLAGS=$FFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) GCC=$G77 if test -n "$compiler"; then AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test "$can_build_shared" = "no" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test "$enable_shared" = yes && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then test "$enable_shared" = yes && enable_static=no fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test "$enable_shared" = yes || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_TAGVAR(GCC, $1)="$G77" _LT_TAGVAR(LD, $1)="$LD" ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" GCC=$lt_save_GCC CC="$lt_save_CC" CFLAGS="$lt_save_CFLAGS" fi # test "$_lt_disable_F77" != yes AC_LANG_POP ])# _LT_LANG_F77_CONFIG # _LT_LANG_FC_CONFIG([TAG]) # ------------------------- # Ensure that the configuration variables for a Fortran compiler are # suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to `libtool'. m4_defun([_LT_LANG_FC_CONFIG], [AC_LANG_PUSH(Fortran) if test -z "$FC" || test "X$FC" = "Xno"; then _lt_disable_FC=yes fi _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for fc test sources. ac_ext=${ac_fc_srcext-f} # Object file extension for compiled fc test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the FC compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test "$_lt_disable_FC" != yes; then # Code to be used in simple compile tests lt_simple_compile_test_code="\ subroutine t return end " # Code to be used in simple link tests lt_simple_link_test_code="\ program t end " # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC="$CC" lt_save_GCC=$GCC lt_save_CFLAGS=$CFLAGS CC=${FC-"f95"} CFLAGS=$FCFLAGS compiler=$CC GCC=$ac_cv_fc_compiler_gnu _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) if test -n "$compiler"; then AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test "$can_build_shared" = "no" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test "$enable_shared" = yes && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then test "$enable_shared" = yes && enable_static=no fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test "$enable_shared" = yes || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_TAGVAR(GCC, $1)="$ac_cv_fc_compiler_gnu" _LT_TAGVAR(LD, $1)="$LD" ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_SYS_HIDDEN_LIBDEPS($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS fi # test "$_lt_disable_FC" != yes AC_LANG_POP ])# _LT_LANG_FC_CONFIG # _LT_LANG_GCJ_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for the GNU Java Compiler compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to `libtool'. m4_defun([_LT_LANG_GCJ_CONFIG], [AC_REQUIRE([LT_PROG_GCJ])dnl AC_LANG_SAVE # Source file extension for Java test sources. ac_ext=java # Object file extension for compiled Java test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="class foo {}" # Code to be used in simple link tests lt_simple_link_test_code='public class conftest { public static void main(String[[]] argv) {}; }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC=yes CC=${GCJ-"gcj"} CFLAGS=$GCJFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_TAGVAR(LD, $1)="$LD" _LT_CC_BASENAME([$compiler]) # GCJ did not exist at the time GCC didn't implicitly link libc in. _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi AC_LANG_RESTORE GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_GCJ_CONFIG # _LT_LANG_GO_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for the GNU Go compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to `libtool'. m4_defun([_LT_LANG_GO_CONFIG], [AC_REQUIRE([LT_PROG_GO])dnl AC_LANG_SAVE # Source file extension for Go test sources. ac_ext=go # Object file extension for compiled Go test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="package main; func main() { }" # Code to be used in simple link tests lt_simple_link_test_code='package main; func main() { }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC=yes CC=${GOC-"gccgo"} CFLAGS=$GOFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_TAGVAR(LD, $1)="$LD" _LT_CC_BASENAME([$compiler]) # Go did not exist at the time GCC didn't implicitly link libc in. _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi AC_LANG_RESTORE GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_GO_CONFIG # _LT_LANG_RC_CONFIG([TAG]) # ------------------------- # Ensure that the configuration variables for the Windows resource compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to `libtool'. m4_defun([_LT_LANG_RC_CONFIG], [AC_REQUIRE([LT_PROG_RC])dnl AC_LANG_SAVE # Source file extension for RC test sources. ac_ext=rc # Object file extension for compiled RC test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }' # Code to be used in simple link tests lt_simple_link_test_code="$lt_simple_compile_test_code" # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC="$CC" lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC= CC=${RC-"windres"} CFLAGS= compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes if test -n "$compiler"; then : _LT_CONFIG($1) fi GCC=$lt_save_GCC AC_LANG_RESTORE CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_RC_CONFIG # LT_PROG_GCJ # ----------- AC_DEFUN([LT_PROG_GCJ], [m4_ifdef([AC_PROG_GCJ], [AC_PROG_GCJ], [m4_ifdef([A][M_PROG_GCJ], [A][M_PROG_GCJ], [AC_CHECK_TOOL(GCJ, gcj,) test "x${GCJFLAGS+set}" = xset || GCJFLAGS="-g -O2" AC_SUBST(GCJFLAGS)])])[]dnl ]) # Old name: AU_ALIAS([LT_AC_PROG_GCJ], [LT_PROG_GCJ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_GCJ], []) # LT_PROG_GO # ---------- AC_DEFUN([LT_PROG_GO], [AC_CHECK_TOOL(GOC, gccgo,) ]) # LT_PROG_RC # ---------- AC_DEFUN([LT_PROG_RC], [AC_CHECK_TOOL(RC, windres,) ]) # Old name: AU_ALIAS([LT_AC_PROG_RC], [LT_PROG_RC]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_RC], []) # _LT_DECL_EGREP # -------------- # If we don't have a new enough Autoconf to choose the best grep # available, choose the one first in the user's PATH. m4_defun([_LT_DECL_EGREP], [AC_REQUIRE([AC_PROG_EGREP])dnl AC_REQUIRE([AC_PROG_FGREP])dnl test -z "$GREP" && GREP=grep _LT_DECL([], [GREP], [1], [A grep program that handles long lines]) _LT_DECL([], [EGREP], [1], [An ERE matcher]) _LT_DECL([], [FGREP], [1], [A literal string matcher]) dnl Non-bleeding-edge autoconf doesn't subst GREP, so do it here too AC_SUBST([GREP]) ]) # _LT_DECL_OBJDUMP # -------------- # If we don't have a new enough Autoconf to choose the best objdump # available, choose the one first in the user's PATH. m4_defun([_LT_DECL_OBJDUMP], [AC_CHECK_TOOL(OBJDUMP, objdump, false) test -z "$OBJDUMP" && OBJDUMP=objdump _LT_DECL([], [OBJDUMP], [1], [An object symbol dumper]) AC_SUBST([OBJDUMP]) ]) # _LT_DECL_DLLTOOL # ---------------- # Ensure DLLTOOL variable is set. m4_defun([_LT_DECL_DLLTOOL], [AC_CHECK_TOOL(DLLTOOL, dlltool, false) test -z "$DLLTOOL" && DLLTOOL=dlltool _LT_DECL([], [DLLTOOL], [1], [DLL creation program]) AC_SUBST([DLLTOOL]) ]) # _LT_DECL_SED # ------------ # Check for a fully-functional sed program, that truncates # as few characters as possible. Prefer GNU sed if found. m4_defun([_LT_DECL_SED], [AC_PROG_SED test -z "$SED" && SED=sed Xsed="$SED -e 1s/^X//" _LT_DECL([], [SED], [1], [A sed program that does not truncate output]) _LT_DECL([], [Xsed], ["\$SED -e 1s/^X//"], [Sed that helps us avoid accidentally triggering echo(1) options like -n]) ])# _LT_DECL_SED m4_ifndef([AC_PROG_SED], [ ############################################################ # NOTE: This macro has been submitted for inclusion into # # GNU Autoconf as AC_PROG_SED. When it is available in # # a released version of Autoconf we should remove this # # macro and use it instead. # ############################################################ m4_defun([AC_PROG_SED], [AC_MSG_CHECKING([for a sed that does not truncate output]) AC_CACHE_VAL(lt_cv_path_SED, [# Loop through the user's path and test for sed and gsed. # Then use that list of sed's as ones to test for truncation. as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for lt_ac_prog in sed gsed; do for ac_exec_ext in '' $ac_executable_extensions; do if $as_executable_p "$as_dir/$lt_ac_prog$ac_exec_ext"; then lt_ac_sed_list="$lt_ac_sed_list $as_dir/$lt_ac_prog$ac_exec_ext" fi done done done IFS=$as_save_IFS lt_ac_max=0 lt_ac_count=0 # Add /usr/xpg4/bin/sed as it is typically found on Solaris # along with /bin/sed that truncates output. for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do test ! -f $lt_ac_sed && continue cat /dev/null > conftest.in lt_ac_count=0 echo $ECHO_N "0123456789$ECHO_C" >conftest.in # Check for GNU sed and select it if it is found. if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then lt_cv_path_SED=$lt_ac_sed break fi while true; do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo >>conftest.nl $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break cmp -s conftest.out conftest.nl || break # 10000 chars as input seems more than enough test $lt_ac_count -gt 10 && break lt_ac_count=`expr $lt_ac_count + 1` if test $lt_ac_count -gt $lt_ac_max; then lt_ac_max=$lt_ac_count lt_cv_path_SED=$lt_ac_sed fi done done ]) SED=$lt_cv_path_SED AC_SUBST([SED]) AC_MSG_RESULT([$SED]) ])#AC_PROG_SED ])#m4_ifndef # Old name: AU_ALIAS([LT_AC_PROG_SED], [AC_PROG_SED]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_SED], []) # _LT_CHECK_SHELL_FEATURES # ------------------------ # Find out whether the shell is Bourne or XSI compatible, # or has some other useful features. m4_defun([_LT_CHECK_SHELL_FEATURES], [AC_MSG_CHECKING([whether the shell understands some XSI constructs]) # Try some XSI features xsi_shell=no ( _lt_dummy="a/b/c" test "${_lt_dummy##*/},${_lt_dummy%/*},${_lt_dummy#??}"${_lt_dummy%"$_lt_dummy"}, \ = c,a/b,b/c, \ && eval 'test $(( 1 + 1 )) -eq 2 \ && test "${#_lt_dummy}" -eq 5' ) >/dev/null 2>&1 \ && xsi_shell=yes AC_MSG_RESULT([$xsi_shell]) _LT_CONFIG_LIBTOOL_INIT([xsi_shell='$xsi_shell']) AC_MSG_CHECKING([whether the shell understands "+="]) lt_shell_append=no ( foo=bar; set foo baz; eval "$[1]+=\$[2]" && test "$foo" = barbaz ) \ >/dev/null 2>&1 \ && lt_shell_append=yes AC_MSG_RESULT([$lt_shell_append]) _LT_CONFIG_LIBTOOL_INIT([lt_shell_append='$lt_shell_append']) if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then lt_unset=unset else lt_unset=false fi _LT_DECL([], [lt_unset], [0], [whether the shell understands "unset"])dnl # test EBCDIC or ASCII case `echo X|tr X '\101'` in A) # ASCII based system # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr lt_SP2NL='tr \040 \012' lt_NL2SP='tr \015\012 \040\040' ;; *) # EBCDIC based system lt_SP2NL='tr \100 \n' lt_NL2SP='tr \r\n \100\100' ;; esac _LT_DECL([SP2NL], [lt_SP2NL], [1], [turn spaces into newlines])dnl _LT_DECL([NL2SP], [lt_NL2SP], [1], [turn newlines into spaces])dnl ])# _LT_CHECK_SHELL_FEATURES # _LT_PROG_FUNCTION_REPLACE (FUNCNAME, REPLACEMENT-BODY) # ------------------------------------------------------ # In `$cfgfile', look for function FUNCNAME delimited by `^FUNCNAME ()$' and # '^} FUNCNAME ', and replace its body with REPLACEMENT-BODY. m4_defun([_LT_PROG_FUNCTION_REPLACE], [dnl { sed -e '/^$1 ()$/,/^} # $1 /c\ $1 ()\ {\ m4_bpatsubsts([$2], [$], [\\], [^\([ ]\)], [\\\1]) } # Extended-shell $1 implementation' "$cfgfile" > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: ]) # _LT_PROG_REPLACE_SHELLFNS # ------------------------- # Replace existing portable implementations of several shell functions with # equivalent extended shell implementations where those features are available.. m4_defun([_LT_PROG_REPLACE_SHELLFNS], [if test x"$xsi_shell" = xyes; then _LT_PROG_FUNCTION_REPLACE([func_dirname], [dnl case ${1} in */*) func_dirname_result="${1%/*}${2}" ;; * ) func_dirname_result="${3}" ;; esac]) _LT_PROG_FUNCTION_REPLACE([func_basename], [dnl func_basename_result="${1##*/}"]) _LT_PROG_FUNCTION_REPLACE([func_dirname_and_basename], [dnl case ${1} in */*) func_dirname_result="${1%/*}${2}" ;; * ) func_dirname_result="${3}" ;; esac func_basename_result="${1##*/}"]) _LT_PROG_FUNCTION_REPLACE([func_stripname], [dnl # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are # positional parameters, so assign one to ordinary parameter first. func_stripname_result=${3} func_stripname_result=${func_stripname_result#"${1}"} func_stripname_result=${func_stripname_result%"${2}"}]) _LT_PROG_FUNCTION_REPLACE([func_split_long_opt], [dnl func_split_long_opt_name=${1%%=*} func_split_long_opt_arg=${1#*=}]) _LT_PROG_FUNCTION_REPLACE([func_split_short_opt], [dnl func_split_short_opt_arg=${1#??} func_split_short_opt_name=${1%"$func_split_short_opt_arg"}]) _LT_PROG_FUNCTION_REPLACE([func_lo2o], [dnl case ${1} in *.lo) func_lo2o_result=${1%.lo}.${objext} ;; *) func_lo2o_result=${1} ;; esac]) _LT_PROG_FUNCTION_REPLACE([func_xform], [ func_xform_result=${1%.*}.lo]) _LT_PROG_FUNCTION_REPLACE([func_arith], [ func_arith_result=$(( $[*] ))]) _LT_PROG_FUNCTION_REPLACE([func_len], [ func_len_result=${#1}]) fi if test x"$lt_shell_append" = xyes; then _LT_PROG_FUNCTION_REPLACE([func_append], [ eval "${1}+=\\${2}"]) _LT_PROG_FUNCTION_REPLACE([func_append_quoted], [dnl func_quote_for_eval "${2}" dnl m4 expansion turns \\\\ into \\, and then the shell eval turns that into \ eval "${1}+=\\\\ \\$func_quote_for_eval_result"]) # Save a `func_append' function call where possible by direct use of '+=' sed -e 's%func_append \([[a-zA-Z_]]\{1,\}\) "%\1+="%g' $cfgfile > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: else # Save a `func_append' function call even when '+=' is not available sed -e 's%func_append \([[a-zA-Z_]]\{1,\}\) "%\1="$\1%g' $cfgfile > $cfgfile.tmp \ && mv -f "$cfgfile.tmp" "$cfgfile" \ || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp") test 0 -eq $? || _lt_function_replace_fail=: fi if test x"$_lt_function_replace_fail" = x":"; then AC_MSG_WARN([Unable to substitute extended shell functions in $ofile]) fi ]) # _LT_PATH_CONVERSION_FUNCTIONS # ----------------------------- # Determine which file name conversion functions should be used by # func_to_host_file (and, implicitly, by func_to_host_path). These are needed # for certain cross-compile configurations and native mingw. m4_defun([_LT_PATH_CONVERSION_FUNCTIONS], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl AC_MSG_CHECKING([how to convert $build file names to $host format]) AC_CACHE_VAL(lt_cv_to_host_file_cmd, [case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_w32 ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_cygwin_to_w32 ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_w32 ;; esac ;; *-*-cygwin* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_cygwin ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_noop ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_cygwin ;; esac ;; * ) # unhandled hosts (and "normal" native builds) lt_cv_to_host_file_cmd=func_convert_file_noop ;; esac ]) to_host_file_cmd=$lt_cv_to_host_file_cmd AC_MSG_RESULT([$lt_cv_to_host_file_cmd]) _LT_DECL([to_host_file_cmd], [lt_cv_to_host_file_cmd], [0], [convert $build file names to $host format])dnl AC_MSG_CHECKING([how to convert $build file names to toolchain format]) AC_CACHE_VAL(lt_cv_to_tool_file_cmd, [#assume ordinary cross tools, or native build. lt_cv_to_tool_file_cmd=func_convert_file_noop case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_tool_file_cmd=func_convert_file_msys_to_w32 ;; esac ;; esac ]) to_tool_file_cmd=$lt_cv_to_tool_file_cmd AC_MSG_RESULT([$lt_cv_to_tool_file_cmd]) _LT_DECL([to_tool_file_cmd], [lt_cv_to_tool_file_cmd], [0], [convert $build files to toolchain format])dnl ])# _LT_PATH_CONVERSION_FUNCTIONS eztrace-1.1-2/m4/ltoptions.m4000066400000000000000000000300731265506773700160110ustar00rootroot00000000000000# Helper functions for option handling. -*- Autoconf -*- # # Copyright (C) 2004, 2005, 2007, 2008, 2009 Free Software Foundation, # Inc. # Written by Gary V. Vaughan, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 7 ltoptions.m4 # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])]) # _LT_MANGLE_OPTION(MACRO-NAME, OPTION-NAME) # ------------------------------------------ m4_define([_LT_MANGLE_OPTION], [[_LT_OPTION_]m4_bpatsubst($1__$2, [[^a-zA-Z0-9_]], [_])]) # _LT_SET_OPTION(MACRO-NAME, OPTION-NAME) # --------------------------------------- # Set option OPTION-NAME for macro MACRO-NAME, and if there is a # matching handler defined, dispatch to it. Other OPTION-NAMEs are # saved as a flag. m4_define([_LT_SET_OPTION], [m4_define(_LT_MANGLE_OPTION([$1], [$2]))dnl m4_ifdef(_LT_MANGLE_DEFUN([$1], [$2]), _LT_MANGLE_DEFUN([$1], [$2]), [m4_warning([Unknown $1 option `$2'])])[]dnl ]) # _LT_IF_OPTION(MACRO-NAME, OPTION-NAME, IF-SET, [IF-NOT-SET]) # ------------------------------------------------------------ # Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. m4_define([_LT_IF_OPTION], [m4_ifdef(_LT_MANGLE_OPTION([$1], [$2]), [$3], [$4])]) # _LT_UNLESS_OPTIONS(MACRO-NAME, OPTION-LIST, IF-NOT-SET) # ------------------------------------------------------- # Execute IF-NOT-SET unless all options in OPTION-LIST for MACRO-NAME # are set. m4_define([_LT_UNLESS_OPTIONS], [m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), [m4_ifdef(_LT_MANGLE_OPTION([$1], _LT_Option), [m4_define([$0_found])])])[]dnl m4_ifdef([$0_found], [m4_undefine([$0_found])], [$3 ])[]dnl ]) # _LT_SET_OPTIONS(MACRO-NAME, OPTION-LIST) # ---------------------------------------- # OPTION-LIST is a space-separated list of Libtool options associated # with MACRO-NAME. If any OPTION has a matching handler declared with # LT_OPTION_DEFINE, dispatch to that macro; otherwise complain about # the unknown option and exit. m4_defun([_LT_SET_OPTIONS], [# Set options m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), [_LT_SET_OPTION([$1], _LT_Option)]) m4_if([$1],[LT_INIT],[ dnl dnl Simply set some default values (i.e off) if boolean options were not dnl specified: _LT_UNLESS_OPTIONS([LT_INIT], [dlopen], [enable_dlopen=no ]) _LT_UNLESS_OPTIONS([LT_INIT], [win32-dll], [enable_win32_dll=no ]) dnl dnl If no reference was made to various pairs of opposing options, then dnl we run the default mode handler for the pair. For example, if neither dnl `shared' nor `disable-shared' was passed, we enable building of shared dnl archives by default: _LT_UNLESS_OPTIONS([LT_INIT], [shared disable-shared], [_LT_ENABLE_SHARED]) _LT_UNLESS_OPTIONS([LT_INIT], [static disable-static], [_LT_ENABLE_STATIC]) _LT_UNLESS_OPTIONS([LT_INIT], [pic-only no-pic], [_LT_WITH_PIC]) _LT_UNLESS_OPTIONS([LT_INIT], [fast-install disable-fast-install], [_LT_ENABLE_FAST_INSTALL]) ]) ])# _LT_SET_OPTIONS ## --------------------------------- ## ## Macros to handle LT_INIT options. ## ## --------------------------------- ## # _LT_MANGLE_DEFUN(MACRO-NAME, OPTION-NAME) # ----------------------------------------- m4_define([_LT_MANGLE_DEFUN], [[_LT_OPTION_DEFUN_]m4_bpatsubst(m4_toupper([$1__$2]), [[^A-Z0-9_]], [_])]) # LT_OPTION_DEFINE(MACRO-NAME, OPTION-NAME, CODE) # ----------------------------------------------- m4_define([LT_OPTION_DEFINE], [m4_define(_LT_MANGLE_DEFUN([$1], [$2]), [$3])[]dnl ])# LT_OPTION_DEFINE # dlopen # ------ LT_OPTION_DEFINE([LT_INIT], [dlopen], [enable_dlopen=yes ]) AU_DEFUN([AC_LIBTOOL_DLOPEN], [_LT_SET_OPTION([LT_INIT], [dlopen]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the `dlopen' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_DLOPEN], []) # win32-dll # --------- # Declare package support for building win32 dll's. LT_OPTION_DEFINE([LT_INIT], [win32-dll], [enable_win32_dll=yes case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*) AC_CHECK_TOOL(AS, as, false) AC_CHECK_TOOL(DLLTOOL, dlltool, false) AC_CHECK_TOOL(OBJDUMP, objdump, false) ;; esac test -z "$AS" && AS=as _LT_DECL([], [AS], [1], [Assembler program])dnl test -z "$DLLTOOL" && DLLTOOL=dlltool _LT_DECL([], [DLLTOOL], [1], [DLL creation program])dnl test -z "$OBJDUMP" && OBJDUMP=objdump _LT_DECL([], [OBJDUMP], [1], [Object dumper program])dnl ])# win32-dll AU_DEFUN([AC_LIBTOOL_WIN32_DLL], [AC_REQUIRE([AC_CANONICAL_HOST])dnl _LT_SET_OPTION([LT_INIT], [win32-dll]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the `win32-dll' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_WIN32_DLL], []) # _LT_ENABLE_SHARED([DEFAULT]) # ---------------------------- # implement the --enable-shared flag, and supports the `shared' and # `disable-shared' LT_INIT options. # DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. m4_define([_LT_ENABLE_SHARED], [m4_define([_LT_ENABLE_SHARED_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([shared], [AS_HELP_STRING([--enable-shared@<:@=PKGS@:>@], [build shared libraries @<:@default=]_LT_ENABLE_SHARED_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_shared=yes ;; no) enable_shared=no ;; *) enable_shared=no # Look at the argument we got. We use all the common list separators. lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," for pkg in $enableval; do IFS="$lt_save_ifs" if test "X$pkg" = "X$p"; then enable_shared=yes fi done IFS="$lt_save_ifs" ;; esac], [enable_shared=]_LT_ENABLE_SHARED_DEFAULT) _LT_DECL([build_libtool_libs], [enable_shared], [0], [Whether or not to build shared libraries]) ])# _LT_ENABLE_SHARED LT_OPTION_DEFINE([LT_INIT], [shared], [_LT_ENABLE_SHARED([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-shared], [_LT_ENABLE_SHARED([no])]) # Old names: AC_DEFUN([AC_ENABLE_SHARED], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[shared]) ]) AC_DEFUN([AC_DISABLE_SHARED], [_LT_SET_OPTION([LT_INIT], [disable-shared]) ]) AU_DEFUN([AM_ENABLE_SHARED], [AC_ENABLE_SHARED($@)]) AU_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_ENABLE_SHARED], []) dnl AC_DEFUN([AM_DISABLE_SHARED], []) # _LT_ENABLE_STATIC([DEFAULT]) # ---------------------------- # implement the --enable-static flag, and support the `static' and # `disable-static' LT_INIT options. # DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. m4_define([_LT_ENABLE_STATIC], [m4_define([_LT_ENABLE_STATIC_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([static], [AS_HELP_STRING([--enable-static@<:@=PKGS@:>@], [build static libraries @<:@default=]_LT_ENABLE_STATIC_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_static=yes ;; no) enable_static=no ;; *) enable_static=no # Look at the argument we got. We use all the common list separators. lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," for pkg in $enableval; do IFS="$lt_save_ifs" if test "X$pkg" = "X$p"; then enable_static=yes fi done IFS="$lt_save_ifs" ;; esac], [enable_static=]_LT_ENABLE_STATIC_DEFAULT) _LT_DECL([build_old_libs], [enable_static], [0], [Whether or not to build static libraries]) ])# _LT_ENABLE_STATIC LT_OPTION_DEFINE([LT_INIT], [static], [_LT_ENABLE_STATIC([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-static], [_LT_ENABLE_STATIC([no])]) # Old names: AC_DEFUN([AC_ENABLE_STATIC], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[static]) ]) AC_DEFUN([AC_DISABLE_STATIC], [_LT_SET_OPTION([LT_INIT], [disable-static]) ]) AU_DEFUN([AM_ENABLE_STATIC], [AC_ENABLE_STATIC($@)]) AU_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_ENABLE_STATIC], []) dnl AC_DEFUN([AM_DISABLE_STATIC], []) # _LT_ENABLE_FAST_INSTALL([DEFAULT]) # ---------------------------------- # implement the --enable-fast-install flag, and support the `fast-install' # and `disable-fast-install' LT_INIT options. # DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. m4_define([_LT_ENABLE_FAST_INSTALL], [m4_define([_LT_ENABLE_FAST_INSTALL_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([fast-install], [AS_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@], [optimize for fast installation @<:@default=]_LT_ENABLE_FAST_INSTALL_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_fast_install=yes ;; no) enable_fast_install=no ;; *) enable_fast_install=no # Look at the argument we got. We use all the common list separators. lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," for pkg in $enableval; do IFS="$lt_save_ifs" if test "X$pkg" = "X$p"; then enable_fast_install=yes fi done IFS="$lt_save_ifs" ;; esac], [enable_fast_install=]_LT_ENABLE_FAST_INSTALL_DEFAULT) _LT_DECL([fast_install], [enable_fast_install], [0], [Whether or not to optimize for fast installation])dnl ])# _LT_ENABLE_FAST_INSTALL LT_OPTION_DEFINE([LT_INIT], [fast-install], [_LT_ENABLE_FAST_INSTALL([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-fast-install], [_LT_ENABLE_FAST_INSTALL([no])]) # Old names: AU_DEFUN([AC_ENABLE_FAST_INSTALL], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[fast-install]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the `fast-install' option into LT_INIT's first parameter.]) ]) AU_DEFUN([AC_DISABLE_FAST_INSTALL], [_LT_SET_OPTION([LT_INIT], [disable-fast-install]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the `disable-fast-install' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_ENABLE_FAST_INSTALL], []) dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], []) # _LT_WITH_PIC([MODE]) # -------------------- # implement the --with-pic flag, and support the `pic-only' and `no-pic' # LT_INIT options. # MODE is either `yes' or `no'. If omitted, it defaults to `both'. m4_define([_LT_WITH_PIC], [AC_ARG_WITH([pic], [AS_HELP_STRING([--with-pic@<:@=PKGS@:>@], [try to use only PIC/non-PIC objects @<:@default=use both@:>@])], [lt_p=${PACKAGE-default} case $withval in yes|no) pic_mode=$withval ;; *) pic_mode=default # Look at the argument we got. We use all the common list separators. lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," for lt_pkg in $withval; do IFS="$lt_save_ifs" if test "X$lt_pkg" = "X$lt_p"; then pic_mode=yes fi done IFS="$lt_save_ifs" ;; esac], [pic_mode=default]) test -z "$pic_mode" && pic_mode=m4_default([$1], [default]) _LT_DECL([], [pic_mode], [0], [What type of objects to build])dnl ])# _LT_WITH_PIC LT_OPTION_DEFINE([LT_INIT], [pic-only], [_LT_WITH_PIC([yes])]) LT_OPTION_DEFINE([LT_INIT], [no-pic], [_LT_WITH_PIC([no])]) # Old name: AU_DEFUN([AC_LIBTOOL_PICMODE], [_LT_SET_OPTION([LT_INIT], [pic-only]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the `pic-only' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_PICMODE], []) ## ----------------- ## ## LTDL_INIT Options ## ## ----------------- ## m4_define([_LTDL_MODE], []) LT_OPTION_DEFINE([LTDL_INIT], [nonrecursive], [m4_define([_LTDL_MODE], [nonrecursive])]) LT_OPTION_DEFINE([LTDL_INIT], [recursive], [m4_define([_LTDL_MODE], [recursive])]) LT_OPTION_DEFINE([LTDL_INIT], [subproject], [m4_define([_LTDL_MODE], [subproject])]) m4_define([_LTDL_TYPE], []) LT_OPTION_DEFINE([LTDL_INIT], [installable], [m4_define([_LTDL_TYPE], [installable])]) LT_OPTION_DEFINE([LTDL_INIT], [convenience], [m4_define([_LTDL_TYPE], [convenience])]) eztrace-1.1-2/m4/ltsugar.m4000066400000000000000000000104241265506773700154350ustar00rootroot00000000000000# ltsugar.m4 -- libtool m4 base layer. -*-Autoconf-*- # # Copyright (C) 2004, 2005, 2007, 2008 Free Software Foundation, Inc. # Written by Gary V. Vaughan, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 6 ltsugar.m4 # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTSUGAR_VERSION], [m4_if([0.1])]) # lt_join(SEP, ARG1, [ARG2...]) # ----------------------------- # Produce ARG1SEPARG2...SEPARGn, omitting [] arguments and their # associated separator. # Needed until we can rely on m4_join from Autoconf 2.62, since all earlier # versions in m4sugar had bugs. m4_define([lt_join], [m4_if([$#], [1], [], [$#], [2], [[$2]], [m4_if([$2], [], [], [[$2]_])$0([$1], m4_shift(m4_shift($@)))])]) m4_define([_lt_join], [m4_if([$#$2], [2], [], [m4_if([$2], [], [], [[$1$2]])$0([$1], m4_shift(m4_shift($@)))])]) # lt_car(LIST) # lt_cdr(LIST) # ------------ # Manipulate m4 lists. # These macros are necessary as long as will still need to support # Autoconf-2.59 which quotes differently. m4_define([lt_car], [[$1]]) m4_define([lt_cdr], [m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])], [$#], 1, [], [m4_dquote(m4_shift($@))])]) m4_define([lt_unquote], $1) # lt_append(MACRO-NAME, STRING, [SEPARATOR]) # ------------------------------------------ # Redefine MACRO-NAME to hold its former content plus `SEPARATOR'`STRING'. # Note that neither SEPARATOR nor STRING are expanded; they are appended # to MACRO-NAME as is (leaving the expansion for when MACRO-NAME is invoked). # No SEPARATOR is output if MACRO-NAME was previously undefined (different # than defined and empty). # # This macro is needed until we can rely on Autoconf 2.62, since earlier # versions of m4sugar mistakenly expanded SEPARATOR but not STRING. m4_define([lt_append], [m4_define([$1], m4_ifdef([$1], [m4_defn([$1])[$3]])[$2])]) # lt_combine(SEP, PREFIX-LIST, INFIX, SUFFIX1, [SUFFIX2...]) # ---------------------------------------------------------- # Produce a SEP delimited list of all paired combinations of elements of # PREFIX-LIST with SUFFIX1 through SUFFIXn. Each element of the list # has the form PREFIXmINFIXSUFFIXn. # Needed until we can rely on m4_combine added in Autoconf 2.62. m4_define([lt_combine], [m4_if(m4_eval([$# > 3]), [1], [m4_pushdef([_Lt_sep], [m4_define([_Lt_sep], m4_defn([lt_car]))])]]dnl [[m4_foreach([_Lt_prefix], [$2], [m4_foreach([_Lt_suffix], ]m4_dquote(m4_dquote(m4_shift(m4_shift(m4_shift($@)))))[, [_Lt_sep([$1])[]m4_defn([_Lt_prefix])[$3]m4_defn([_Lt_suffix])])])])]) # lt_if_append_uniq(MACRO-NAME, VARNAME, [SEPARATOR], [UNIQ], [NOT-UNIQ]) # ----------------------------------------------------------------------- # Iff MACRO-NAME does not yet contain VARNAME, then append it (delimited # by SEPARATOR if supplied) and expand UNIQ, else NOT-UNIQ. m4_define([lt_if_append_uniq], [m4_ifdef([$1], [m4_if(m4_index([$3]m4_defn([$1])[$3], [$3$2$3]), [-1], [lt_append([$1], [$2], [$3])$4], [$5])], [lt_append([$1], [$2], [$3])$4])]) # lt_dict_add(DICT, KEY, VALUE) # ----------------------------- m4_define([lt_dict_add], [m4_define([$1($2)], [$3])]) # lt_dict_add_subkey(DICT, KEY, SUBKEY, VALUE) # -------------------------------------------- m4_define([lt_dict_add_subkey], [m4_define([$1($2:$3)], [$4])]) # lt_dict_fetch(DICT, KEY, [SUBKEY]) # ---------------------------------- m4_define([lt_dict_fetch], [m4_ifval([$3], m4_ifdef([$1($2:$3)], [m4_defn([$1($2:$3)])]), m4_ifdef([$1($2)], [m4_defn([$1($2)])]))]) # lt_if_dict_fetch(DICT, KEY, [SUBKEY], VALUE, IF-TRUE, [IF-FALSE]) # ----------------------------------------------------------------- m4_define([lt_if_dict_fetch], [m4_if(lt_dict_fetch([$1], [$2], [$3]), [$4], [$5], [$6])]) # lt_dict_filter(DICT, [SUBKEY], VALUE, [SEPARATOR], KEY, [...]) # -------------------------------------------------------------- m4_define([lt_dict_filter], [m4_if([$5], [], [], [lt_join(m4_quote(m4_default([$4], [[, ]])), lt_unquote(m4_split(m4_normalize(m4_foreach(_Lt_key, lt_car([m4_shiftn(4, $@)]), [lt_if_dict_fetch([$1], _Lt_key, [$2], [$3], [_Lt_key ])])))))])[]dnl ]) eztrace-1.1-2/m4/ltversion.m4000066400000000000000000000012621265506773700160010ustar00rootroot00000000000000# ltversion.m4 -- version numbers -*- Autoconf -*- # # Copyright (C) 2004 Free Software Foundation, Inc. # Written by Scott James Remnant, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # @configure_input@ # serial 3337 ltversion.m4 # This file is part of GNU Libtool m4_define([LT_PACKAGE_VERSION], [2.4.2]) m4_define([LT_PACKAGE_REVISION], [1.3337]) AC_DEFUN([LTVERSION_VERSION], [macro_version='2.4.2' macro_revision='1.3337' _LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?]) _LT_DECL(, macro_revision, 0) ]) eztrace-1.1-2/m4/lt~obsolete.m4000066400000000000000000000137561265506773700163410ustar00rootroot00000000000000# lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*- # # Copyright (C) 2004, 2005, 2007, 2009 Free Software Foundation, Inc. # Written by Scott James Remnant, 2004. # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 5 lt~obsolete.m4 # These exist entirely to fool aclocal when bootstrapping libtool. # # In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN) # which have later been changed to m4_define as they aren't part of the # exported API, or moved to Autoconf or Automake where they belong. # # The trouble is, aclocal is a bit thick. It'll see the old AC_DEFUN # in /usr/share/aclocal/libtool.m4 and remember it, then when it sees us # using a macro with the same name in our local m4/libtool.m4 it'll # pull the old libtool.m4 in (it doesn't see our shiny new m4_define # and doesn't know about Autoconf macros at all.) # # So we provide this file, which has a silly filename so it's always # included after everything else. This provides aclocal with the # AC_DEFUNs it wants, but when m4 processes it, it doesn't do anything # because those macros already exist, or will be overwritten later. # We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6. # # Anytime we withdraw an AC_DEFUN or AU_DEFUN, remember to add it here. # Yes, that means every name once taken will need to remain here until # we give up compatibility with versions before 1.7, at which point # we need to keep only those names which we still refer to. # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTOBSOLETE_VERSION], [m4_if([1])]) m4_ifndef([AC_LIBTOOL_LINKER_OPTION], [AC_DEFUN([AC_LIBTOOL_LINKER_OPTION])]) m4_ifndef([AC_PROG_EGREP], [AC_DEFUN([AC_PROG_EGREP])]) m4_ifndef([_LT_AC_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH])]) m4_ifndef([_LT_AC_SHELL_INIT], [AC_DEFUN([_LT_AC_SHELL_INIT])]) m4_ifndef([_LT_AC_SYS_LIBPATH_AIX], [AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX])]) m4_ifndef([_LT_PROG_LTMAIN], [AC_DEFUN([_LT_PROG_LTMAIN])]) m4_ifndef([_LT_AC_TAGVAR], [AC_DEFUN([_LT_AC_TAGVAR])]) m4_ifndef([AC_LTDL_ENABLE_INSTALL], [AC_DEFUN([AC_LTDL_ENABLE_INSTALL])]) m4_ifndef([AC_LTDL_PREOPEN], [AC_DEFUN([AC_LTDL_PREOPEN])]) m4_ifndef([_LT_AC_SYS_COMPILER], [AC_DEFUN([_LT_AC_SYS_COMPILER])]) m4_ifndef([_LT_AC_LOCK], [AC_DEFUN([_LT_AC_LOCK])]) m4_ifndef([AC_LIBTOOL_SYS_OLD_ARCHIVE], [AC_DEFUN([AC_LIBTOOL_SYS_OLD_ARCHIVE])]) m4_ifndef([_LT_AC_TRY_DLOPEN_SELF], [AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF])]) m4_ifndef([AC_LIBTOOL_PROG_CC_C_O], [AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O])]) m4_ifndef([AC_LIBTOOL_SYS_HARD_LINK_LOCKS], [AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS])]) m4_ifndef([AC_LIBTOOL_OBJDIR], [AC_DEFUN([AC_LIBTOOL_OBJDIR])]) m4_ifndef([AC_LTDL_OBJDIR], [AC_DEFUN([AC_LTDL_OBJDIR])]) m4_ifndef([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH], [AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH])]) m4_ifndef([AC_LIBTOOL_SYS_LIB_STRIP], [AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP])]) m4_ifndef([AC_PATH_MAGIC], [AC_DEFUN([AC_PATH_MAGIC])]) m4_ifndef([AC_PROG_LD_GNU], [AC_DEFUN([AC_PROG_LD_GNU])]) m4_ifndef([AC_PROG_LD_RELOAD_FLAG], [AC_DEFUN([AC_PROG_LD_RELOAD_FLAG])]) m4_ifndef([AC_DEPLIBS_CHECK_METHOD], [AC_DEFUN([AC_DEPLIBS_CHECK_METHOD])]) m4_ifndef([AC_LIBTOOL_PROG_COMPILER_NO_RTTI], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI])]) m4_ifndef([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE], [AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE])]) m4_ifndef([AC_LIBTOOL_PROG_COMPILER_PIC], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC])]) m4_ifndef([AC_LIBTOOL_PROG_LD_SHLIBS], [AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS])]) m4_ifndef([AC_LIBTOOL_POSTDEP_PREDEP], [AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP])]) m4_ifndef([LT_AC_PROG_EGREP], [AC_DEFUN([LT_AC_PROG_EGREP])]) m4_ifndef([LT_AC_PROG_SED], [AC_DEFUN([LT_AC_PROG_SED])]) m4_ifndef([_LT_CC_BASENAME], [AC_DEFUN([_LT_CC_BASENAME])]) m4_ifndef([_LT_COMPILER_BOILERPLATE], [AC_DEFUN([_LT_COMPILER_BOILERPLATE])]) m4_ifndef([_LT_LINKER_BOILERPLATE], [AC_DEFUN([_LT_LINKER_BOILERPLATE])]) m4_ifndef([_AC_PROG_LIBTOOL], [AC_DEFUN([_AC_PROG_LIBTOOL])]) m4_ifndef([AC_LIBTOOL_SETUP], [AC_DEFUN([AC_LIBTOOL_SETUP])]) m4_ifndef([_LT_AC_CHECK_DLFCN], [AC_DEFUN([_LT_AC_CHECK_DLFCN])]) m4_ifndef([AC_LIBTOOL_SYS_DYNAMIC_LINKER], [AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER])]) m4_ifndef([_LT_AC_TAGCONFIG], [AC_DEFUN([_LT_AC_TAGCONFIG])]) m4_ifndef([AC_DISABLE_FAST_INSTALL], [AC_DEFUN([AC_DISABLE_FAST_INSTALL])]) m4_ifndef([_LT_AC_LANG_CXX], [AC_DEFUN([_LT_AC_LANG_CXX])]) m4_ifndef([_LT_AC_LANG_F77], [AC_DEFUN([_LT_AC_LANG_F77])]) m4_ifndef([_LT_AC_LANG_GCJ], [AC_DEFUN([_LT_AC_LANG_GCJ])]) m4_ifndef([AC_LIBTOOL_LANG_C_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG])]) m4_ifndef([_LT_AC_LANG_C_CONFIG], [AC_DEFUN([_LT_AC_LANG_C_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_CXX_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG])]) m4_ifndef([_LT_AC_LANG_CXX_CONFIG], [AC_DEFUN([_LT_AC_LANG_CXX_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_F77_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_F77_CONFIG])]) m4_ifndef([_LT_AC_LANG_F77_CONFIG], [AC_DEFUN([_LT_AC_LANG_F77_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_GCJ_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_GCJ_CONFIG])]) m4_ifndef([_LT_AC_LANG_GCJ_CONFIG], [AC_DEFUN([_LT_AC_LANG_GCJ_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_RC_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_RC_CONFIG])]) m4_ifndef([_LT_AC_LANG_RC_CONFIG], [AC_DEFUN([_LT_AC_LANG_RC_CONFIG])]) m4_ifndef([AC_LIBTOOL_CONFIG], [AC_DEFUN([AC_LIBTOOL_CONFIG])]) m4_ifndef([_LT_AC_FILE_LTDLL_C], [AC_DEFUN([_LT_AC_FILE_LTDLL_C])]) m4_ifndef([_LT_REQUIRED_DARWIN_CHECKS], [AC_DEFUN([_LT_REQUIRED_DARWIN_CHECKS])]) m4_ifndef([_LT_AC_PROG_CXXCPP], [AC_DEFUN([_LT_AC_PROG_CXXCPP])]) m4_ifndef([_LT_PREPARE_SED_QUOTE_VARS], [AC_DEFUN([_LT_PREPARE_SED_QUOTE_VARS])]) m4_ifndef([_LT_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_PROG_ECHO_BACKSLASH])]) m4_ifndef([_LT_PROG_F77], [AC_DEFUN([_LT_PROG_F77])]) m4_ifndef([_LT_PROG_FC], [AC_DEFUN([_LT_PROG_FC])]) m4_ifndef([_LT_PROG_CXX], [AC_DEFUN([_LT_PROG_CXX])]) eztrace-1.1-2/m4/pkg.m4000066400000000000000000000171671265506773700145500ustar00rootroot00000000000000# pkg.m4 - Macros to locate and utilise pkg-config. -*- Autoconf -*- # serial 1 (pkg-config-0.24) # # Copyright © 2004 Scott James Remnant . # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # PKG_PROG_PKG_CONFIG([MIN-VERSION]) # ---------------------------------- AC_DEFUN([PKG_PROG_PKG_CONFIG], [m4_pattern_forbid([^_?PKG_[A-Z_]+$]) m4_pattern_allow([^PKG_CONFIG(_(PATH|LIBDIR|SYSROOT_DIR|ALLOW_SYSTEM_(CFLAGS|LIBS)))?$]) m4_pattern_allow([^PKG_CONFIG_(DISABLE_UNINSTALLED|TOP_BUILD_DIR|DEBUG_SPEW)$]) AC_ARG_VAR([PKG_CONFIG], [path to pkg-config utility]) AC_ARG_VAR([PKG_CONFIG_PATH], [directories to add to pkg-config's search path]) AC_ARG_VAR([PKG_CONFIG_LIBDIR], [path overriding pkg-config's built-in search path]) if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then AC_PATH_TOOL([PKG_CONFIG], [pkg-config]) fi if test -n "$PKG_CONFIG"; then _pkg_min_version=m4_default([$1], [0.9.0]) AC_MSG_CHECKING([pkg-config is at least version $_pkg_min_version]) if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) PKG_CONFIG="" fi fi[]dnl ])# PKG_PROG_PKG_CONFIG # PKG_CHECK_EXISTS(MODULES, [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND]) # # Check to see whether a particular set of modules exists. Similar # to PKG_CHECK_MODULES(), but does not set variables or print errors. # # Please remember that m4 expands AC_REQUIRE([PKG_PROG_PKG_CONFIG]) # only at the first occurence in configure.ac, so if the first place # it's called might be skipped (such as if it is within an "if", you # have to call PKG_CHECK_EXISTS manually # -------------------------------------------------------------- AC_DEFUN([PKG_CHECK_EXISTS], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl if test -n "$PKG_CONFIG" && \ AC_RUN_LOG([$PKG_CONFIG --exists --print-errors "$1"]); then m4_default([$2], [:]) m4_ifvaln([$3], [else $3])dnl fi]) # _PKG_CONFIG([VARIABLE], [COMMAND], [MODULES]) # --------------------------------------------- m4_define([_PKG_CONFIG], [if test -n "$$1"; then pkg_cv_[]$1="$$1" elif test -n "$PKG_CONFIG"; then PKG_CHECK_EXISTS([$3], [pkg_cv_[]$1=`$PKG_CONFIG --[]$2 "$3" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes ], [pkg_failed=yes]) else pkg_failed=untried fi[]dnl ])# _PKG_CONFIG # _PKG_SHORT_ERRORS_SUPPORTED # ----------------------------- AC_DEFUN([_PKG_SHORT_ERRORS_SUPPORTED], [AC_REQUIRE([PKG_PROG_PKG_CONFIG]) if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi[]dnl ])# _PKG_SHORT_ERRORS_SUPPORTED # PKG_CHECK_MODULES(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND], # [ACTION-IF-NOT-FOUND]) # # # Note that if there is a possibility the first call to # PKG_CHECK_MODULES might not happen, you should be sure to include an # explicit call to PKG_PROG_PKG_CONFIG in your configure.ac # # # -------------------------------------------------------------- AC_DEFUN([PKG_CHECK_MODULES], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl AC_ARG_VAR([$1][_CFLAGS], [C compiler flags for $1, overriding pkg-config])dnl AC_ARG_VAR([$1][_LIBS], [linker flags for $1, overriding pkg-config])dnl pkg_failed=no AC_MSG_CHECKING([for $1]) _PKG_CONFIG([$1][_CFLAGS], [cflags], [$2]) _PKG_CONFIG([$1][_LIBS], [libs], [$2]) m4_define([_PKG_TEXT], [Alternatively, you may set the environment variables $1[]_CFLAGS and $1[]_LIBS to avoid the need to call pkg-config. See the pkg-config man page for more details.]) if test $pkg_failed = yes; then AC_MSG_RESULT([no]) _PKG_SHORT_ERRORS_SUPPORTED if test $_pkg_short_errors_supported = yes; then $1[]_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "$2" 2>&1` else $1[]_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "$2" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$$1[]_PKG_ERRORS" >&AS_MESSAGE_LOG_FD m4_default([$4], [AC_MSG_ERROR( [Package requirements ($2) were not met: $$1_PKG_ERRORS Consider adjusting the PKG_CONFIG_PATH environment variable if you installed software in a non-standard prefix. _PKG_TEXT])[]dnl ]) elif test $pkg_failed = untried; then AC_MSG_RESULT([no]) m4_default([$4], [AC_MSG_FAILURE( [The pkg-config script could not be found or is too old. Make sure it is in your PATH or set the PKG_CONFIG environment variable to the full path to pkg-config. _PKG_TEXT To get pkg-config, see .])[]dnl ]) else $1[]_CFLAGS=$pkg_cv_[]$1[]_CFLAGS $1[]_LIBS=$pkg_cv_[]$1[]_LIBS AC_MSG_RESULT([yes]) $3 fi[]dnl ])# PKG_CHECK_MODULES # PKG_INSTALLDIR(DIRECTORY) # ------------------------- # Substitutes the variable pkgconfigdir as the location where a module # should install pkg-config .pc files. By default the directory is # $libdir/pkgconfig, but the default can be changed by passing # DIRECTORY. The user can override through the --with-pkgconfigdir # parameter. AC_DEFUN([PKG_INSTALLDIR], [m4_pushdef([pkg_default], [m4_default([$1], ['${libdir}/pkgconfig'])]) m4_pushdef([pkg_description], [pkg-config installation directory @<:@]pkg_default[@:>@]) AC_ARG_WITH([pkgconfigdir], [AS_HELP_STRING([--with-pkgconfigdir], pkg_description)],, [with_pkgconfigdir=]pkg_default) AC_SUBST([pkgconfigdir], [$with_pkgconfigdir]) m4_popdef([pkg_default]) m4_popdef([pkg_description]) ]) dnl PKG_INSTALLDIR # PKG_NOARCH_INSTALLDIR(DIRECTORY) # ------------------------- # Substitutes the variable noarch_pkgconfigdir as the location where a # module should install arch-independent pkg-config .pc files. By # default the directory is $datadir/pkgconfig, but the default can be # changed by passing DIRECTORY. The user can override through the # --with-noarch-pkgconfigdir parameter. AC_DEFUN([PKG_NOARCH_INSTALLDIR], [m4_pushdef([pkg_default], [m4_default([$1], ['${datadir}/pkgconfig'])]) m4_pushdef([pkg_description], [pkg-config arch-independent installation directory @<:@]pkg_default[@:>@]) AC_ARG_WITH([noarch-pkgconfigdir], [AS_HELP_STRING([--with-noarch-pkgconfigdir], pkg_description)],, [with_noarch_pkgconfigdir=]pkg_default) AC_SUBST([noarch_pkgconfigdir], [$with_noarch_pkgconfigdir]) m4_popdef([pkg_default]) m4_popdef([pkg_description]) ]) dnl PKG_NOARCH_INSTALLDIR # PKG_CHECK_VAR(VARIABLE, MODULE, CONFIG-VARIABLE, # [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND]) # ------------------------------------------- # Retrieves the value of the pkg-config variable for the given module. AC_DEFUN([PKG_CHECK_VAR], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl AC_ARG_VAR([$1], [value of $3 for $2, overriding pkg-config])dnl _PKG_CONFIG([$1], [variable="][$3]["], [$2]) AS_VAR_COPY([$1], [pkg_cv_][$1]) AS_VAR_IF([$1], [""], [$5], [$4])dnl ])# PKG_CHECK_VAR eztrace-1.1-2/missing000077500000000000000000000153301265506773700145720ustar00rootroot00000000000000#! /bin/sh # Common wrapper for a few potentially missing GNU programs. scriptversion=2013-10-28.13; # UTC # Copyright (C) 1996-2014 Free Software Foundation, Inc. # Originally written by Fran,cois Pinard , 1996. # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2, or (at your option) # any later version. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. if test $# -eq 0; then echo 1>&2 "Try '$0 --help' for more information" exit 1 fi case $1 in --is-lightweight) # Used by our autoconf macros to check whether the available missing # script is modern enough. exit 0 ;; --run) # Back-compat with the calling convention used by older automake. shift ;; -h|--h|--he|--hel|--help) echo "\ $0 [OPTION]... PROGRAM [ARGUMENT]... Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due to PROGRAM being missing or too old. Options: -h, --help display this help and exit -v, --version output version information and exit Supported PROGRAM values: aclocal autoconf autoheader autom4te automake makeinfo bison yacc flex lex help2man Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and 'g' are ignored when checking the name. Send bug reports to ." exit $? ;; -v|--v|--ve|--ver|--vers|--versi|--versio|--version) echo "missing $scriptversion (GNU Automake)" exit $? ;; -*) echo 1>&2 "$0: unknown '$1' option" echo 1>&2 "Try '$0 --help' for more information" exit 1 ;; esac # Run the given program, remember its exit status. "$@"; st=$? # If it succeeded, we are done. test $st -eq 0 && exit 0 # Also exit now if we it failed (or wasn't found), and '--version' was # passed; such an option is passed most likely to detect whether the # program is present and works. case $2 in --version|--help) exit $st;; esac # Exit code 63 means version mismatch. This often happens when the user # tries to use an ancient version of a tool on a file that requires a # minimum version. if test $st -eq 63; then msg="probably too old" elif test $st -eq 127; then # Program was missing. msg="missing on your system" else # Program was found and executed, but failed. Give up. exit $st fi perl_URL=http://www.perl.org/ flex_URL=http://flex.sourceforge.net/ gnu_software_URL=http://www.gnu.org/software program_details () { case $1 in aclocal|automake) echo "The '$1' program is part of the GNU Automake package:" echo "<$gnu_software_URL/automake>" echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:" echo "<$gnu_software_URL/autoconf>" echo "<$gnu_software_URL/m4/>" echo "<$perl_URL>" ;; autoconf|autom4te|autoheader) echo "The '$1' program is part of the GNU Autoconf package:" echo "<$gnu_software_URL/autoconf/>" echo "It also requires GNU m4 and Perl in order to run:" echo "<$gnu_software_URL/m4/>" echo "<$perl_URL>" ;; esac } give_advice () { # Normalize program name to check for. normalized_program=`echo "$1" | sed ' s/^gnu-//; t s/^gnu//; t s/^g//; t'` printf '%s\n' "'$1' is $msg." configure_deps="'configure.ac' or m4 files included by 'configure.ac'" case $normalized_program in autoconf*) echo "You should only need it if you modified 'configure.ac'," echo "or m4 files included by it." program_details 'autoconf' ;; autoheader*) echo "You should only need it if you modified 'acconfig.h' or" echo "$configure_deps." program_details 'autoheader' ;; automake*) echo "You should only need it if you modified 'Makefile.am' or" echo "$configure_deps." program_details 'automake' ;; aclocal*) echo "You should only need it if you modified 'acinclude.m4' or" echo "$configure_deps." program_details 'aclocal' ;; autom4te*) echo "You might have modified some maintainer files that require" echo "the 'autom4te' program to be rebuilt." program_details 'autom4te' ;; bison*|yacc*) echo "You should only need it if you modified a '.y' file." echo "You may want to install the GNU Bison package:" echo "<$gnu_software_URL/bison/>" ;; lex*|flex*) echo "You should only need it if you modified a '.l' file." echo "You may want to install the Fast Lexical Analyzer package:" echo "<$flex_URL>" ;; help2man*) echo "You should only need it if you modified a dependency" \ "of a man page." echo "You may want to install the GNU Help2man package:" echo "<$gnu_software_URL/help2man/>" ;; makeinfo*) echo "You should only need it if you modified a '.texi' file, or" echo "any other file indirectly affecting the aspect of the manual." echo "You might want to install the Texinfo package:" echo "<$gnu_software_URL/texinfo/>" echo "The spurious makeinfo call might also be the consequence of" echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might" echo "want to install GNU make:" echo "<$gnu_software_URL/make/>" ;; *) echo "You might have modified some files without having the proper" echo "tools for further handling them. Check the 'README' file, it" echo "often tells you about the needed prerequisites for installing" echo "this package. You may also peek at any GNU archive site, in" echo "case some other package contains this missing '$1' program." ;; esac } give_advice "$1" | sed -e '1s/^/WARNING: /' \ -e '2,$s/^/ /' >&2 # Propagate the correct exit status (expected to be 127 for a program # not found, 63 for a program that failed due to version mismatch). exit $st # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC" # time-stamp-end: "; # UTC" # End: eztrace-1.1-2/src/000077500000000000000000000000001265506773700137605ustar00rootroot00000000000000eztrace-1.1-2/src/core/000077500000000000000000000000001265506773700147105ustar00rootroot00000000000000eztrace-1.1-2/src/core/Makefile.am000066400000000000000000000122451265506773700167500ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. TLCFLAGS=$(TL_CPPFLAGS) TLLDFLAGS=$(TL_LDFLAGS) TLLIBADD=$(TL_LIB) GTGCFLAGS=$(GTG_CPPFLAGS) GTGLDFLAGS=$(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD=$(GTG_LIB) bin_PROGRAMS = eztrace_convert eztrace_avail eztrace_loaded eztrace_stats generated_scripts = eztrace_create_plugin eztrace_plugin_generator eztrace.preload bin_SCRIPTS = $(generated_scripts) function.pm input/Makefile.template eztrace_indent_fortran lib_LTLIBRARIES = libeztrace.la \ libeztrace-autostart.la \ libeztrace-convert-core.la eztrace_CPPFLAGS = -I$(top_srcdir)/src/pptrace/ $(TLCFLAGS) -g -O0 -DEZTRACE_LIB_DIR=\"${libdir}/\" -DEZTRACE_ABS_TOP_BUILDDIR=\"${abs_top_builddir}/\" eztrace_LDFLAGS = -g -O0 $(TLLDFLAGS) #TODO: lbfd is not needed when litl is selected eztrace_LDADD = -L${prefix}/lib -ldl $(TLLIBADD) eztrace_SOURCES = ezt_demangle.c if USE_PPTRACE bin_PROGRAMS += eztrace check_PROGRAMS = eztrace eztrace_SOURCES +=eztrace.c \ ../pptrace/pptrace.c \ ../pptrace/binary.c \ ../pptrace/errors.c \ ../pptrace/hijack.c \ ../pptrace/isize.c \ ../pptrace/memory.c \ ../pptrace/opcodes.c \ ../pptrace/tracing.c eztrace_CPPFLAGS += -DUSE_PPTRACE=1 endif if HAVE_DEMANGLE eztrace_CPPFLAGS += -DHAVE_DEMANGLE eztrace_LDADD += -liberty endif if HAVE_LIBOPCODE eztrace_LDFLAGS+=-lopcodes endif #HAVE_LIBOPCODE eztrace_LDADD += -lbfd -liberty -lz eztrace_avail_CPPFLAGS = $(TLCFLAGS) eztrace_avail_LDFLAGS = $(TLLDFLAGS) eztrace_avail_LDADD = -ldl libeztrace-convert-core.la eztrace_avail_SOURCES = eztrace_avail.c eztrace_loaded_CPPFLAGS = $(TLCFLAGS) eztrace_loaded_LDFLAGS = $(TLLDFLAGS) eztrace_loaded_LDADD = -ldl libeztrace-convert-core.la eztrace_loaded_SOURCES = eztrace_loaded.c eztrace_stats_CPPFLAGS = $(TLCFLAGS) eztrace_stats_LDFLAGS = $(TLLDFLAGS) eztrace_stats_LDADD = -ldl libeztrace-convert-core.la $(TLLIBADD) eztrace_stats_SOURCES = eztrace_stats.c eztrace_stats_DEPENDENCIES = libeztrace-convert-core.la eztrace_convert_CPPFLAGS = $(GTGCFLAGS) $(TLCFLAGS) eztrace_convert_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) eztrace_convert_LDADD = $(GTGLIBADD) -ldl libeztrace-convert-core.la $(TLLIBADD) eztrace_convert_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace-convert-core.la eztrace_convert_SOURCES = eztrace_convert.c \ eztrace_convert.h \ eztrace_convert_types.h \ eztrace_types.h \ eztrace_convert_macros.h \ eztrace_litl_packed.h \ eztrace_litl.h \ ev_codes.h \ eztrace_hook.h libeztrace_convert_core_la_CPPFLAGS = $(TLCFLAGS) $(GTGCFLAGS) -DEZTRACE_LIB_DIR=\"${libdir}\" -DDYNLIB_EXT=\"${DYNLIB_EXT}\" libeztrace_convert_core_la_LIBADD = -lm -lpthread $(TLLIBADD) $(GTGLIBADD) libeztrace_convert_core_la_LDFLAGS = --no-undefined $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_core_la_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace_convert_core_la_SOURCES = eztrace_convert_core.c \ eztrace_stats_core.c \ eztrace_stats_core.h \ eztrace_hierarchical_array.c \ eztrace_hierarchical_array.h \ eztrace_array.c \ eztrace_array.h \ eztrace_types.h \ eztrace_convert_types.h \ eztrace_convert_macros.h \ eztrace_litl_packed.h \ eztrace_litl.h \ eztrace_convert.h \ submodules/ezt_submodule_convert.c \ submodules/ezt_submodule.h \ submodules/ezt_getcpu_convert.c \ submodules/ezt_getcpu.h \ ezt_demangle.c \ ezt_demangle.h if HAVE_DEMANGLE libeztrace_convert_core_la_CPPFLAGS += -DHAVE_DEMANGLE libeztrace_convert_core_la_LIBADD += -liberty endif libeztrace_la_CPPFLAGS = $(TLCFLAGS) libeztrace_la_LIBADD = -lm -lpthread $(TLLIBADD) libeztrace_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_la_SOURCES = eztrace_core.c \ eztrace_sampling.c \ pthread_core.c \ submodules/ezt_submodule.c \ submodules/ezt_submodule.h \ submodules/ezt_getcpu.c \ submodules/ezt_getcpu.h libeztrace_autostart_la_CPPFLAGS = $(TLCFLAGS) libeztrace_autostart_la_CFLAGS = -DEZTRACE_AUTOSTART libeztrace_autostart_la_LIBADD = -lm -lpthread $(TLLIBADD) libeztrace_autostart_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_autostart_la_SOURCES = eztrace_core.c \ eztrace_sampling.c \ pthread_core.c \ submodules/ezt_submodule.c \ submodules/ezt_submodule.h \ submodules/ezt_getcpu.c \ submodules/ezt_getcpu.h inputdir = $(datadir)/eztrace input_DATA = input/example.c.template\ input/example_ev_codes.h.template\ input/eztrace_convert_example.c.template \ input/Makefile.template EXTRA_DIST = $(input_DATA) eztrace_create_plugin.in eztrace_plugin_generator function.pm eztrace.c.in eztrace.preload.in eztrace_indent_fortran CLEANFILES = $(generated_scripts) eztrace eztrace_config.h include_HEADERS = eztrace.h\ eztrace_litl_packed.h \ eztrace_litl.h \ ../pptrace/pptrace.h \ eztrace_config.h \ ev_codes.h \ eztrace_list.h \ eztrace_stack.h \ eztrace_hook.h \ eztrace_convert.h\ eztrace_convert_core.h\ eztrace_convert_macros.h\ eztrace_sampling.h\ eztrace_types.h \ eztrace_convert_types.h eztrace-1.1-2/src/core/Makefile.in000066400000000000000000002764561265506773700170010ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ bin_PROGRAMS = eztrace_convert$(EXEEXT) eztrace_avail$(EXEEXT) \ eztrace_loaded$(EXEEXT) eztrace_stats$(EXEEXT) $(am__EXEEXT_1) @USE_PPTRACE_TRUE@am__append_1 = eztrace @USE_PPTRACE_TRUE@check_PROGRAMS = eztrace$(EXEEXT) @USE_PPTRACE_TRUE@am__append_2 = eztrace.c \ @USE_PPTRACE_TRUE@ ../pptrace/pptrace.c \ @USE_PPTRACE_TRUE@ ../pptrace/binary.c \ @USE_PPTRACE_TRUE@ ../pptrace/errors.c \ @USE_PPTRACE_TRUE@ ../pptrace/hijack.c \ @USE_PPTRACE_TRUE@ ../pptrace/isize.c \ @USE_PPTRACE_TRUE@ ../pptrace/memory.c \ @USE_PPTRACE_TRUE@ ../pptrace/opcodes.c \ @USE_PPTRACE_TRUE@ ../pptrace/tracing.c @USE_PPTRACE_TRUE@am__append_3 = -DUSE_PPTRACE=1 @HAVE_DEMANGLE_TRUE@am__append_4 = -DHAVE_DEMANGLE @HAVE_DEMANGLE_TRUE@am__append_5 = -liberty @HAVE_LIBOPCODE_TRUE@am__append_6 = -lopcodes @HAVE_DEMANGLE_TRUE@am__append_7 = -DHAVE_DEMANGLE @HAVE_DEMANGLE_TRUE@am__append_8 = -liberty subdir = src/core ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(include_HEADERS) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = eztrace_create_plugin eztrace_plugin_generator \ eztrace.c eztrace.preload eztrace_config.h CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(libdir)" "$(DESTDIR)$(bindir)" \ "$(DESTDIR)$(bindir)" "$(DESTDIR)$(inputdir)" \ "$(DESTDIR)$(includedir)" LTLIBRARIES = $(lib_LTLIBRARIES) am__DEPENDENCIES_1 = am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) libeztrace_autostart_la_DEPENDENCIES = $(am__DEPENDENCIES_2) am__dirstamp = $(am__leading_dot)dirstamp am_libeztrace_autostart_la_OBJECTS = \ libeztrace_autostart_la-eztrace_core.lo \ libeztrace_autostart_la-eztrace_sampling.lo \ libeztrace_autostart_la-pthread_core.lo \ submodules/libeztrace_autostart_la-ezt_submodule.lo \ submodules/libeztrace_autostart_la-ezt_getcpu.lo libeztrace_autostart_la_OBJECTS = \ $(am_libeztrace_autostart_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libeztrace_autostart_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(libeztrace_autostart_la_CFLAGS) $(CFLAGS) \ $(libeztrace_autostart_la_LDFLAGS) $(LDFLAGS) -o $@ am_libeztrace_convert_core_la_OBJECTS = \ libeztrace_convert_core_la-eztrace_convert_core.lo \ libeztrace_convert_core_la-eztrace_stats_core.lo \ libeztrace_convert_core_la-eztrace_hierarchical_array.lo \ libeztrace_convert_core_la-eztrace_array.lo \ submodules/libeztrace_convert_core_la-ezt_submodule_convert.lo \ submodules/libeztrace_convert_core_la-ezt_getcpu_convert.lo \ libeztrace_convert_core_la-ezt_demangle.lo libeztrace_convert_core_la_OBJECTS = \ $(am_libeztrace_convert_core_la_OBJECTS) libeztrace_convert_core_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_convert_core_la_LDFLAGS) \ $(LDFLAGS) -o $@ libeztrace_la_DEPENDENCIES = $(am__DEPENDENCIES_2) am_libeztrace_la_OBJECTS = libeztrace_la-eztrace_core.lo \ libeztrace_la-eztrace_sampling.lo \ libeztrace_la-pthread_core.lo \ submodules/libeztrace_la-ezt_submodule.lo \ submodules/libeztrace_la-ezt_getcpu.lo libeztrace_la_OBJECTS = $(am_libeztrace_la_OBJECTS) libeztrace_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(libeztrace_la_LDFLAGS) $(LDFLAGS) -o $@ @USE_PPTRACE_TRUE@am__EXEEXT_1 = eztrace$(EXEEXT) PROGRAMS = $(bin_PROGRAMS) am__eztrace_SOURCES_DIST = ezt_demangle.c eztrace.c \ ../pptrace/pptrace.c ../pptrace/binary.c ../pptrace/errors.c \ ../pptrace/hijack.c ../pptrace/isize.c ../pptrace/memory.c \ ../pptrace/opcodes.c ../pptrace/tracing.c @USE_PPTRACE_TRUE@am__objects_1 = eztrace-eztrace.$(OBJEXT) \ @USE_PPTRACE_TRUE@ ../pptrace/eztrace-pptrace.$(OBJEXT) \ @USE_PPTRACE_TRUE@ ../pptrace/eztrace-binary.$(OBJEXT) \ @USE_PPTRACE_TRUE@ ../pptrace/eztrace-errors.$(OBJEXT) \ @USE_PPTRACE_TRUE@ ../pptrace/eztrace-hijack.$(OBJEXT) \ @USE_PPTRACE_TRUE@ ../pptrace/eztrace-isize.$(OBJEXT) \ @USE_PPTRACE_TRUE@ ../pptrace/eztrace-memory.$(OBJEXT) \ @USE_PPTRACE_TRUE@ ../pptrace/eztrace-opcodes.$(OBJEXT) \ @USE_PPTRACE_TRUE@ ../pptrace/eztrace-tracing.$(OBJEXT) am_eztrace_OBJECTS = eztrace-ezt_demangle.$(OBJEXT) $(am__objects_1) eztrace_OBJECTS = $(am_eztrace_OBJECTS) eztrace_DEPENDENCIES = $(am__DEPENDENCIES_2) $(am__DEPENDENCIES_1) eztrace_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(eztrace_LDFLAGS) $(LDFLAGS) -o $@ am_eztrace_avail_OBJECTS = eztrace_avail-eztrace_avail.$(OBJEXT) eztrace_avail_OBJECTS = $(am_eztrace_avail_OBJECTS) eztrace_avail_DEPENDENCIES = libeztrace-convert-core.la eztrace_avail_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(eztrace_avail_LDFLAGS) $(LDFLAGS) -o $@ am_eztrace_convert_OBJECTS = \ eztrace_convert-eztrace_convert.$(OBJEXT) eztrace_convert_OBJECTS = $(am_eztrace_convert_OBJECTS) eztrace_convert_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(eztrace_convert_LDFLAGS) $(LDFLAGS) \ -o $@ am_eztrace_loaded_OBJECTS = eztrace_loaded-eztrace_loaded.$(OBJEXT) eztrace_loaded_OBJECTS = $(am_eztrace_loaded_OBJECTS) eztrace_loaded_DEPENDENCIES = libeztrace-convert-core.la eztrace_loaded_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(eztrace_loaded_LDFLAGS) $(LDFLAGS) -o \ $@ am_eztrace_stats_OBJECTS = eztrace_stats-eztrace_stats.$(OBJEXT) eztrace_stats_OBJECTS = $(am_eztrace_stats_OBJECTS) eztrace_stats_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(eztrace_stats_LDFLAGS) $(LDFLAGS) -o $@ SCRIPTS = $(bin_SCRIPTS) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libeztrace_autostart_la_SOURCES) \ $(libeztrace_convert_core_la_SOURCES) $(libeztrace_la_SOURCES) \ $(eztrace_SOURCES) $(eztrace_avail_SOURCES) \ $(eztrace_convert_SOURCES) $(eztrace_loaded_SOURCES) \ $(eztrace_stats_SOURCES) DIST_SOURCES = $(libeztrace_autostart_la_SOURCES) \ $(libeztrace_convert_core_la_SOURCES) $(libeztrace_la_SOURCES) \ $(am__eztrace_SOURCES_DIST) $(eztrace_avail_SOURCES) \ $(eztrace_convert_SOURCES) $(eztrace_loaded_SOURCES) \ $(eztrace_stats_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac DATA = $(input_DATA) HEADERS = $(include_HEADERS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/eztrace.c.in \ $(srcdir)/eztrace.preload.in $(srcdir)/eztrace_config.h.in \ $(srcdir)/eztrace_create_plugin.in \ $(srcdir)/eztrace_plugin_generator.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ TLCFLAGS = $(TL_CPPFLAGS) TLLDFLAGS = $(TL_LDFLAGS) TLLIBADD = $(TL_LIB) GTGCFLAGS = $(GTG_CPPFLAGS) GTGLDFLAGS = $(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD = $(GTG_LIB) generated_scripts = eztrace_create_plugin eztrace_plugin_generator eztrace.preload bin_SCRIPTS = $(generated_scripts) function.pm input/Makefile.template eztrace_indent_fortran lib_LTLIBRARIES = libeztrace.la \ libeztrace-autostart.la \ libeztrace-convert-core.la eztrace_CPPFLAGS = -I$(top_srcdir)/src/pptrace/ $(TLCFLAGS) -g -O0 \ -DEZTRACE_LIB_DIR=\"${libdir}/\" \ -DEZTRACE_ABS_TOP_BUILDDIR=\"${abs_top_builddir}/\" \ $(am__append_3) $(am__append_4) eztrace_LDFLAGS = -g -O0 $(TLLDFLAGS) $(am__append_6) #TODO: lbfd is not needed when litl is selected eztrace_LDADD = -L${prefix}/lib -ldl $(TLLIBADD) $(am__append_5) -lbfd \ -liberty -lz eztrace_SOURCES = ezt_demangle.c $(am__append_2) eztrace_avail_CPPFLAGS = $(TLCFLAGS) eztrace_avail_LDFLAGS = $(TLLDFLAGS) eztrace_avail_LDADD = -ldl libeztrace-convert-core.la eztrace_avail_SOURCES = eztrace_avail.c eztrace_loaded_CPPFLAGS = $(TLCFLAGS) eztrace_loaded_LDFLAGS = $(TLLDFLAGS) eztrace_loaded_LDADD = -ldl libeztrace-convert-core.la eztrace_loaded_SOURCES = eztrace_loaded.c eztrace_stats_CPPFLAGS = $(TLCFLAGS) eztrace_stats_LDFLAGS = $(TLLDFLAGS) eztrace_stats_LDADD = -ldl libeztrace-convert-core.la $(TLLIBADD) eztrace_stats_SOURCES = eztrace_stats.c eztrace_stats_DEPENDENCIES = libeztrace-convert-core.la eztrace_convert_CPPFLAGS = $(GTGCFLAGS) $(TLCFLAGS) eztrace_convert_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) eztrace_convert_LDADD = $(GTGLIBADD) -ldl libeztrace-convert-core.la $(TLLIBADD) eztrace_convert_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace-convert-core.la eztrace_convert_SOURCES = eztrace_convert.c \ eztrace_convert.h \ eztrace_convert_types.h \ eztrace_types.h \ eztrace_convert_macros.h \ eztrace_litl_packed.h \ eztrace_litl.h \ ev_codes.h \ eztrace_hook.h libeztrace_convert_core_la_CPPFLAGS = $(TLCFLAGS) $(GTGCFLAGS) \ -DEZTRACE_LIB_DIR=\"${libdir}\" -DDYNLIB_EXT=\"${DYNLIB_EXT}\" \ $(am__append_7) libeztrace_convert_core_la_LIBADD = -lm -lpthread $(TLLIBADD) \ $(GTGLIBADD) $(am__append_8) libeztrace_convert_core_la_LDFLAGS = --no-undefined $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_core_la_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace_convert_core_la_SOURCES = eztrace_convert_core.c \ eztrace_stats_core.c \ eztrace_stats_core.h \ eztrace_hierarchical_array.c \ eztrace_hierarchical_array.h \ eztrace_array.c \ eztrace_array.h \ eztrace_types.h \ eztrace_convert_types.h \ eztrace_convert_macros.h \ eztrace_litl_packed.h \ eztrace_litl.h \ eztrace_convert.h \ submodules/ezt_submodule_convert.c \ submodules/ezt_submodule.h \ submodules/ezt_getcpu_convert.c \ submodules/ezt_getcpu.h \ ezt_demangle.c \ ezt_demangle.h libeztrace_la_CPPFLAGS = $(TLCFLAGS) libeztrace_la_LIBADD = -lm -lpthread $(TLLIBADD) libeztrace_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_la_SOURCES = eztrace_core.c \ eztrace_sampling.c \ pthread_core.c \ submodules/ezt_submodule.c \ submodules/ezt_submodule.h \ submodules/ezt_getcpu.c \ submodules/ezt_getcpu.h libeztrace_autostart_la_CPPFLAGS = $(TLCFLAGS) libeztrace_autostart_la_CFLAGS = -DEZTRACE_AUTOSTART libeztrace_autostart_la_LIBADD = -lm -lpthread $(TLLIBADD) libeztrace_autostart_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_autostart_la_SOURCES = eztrace_core.c \ eztrace_sampling.c \ pthread_core.c \ submodules/ezt_submodule.c \ submodules/ezt_submodule.h \ submodules/ezt_getcpu.c \ submodules/ezt_getcpu.h inputdir = $(datadir)/eztrace input_DATA = input/example.c.template\ input/example_ev_codes.h.template\ input/eztrace_convert_example.c.template \ input/Makefile.template EXTRA_DIST = $(input_DATA) eztrace_create_plugin.in eztrace_plugin_generator function.pm eztrace.c.in eztrace.preload.in eztrace_indent_fortran CLEANFILES = $(generated_scripts) eztrace eztrace_config.h include_HEADERS = eztrace.h\ eztrace_litl_packed.h \ eztrace_litl.h \ ../pptrace/pptrace.h \ eztrace_config.h \ ev_codes.h \ eztrace_list.h \ eztrace_stack.h \ eztrace_hook.h \ eztrace_convert.h\ eztrace_convert_core.h\ eztrace_convert_macros.h\ eztrace_sampling.h\ eztrace_types.h \ eztrace_convert_types.h all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/core/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu src/core/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): eztrace_create_plugin: $(top_builddir)/config.status $(srcdir)/eztrace_create_plugin.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ eztrace_plugin_generator: $(top_builddir)/config.status $(srcdir)/eztrace_plugin_generator.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ eztrace.c: $(top_builddir)/config.status $(srcdir)/eztrace.c.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ eztrace.preload: $(top_builddir)/config.status $(srcdir)/eztrace.preload.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ eztrace_config.h: $(top_builddir)/config.status $(srcdir)/eztrace_config.h.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ } uninstall-libLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ done clean-libLTLIBRARIES: -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) @list='$(lib_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } submodules/$(am__dirstamp): @$(MKDIR_P) submodules @: > submodules/$(am__dirstamp) submodules/$(DEPDIR)/$(am__dirstamp): @$(MKDIR_P) submodules/$(DEPDIR) @: > submodules/$(DEPDIR)/$(am__dirstamp) submodules/libeztrace_autostart_la-ezt_submodule.lo: \ submodules/$(am__dirstamp) \ submodules/$(DEPDIR)/$(am__dirstamp) submodules/libeztrace_autostart_la-ezt_getcpu.lo: \ submodules/$(am__dirstamp) \ submodules/$(DEPDIR)/$(am__dirstamp) libeztrace-autostart.la: $(libeztrace_autostart_la_OBJECTS) $(libeztrace_autostart_la_DEPENDENCIES) $(EXTRA_libeztrace_autostart_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_autostart_la_LINK) -rpath $(libdir) $(libeztrace_autostart_la_OBJECTS) $(libeztrace_autostart_la_LIBADD) $(LIBS) submodules/libeztrace_convert_core_la-ezt_submodule_convert.lo: \ submodules/$(am__dirstamp) \ submodules/$(DEPDIR)/$(am__dirstamp) submodules/libeztrace_convert_core_la-ezt_getcpu_convert.lo: \ submodules/$(am__dirstamp) \ submodules/$(DEPDIR)/$(am__dirstamp) libeztrace-convert-core.la: $(libeztrace_convert_core_la_OBJECTS) $(libeztrace_convert_core_la_DEPENDENCIES) $(EXTRA_libeztrace_convert_core_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_convert_core_la_LINK) -rpath $(libdir) $(libeztrace_convert_core_la_OBJECTS) $(libeztrace_convert_core_la_LIBADD) $(LIBS) submodules/libeztrace_la-ezt_submodule.lo: submodules/$(am__dirstamp) \ submodules/$(DEPDIR)/$(am__dirstamp) submodules/libeztrace_la-ezt_getcpu.lo: submodules/$(am__dirstamp) \ submodules/$(DEPDIR)/$(am__dirstamp) libeztrace.la: $(libeztrace_la_OBJECTS) $(libeztrace_la_DEPENDENCIES) $(EXTRA_libeztrace_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_la_LINK) -rpath $(libdir) $(libeztrace_la_OBJECTS) $(libeztrace_la_LIBADD) $(LIBS) install-binPROGRAMS: $(bin_PROGRAMS) @$(NORMAL_INSTALL) @list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(bindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(bindir)" || exit 1; \ fi; \ for p in $$list; do echo "$$p $$p"; done | \ sed 's/$(EXEEXT)$$//' | \ while read p p1; do if test -f $$p \ || test -f $$p1 \ ; then echo "$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n;h' \ -e 's|.*|.|' \ -e 'p;x;s,.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/' | \ sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1 } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) files[d] = files[d] " " $$1; \ else { print "f", $$3 "/" $$4, $$1; } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files '$(DESTDIR)$(bindir)$$dir'"; \ $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(bindir)$$dir" || exit $$?; \ } \ ; done uninstall-binPROGRAMS: @$(NORMAL_UNINSTALL) @list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 'h;s,^.*/,,;s/$(EXEEXT)$$//;$(transform)' \ -e 's/$$/$(EXEEXT)/' \ `; \ test -n "$$list" || exit 0; \ echo " ( cd '$(DESTDIR)$(bindir)' && rm -f" $$files ")"; \ cd "$(DESTDIR)$(bindir)" && rm -f $$files clean-binPROGRAMS: @list='$(bin_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list clean-checkPROGRAMS: @list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list ../pptrace/$(am__dirstamp): @$(MKDIR_P) ../pptrace @: > ../pptrace/$(am__dirstamp) ../pptrace/$(DEPDIR)/$(am__dirstamp): @$(MKDIR_P) ../pptrace/$(DEPDIR) @: > ../pptrace/$(DEPDIR)/$(am__dirstamp) ../pptrace/eztrace-pptrace.$(OBJEXT): ../pptrace/$(am__dirstamp) \ ../pptrace/$(DEPDIR)/$(am__dirstamp) ../pptrace/eztrace-binary.$(OBJEXT): ../pptrace/$(am__dirstamp) \ ../pptrace/$(DEPDIR)/$(am__dirstamp) ../pptrace/eztrace-errors.$(OBJEXT): ../pptrace/$(am__dirstamp) \ ../pptrace/$(DEPDIR)/$(am__dirstamp) ../pptrace/eztrace-hijack.$(OBJEXT): ../pptrace/$(am__dirstamp) \ ../pptrace/$(DEPDIR)/$(am__dirstamp) ../pptrace/eztrace-isize.$(OBJEXT): ../pptrace/$(am__dirstamp) \ ../pptrace/$(DEPDIR)/$(am__dirstamp) ../pptrace/eztrace-memory.$(OBJEXT): ../pptrace/$(am__dirstamp) \ ../pptrace/$(DEPDIR)/$(am__dirstamp) ../pptrace/eztrace-opcodes.$(OBJEXT): ../pptrace/$(am__dirstamp) \ ../pptrace/$(DEPDIR)/$(am__dirstamp) ../pptrace/eztrace-tracing.$(OBJEXT): ../pptrace/$(am__dirstamp) \ ../pptrace/$(DEPDIR)/$(am__dirstamp) eztrace$(EXEEXT): $(eztrace_OBJECTS) $(eztrace_DEPENDENCIES) $(EXTRA_eztrace_DEPENDENCIES) @rm -f eztrace$(EXEEXT) $(AM_V_CCLD)$(eztrace_LINK) $(eztrace_OBJECTS) $(eztrace_LDADD) $(LIBS) eztrace_avail$(EXEEXT): $(eztrace_avail_OBJECTS) $(eztrace_avail_DEPENDENCIES) $(EXTRA_eztrace_avail_DEPENDENCIES) @rm -f eztrace_avail$(EXEEXT) $(AM_V_CCLD)$(eztrace_avail_LINK) $(eztrace_avail_OBJECTS) $(eztrace_avail_LDADD) $(LIBS) eztrace_convert$(EXEEXT): $(eztrace_convert_OBJECTS) $(eztrace_convert_DEPENDENCIES) $(EXTRA_eztrace_convert_DEPENDENCIES) @rm -f eztrace_convert$(EXEEXT) $(AM_V_CCLD)$(eztrace_convert_LINK) $(eztrace_convert_OBJECTS) $(eztrace_convert_LDADD) $(LIBS) eztrace_loaded$(EXEEXT): $(eztrace_loaded_OBJECTS) $(eztrace_loaded_DEPENDENCIES) $(EXTRA_eztrace_loaded_DEPENDENCIES) @rm -f eztrace_loaded$(EXEEXT) $(AM_V_CCLD)$(eztrace_loaded_LINK) $(eztrace_loaded_OBJECTS) $(eztrace_loaded_LDADD) $(LIBS) eztrace_stats$(EXEEXT): $(eztrace_stats_OBJECTS) $(eztrace_stats_DEPENDENCIES) $(EXTRA_eztrace_stats_DEPENDENCIES) @rm -f eztrace_stats$(EXEEXT) $(AM_V_CCLD)$(eztrace_stats_LINK) $(eztrace_stats_OBJECTS) $(eztrace_stats_LDADD) $(LIBS) install-binSCRIPTS: $(bin_SCRIPTS) @$(NORMAL_INSTALL) @list='$(bin_SCRIPTS)'; test -n "$(bindir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(bindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(bindir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ if test -f "$$d$$p"; then echo "$$d$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n' \ -e 'h;s|.*|.|' \ -e 'p;x;s,.*/,,;$(transform)' | sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1; } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) { files[d] = files[d] " " $$1; \ if (++n[d] == $(am__install_max)) { \ print "f", d, files[d]; n[d] = 0; files[d] = "" } } \ else { print "f", d "/" $$4, $$1 } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_SCRIPT) $$files '$(DESTDIR)$(bindir)$$dir'"; \ $(INSTALL_SCRIPT) $$files "$(DESTDIR)$(bindir)$$dir" || exit $$?; \ } \ ; done uninstall-binSCRIPTS: @$(NORMAL_UNINSTALL) @list='$(bin_SCRIPTS)'; test -n "$(bindir)" || exit 0; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 's,.*/,,;$(transform)'`; \ dir='$(DESTDIR)$(bindir)'; $(am__uninstall_files_from_dir) mostlyclean-compile: -rm -f *.$(OBJEXT) -rm -f ../pptrace/*.$(OBJEXT) -rm -f submodules/*.$(OBJEXT) -rm -f submodules/*.lo distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@../pptrace/$(DEPDIR)/eztrace-binary.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@../pptrace/$(DEPDIR)/eztrace-errors.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@../pptrace/$(DEPDIR)/eztrace-hijack.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@../pptrace/$(DEPDIR)/eztrace-isize.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@../pptrace/$(DEPDIR)/eztrace-memory.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@../pptrace/$(DEPDIR)/eztrace-opcodes.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@../pptrace/$(DEPDIR)/eztrace-pptrace.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@../pptrace/$(DEPDIR)/eztrace-tracing.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eztrace-ezt_demangle.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eztrace-eztrace.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eztrace_avail-eztrace_avail.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eztrace_convert-eztrace_convert.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eztrace_loaded-eztrace_loaded.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eztrace_stats-eztrace_stats.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_autostart_la-eztrace_core.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_autostart_la-eztrace_sampling.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_autostart_la-pthread_core.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_core_la-ezt_demangle.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_core_la-eztrace_array.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_core_la-eztrace_convert_core.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_core_la-eztrace_hierarchical_array.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_core_la-eztrace_stats_core.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_la-eztrace_core.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_la-eztrace_sampling.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_la-pthread_core.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@submodules/$(DEPDIR)/libeztrace_autostart_la-ezt_getcpu.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@submodules/$(DEPDIR)/libeztrace_autostart_la-ezt_submodule.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@submodules/$(DEPDIR)/libeztrace_convert_core_la-ezt_getcpu_convert.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@submodules/$(DEPDIR)/libeztrace_convert_core_la-ezt_submodule_convert.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@submodules/$(DEPDIR)/libeztrace_la-ezt_getcpu.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@submodules/$(DEPDIR)/libeztrace_la-ezt_submodule.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< libeztrace_autostart_la-eztrace_core.lo: eztrace_core.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_la_CFLAGS) $(CFLAGS) -MT libeztrace_autostart_la-eztrace_core.lo -MD -MP -MF $(DEPDIR)/libeztrace_autostart_la-eztrace_core.Tpo -c -o libeztrace_autostart_la-eztrace_core.lo `test -f 'eztrace_core.c' || echo '$(srcdir)/'`eztrace_core.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_autostart_la-eztrace_core.Tpo $(DEPDIR)/libeztrace_autostart_la-eztrace_core.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_core.c' object='libeztrace_autostart_la-eztrace_core.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_la_CFLAGS) $(CFLAGS) -c -o libeztrace_autostart_la-eztrace_core.lo `test -f 'eztrace_core.c' || echo '$(srcdir)/'`eztrace_core.c libeztrace_autostart_la-eztrace_sampling.lo: eztrace_sampling.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_la_CFLAGS) $(CFLAGS) -MT libeztrace_autostart_la-eztrace_sampling.lo -MD -MP -MF $(DEPDIR)/libeztrace_autostart_la-eztrace_sampling.Tpo -c -o libeztrace_autostart_la-eztrace_sampling.lo `test -f 'eztrace_sampling.c' || echo '$(srcdir)/'`eztrace_sampling.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_autostart_la-eztrace_sampling.Tpo $(DEPDIR)/libeztrace_autostart_la-eztrace_sampling.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_sampling.c' object='libeztrace_autostart_la-eztrace_sampling.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_la_CFLAGS) $(CFLAGS) -c -o libeztrace_autostart_la-eztrace_sampling.lo `test -f 'eztrace_sampling.c' || echo '$(srcdir)/'`eztrace_sampling.c libeztrace_autostart_la-pthread_core.lo: pthread_core.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_la_CFLAGS) $(CFLAGS) -MT libeztrace_autostart_la-pthread_core.lo -MD -MP -MF $(DEPDIR)/libeztrace_autostart_la-pthread_core.Tpo -c -o libeztrace_autostart_la-pthread_core.lo `test -f 'pthread_core.c' || echo '$(srcdir)/'`pthread_core.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_autostart_la-pthread_core.Tpo $(DEPDIR)/libeztrace_autostart_la-pthread_core.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='pthread_core.c' object='libeztrace_autostart_la-pthread_core.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_la_CFLAGS) $(CFLAGS) -c -o libeztrace_autostart_la-pthread_core.lo `test -f 'pthread_core.c' || echo '$(srcdir)/'`pthread_core.c submodules/libeztrace_autostart_la-ezt_submodule.lo: submodules/ezt_submodule.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_la_CFLAGS) $(CFLAGS) -MT submodules/libeztrace_autostart_la-ezt_submodule.lo -MD -MP -MF submodules/$(DEPDIR)/libeztrace_autostart_la-ezt_submodule.Tpo -c -o submodules/libeztrace_autostart_la-ezt_submodule.lo `test -f 'submodules/ezt_submodule.c' || echo '$(srcdir)/'`submodules/ezt_submodule.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) submodules/$(DEPDIR)/libeztrace_autostart_la-ezt_submodule.Tpo submodules/$(DEPDIR)/libeztrace_autostart_la-ezt_submodule.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='submodules/ezt_submodule.c' object='submodules/libeztrace_autostart_la-ezt_submodule.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_la_CFLAGS) $(CFLAGS) -c -o submodules/libeztrace_autostart_la-ezt_submodule.lo `test -f 'submodules/ezt_submodule.c' || echo '$(srcdir)/'`submodules/ezt_submodule.c submodules/libeztrace_autostart_la-ezt_getcpu.lo: submodules/ezt_getcpu.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_la_CFLAGS) $(CFLAGS) -MT submodules/libeztrace_autostart_la-ezt_getcpu.lo -MD -MP -MF submodules/$(DEPDIR)/libeztrace_autostart_la-ezt_getcpu.Tpo -c -o submodules/libeztrace_autostart_la-ezt_getcpu.lo `test -f 'submodules/ezt_getcpu.c' || echo '$(srcdir)/'`submodules/ezt_getcpu.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) submodules/$(DEPDIR)/libeztrace_autostart_la-ezt_getcpu.Tpo submodules/$(DEPDIR)/libeztrace_autostart_la-ezt_getcpu.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='submodules/ezt_getcpu.c' object='submodules/libeztrace_autostart_la-ezt_getcpu.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_la_CFLAGS) $(CFLAGS) -c -o submodules/libeztrace_autostart_la-ezt_getcpu.lo `test -f 'submodules/ezt_getcpu.c' || echo '$(srcdir)/'`submodules/ezt_getcpu.c libeztrace_convert_core_la-eztrace_convert_core.lo: eztrace_convert_core.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_core_la-eztrace_convert_core.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_core_la-eztrace_convert_core.Tpo -c -o libeztrace_convert_core_la-eztrace_convert_core.lo `test -f 'eztrace_convert_core.c' || echo '$(srcdir)/'`eztrace_convert_core.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_core_la-eztrace_convert_core.Tpo $(DEPDIR)/libeztrace_convert_core_la-eztrace_convert_core.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_core.c' object='libeztrace_convert_core_la-eztrace_convert_core.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_core_la-eztrace_convert_core.lo `test -f 'eztrace_convert_core.c' || echo '$(srcdir)/'`eztrace_convert_core.c libeztrace_convert_core_la-eztrace_stats_core.lo: eztrace_stats_core.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_core_la-eztrace_stats_core.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_core_la-eztrace_stats_core.Tpo -c -o libeztrace_convert_core_la-eztrace_stats_core.lo `test -f 'eztrace_stats_core.c' || echo '$(srcdir)/'`eztrace_stats_core.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_core_la-eztrace_stats_core.Tpo $(DEPDIR)/libeztrace_convert_core_la-eztrace_stats_core.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_stats_core.c' object='libeztrace_convert_core_la-eztrace_stats_core.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_core_la-eztrace_stats_core.lo `test -f 'eztrace_stats_core.c' || echo '$(srcdir)/'`eztrace_stats_core.c libeztrace_convert_core_la-eztrace_hierarchical_array.lo: eztrace_hierarchical_array.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_core_la-eztrace_hierarchical_array.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_core_la-eztrace_hierarchical_array.Tpo -c -o libeztrace_convert_core_la-eztrace_hierarchical_array.lo `test -f 'eztrace_hierarchical_array.c' || echo '$(srcdir)/'`eztrace_hierarchical_array.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_core_la-eztrace_hierarchical_array.Tpo $(DEPDIR)/libeztrace_convert_core_la-eztrace_hierarchical_array.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_hierarchical_array.c' object='libeztrace_convert_core_la-eztrace_hierarchical_array.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_core_la-eztrace_hierarchical_array.lo `test -f 'eztrace_hierarchical_array.c' || echo '$(srcdir)/'`eztrace_hierarchical_array.c libeztrace_convert_core_la-eztrace_array.lo: eztrace_array.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_core_la-eztrace_array.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_core_la-eztrace_array.Tpo -c -o libeztrace_convert_core_la-eztrace_array.lo `test -f 'eztrace_array.c' || echo '$(srcdir)/'`eztrace_array.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_core_la-eztrace_array.Tpo $(DEPDIR)/libeztrace_convert_core_la-eztrace_array.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_array.c' object='libeztrace_convert_core_la-eztrace_array.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_core_la-eztrace_array.lo `test -f 'eztrace_array.c' || echo '$(srcdir)/'`eztrace_array.c submodules/libeztrace_convert_core_la-ezt_submodule_convert.lo: submodules/ezt_submodule_convert.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT submodules/libeztrace_convert_core_la-ezt_submodule_convert.lo -MD -MP -MF submodules/$(DEPDIR)/libeztrace_convert_core_la-ezt_submodule_convert.Tpo -c -o submodules/libeztrace_convert_core_la-ezt_submodule_convert.lo `test -f 'submodules/ezt_submodule_convert.c' || echo '$(srcdir)/'`submodules/ezt_submodule_convert.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) submodules/$(DEPDIR)/libeztrace_convert_core_la-ezt_submodule_convert.Tpo submodules/$(DEPDIR)/libeztrace_convert_core_la-ezt_submodule_convert.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='submodules/ezt_submodule_convert.c' object='submodules/libeztrace_convert_core_la-ezt_submodule_convert.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o submodules/libeztrace_convert_core_la-ezt_submodule_convert.lo `test -f 'submodules/ezt_submodule_convert.c' || echo '$(srcdir)/'`submodules/ezt_submodule_convert.c submodules/libeztrace_convert_core_la-ezt_getcpu_convert.lo: submodules/ezt_getcpu_convert.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT submodules/libeztrace_convert_core_la-ezt_getcpu_convert.lo -MD -MP -MF submodules/$(DEPDIR)/libeztrace_convert_core_la-ezt_getcpu_convert.Tpo -c -o submodules/libeztrace_convert_core_la-ezt_getcpu_convert.lo `test -f 'submodules/ezt_getcpu_convert.c' || echo '$(srcdir)/'`submodules/ezt_getcpu_convert.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) submodules/$(DEPDIR)/libeztrace_convert_core_la-ezt_getcpu_convert.Tpo submodules/$(DEPDIR)/libeztrace_convert_core_la-ezt_getcpu_convert.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='submodules/ezt_getcpu_convert.c' object='submodules/libeztrace_convert_core_la-ezt_getcpu_convert.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o submodules/libeztrace_convert_core_la-ezt_getcpu_convert.lo `test -f 'submodules/ezt_getcpu_convert.c' || echo '$(srcdir)/'`submodules/ezt_getcpu_convert.c libeztrace_convert_core_la-ezt_demangle.lo: ezt_demangle.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_core_la-ezt_demangle.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_core_la-ezt_demangle.Tpo -c -o libeztrace_convert_core_la-ezt_demangle.lo `test -f 'ezt_demangle.c' || echo '$(srcdir)/'`ezt_demangle.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_core_la-ezt_demangle.Tpo $(DEPDIR)/libeztrace_convert_core_la-ezt_demangle.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ezt_demangle.c' object='libeztrace_convert_core_la-ezt_demangle.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_core_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_core_la-ezt_demangle.lo `test -f 'ezt_demangle.c' || echo '$(srcdir)/'`ezt_demangle.c libeztrace_la-eztrace_core.lo: eztrace_core.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_la-eztrace_core.lo -MD -MP -MF $(DEPDIR)/libeztrace_la-eztrace_core.Tpo -c -o libeztrace_la-eztrace_core.lo `test -f 'eztrace_core.c' || echo '$(srcdir)/'`eztrace_core.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_la-eztrace_core.Tpo $(DEPDIR)/libeztrace_la-eztrace_core.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_core.c' object='libeztrace_la-eztrace_core.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_la-eztrace_core.lo `test -f 'eztrace_core.c' || echo '$(srcdir)/'`eztrace_core.c libeztrace_la-eztrace_sampling.lo: eztrace_sampling.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_la-eztrace_sampling.lo -MD -MP -MF $(DEPDIR)/libeztrace_la-eztrace_sampling.Tpo -c -o libeztrace_la-eztrace_sampling.lo `test -f 'eztrace_sampling.c' || echo '$(srcdir)/'`eztrace_sampling.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_la-eztrace_sampling.Tpo $(DEPDIR)/libeztrace_la-eztrace_sampling.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_sampling.c' object='libeztrace_la-eztrace_sampling.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_la-eztrace_sampling.lo `test -f 'eztrace_sampling.c' || echo '$(srcdir)/'`eztrace_sampling.c libeztrace_la-pthread_core.lo: pthread_core.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_la-pthread_core.lo -MD -MP -MF $(DEPDIR)/libeztrace_la-pthread_core.Tpo -c -o libeztrace_la-pthread_core.lo `test -f 'pthread_core.c' || echo '$(srcdir)/'`pthread_core.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_la-pthread_core.Tpo $(DEPDIR)/libeztrace_la-pthread_core.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='pthread_core.c' object='libeztrace_la-pthread_core.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_la-pthread_core.lo `test -f 'pthread_core.c' || echo '$(srcdir)/'`pthread_core.c submodules/libeztrace_la-ezt_submodule.lo: submodules/ezt_submodule.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT submodules/libeztrace_la-ezt_submodule.lo -MD -MP -MF submodules/$(DEPDIR)/libeztrace_la-ezt_submodule.Tpo -c -o submodules/libeztrace_la-ezt_submodule.lo `test -f 'submodules/ezt_submodule.c' || echo '$(srcdir)/'`submodules/ezt_submodule.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) submodules/$(DEPDIR)/libeztrace_la-ezt_submodule.Tpo submodules/$(DEPDIR)/libeztrace_la-ezt_submodule.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='submodules/ezt_submodule.c' object='submodules/libeztrace_la-ezt_submodule.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o submodules/libeztrace_la-ezt_submodule.lo `test -f 'submodules/ezt_submodule.c' || echo '$(srcdir)/'`submodules/ezt_submodule.c submodules/libeztrace_la-ezt_getcpu.lo: submodules/ezt_getcpu.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT submodules/libeztrace_la-ezt_getcpu.lo -MD -MP -MF submodules/$(DEPDIR)/libeztrace_la-ezt_getcpu.Tpo -c -o submodules/libeztrace_la-ezt_getcpu.lo `test -f 'submodules/ezt_getcpu.c' || echo '$(srcdir)/'`submodules/ezt_getcpu.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) submodules/$(DEPDIR)/libeztrace_la-ezt_getcpu.Tpo submodules/$(DEPDIR)/libeztrace_la-ezt_getcpu.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='submodules/ezt_getcpu.c' object='submodules/libeztrace_la-ezt_getcpu.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o submodules/libeztrace_la-ezt_getcpu.lo `test -f 'submodules/ezt_getcpu.c' || echo '$(srcdir)/'`submodules/ezt_getcpu.c eztrace-ezt_demangle.o: ezt_demangle.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT eztrace-ezt_demangle.o -MD -MP -MF $(DEPDIR)/eztrace-ezt_demangle.Tpo -c -o eztrace-ezt_demangle.o `test -f 'ezt_demangle.c' || echo '$(srcdir)/'`ezt_demangle.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/eztrace-ezt_demangle.Tpo $(DEPDIR)/eztrace-ezt_demangle.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ezt_demangle.c' object='eztrace-ezt_demangle.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o eztrace-ezt_demangle.o `test -f 'ezt_demangle.c' || echo '$(srcdir)/'`ezt_demangle.c eztrace-ezt_demangle.obj: ezt_demangle.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT eztrace-ezt_demangle.obj -MD -MP -MF $(DEPDIR)/eztrace-ezt_demangle.Tpo -c -o eztrace-ezt_demangle.obj `if test -f 'ezt_demangle.c'; then $(CYGPATH_W) 'ezt_demangle.c'; else $(CYGPATH_W) '$(srcdir)/ezt_demangle.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/eztrace-ezt_demangle.Tpo $(DEPDIR)/eztrace-ezt_demangle.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ezt_demangle.c' object='eztrace-ezt_demangle.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o eztrace-ezt_demangle.obj `if test -f 'ezt_demangle.c'; then $(CYGPATH_W) 'ezt_demangle.c'; else $(CYGPATH_W) '$(srcdir)/ezt_demangle.c'; fi` eztrace-eztrace.o: eztrace.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT eztrace-eztrace.o -MD -MP -MF $(DEPDIR)/eztrace-eztrace.Tpo -c -o eztrace-eztrace.o `test -f 'eztrace.c' || echo '$(srcdir)/'`eztrace.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/eztrace-eztrace.Tpo $(DEPDIR)/eztrace-eztrace.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace.c' object='eztrace-eztrace.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o eztrace-eztrace.o `test -f 'eztrace.c' || echo '$(srcdir)/'`eztrace.c eztrace-eztrace.obj: eztrace.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT eztrace-eztrace.obj -MD -MP -MF $(DEPDIR)/eztrace-eztrace.Tpo -c -o eztrace-eztrace.obj `if test -f 'eztrace.c'; then $(CYGPATH_W) 'eztrace.c'; else $(CYGPATH_W) '$(srcdir)/eztrace.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/eztrace-eztrace.Tpo $(DEPDIR)/eztrace-eztrace.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace.c' object='eztrace-eztrace.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o eztrace-eztrace.obj `if test -f 'eztrace.c'; then $(CYGPATH_W) 'eztrace.c'; else $(CYGPATH_W) '$(srcdir)/eztrace.c'; fi` ../pptrace/eztrace-pptrace.o: ../pptrace/pptrace.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-pptrace.o -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-pptrace.Tpo -c -o ../pptrace/eztrace-pptrace.o `test -f '../pptrace/pptrace.c' || echo '$(srcdir)/'`../pptrace/pptrace.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-pptrace.Tpo ../pptrace/$(DEPDIR)/eztrace-pptrace.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/pptrace.c' object='../pptrace/eztrace-pptrace.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-pptrace.o `test -f '../pptrace/pptrace.c' || echo '$(srcdir)/'`../pptrace/pptrace.c ../pptrace/eztrace-pptrace.obj: ../pptrace/pptrace.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-pptrace.obj -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-pptrace.Tpo -c -o ../pptrace/eztrace-pptrace.obj `if test -f '../pptrace/pptrace.c'; then $(CYGPATH_W) '../pptrace/pptrace.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/pptrace.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-pptrace.Tpo ../pptrace/$(DEPDIR)/eztrace-pptrace.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/pptrace.c' object='../pptrace/eztrace-pptrace.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-pptrace.obj `if test -f '../pptrace/pptrace.c'; then $(CYGPATH_W) '../pptrace/pptrace.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/pptrace.c'; fi` ../pptrace/eztrace-binary.o: ../pptrace/binary.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-binary.o -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-binary.Tpo -c -o ../pptrace/eztrace-binary.o `test -f '../pptrace/binary.c' || echo '$(srcdir)/'`../pptrace/binary.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-binary.Tpo ../pptrace/$(DEPDIR)/eztrace-binary.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/binary.c' object='../pptrace/eztrace-binary.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-binary.o `test -f '../pptrace/binary.c' || echo '$(srcdir)/'`../pptrace/binary.c ../pptrace/eztrace-binary.obj: ../pptrace/binary.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-binary.obj -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-binary.Tpo -c -o ../pptrace/eztrace-binary.obj `if test -f '../pptrace/binary.c'; then $(CYGPATH_W) '../pptrace/binary.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/binary.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-binary.Tpo ../pptrace/$(DEPDIR)/eztrace-binary.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/binary.c' object='../pptrace/eztrace-binary.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-binary.obj `if test -f '../pptrace/binary.c'; then $(CYGPATH_W) '../pptrace/binary.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/binary.c'; fi` ../pptrace/eztrace-errors.o: ../pptrace/errors.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-errors.o -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-errors.Tpo -c -o ../pptrace/eztrace-errors.o `test -f '../pptrace/errors.c' || echo '$(srcdir)/'`../pptrace/errors.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-errors.Tpo ../pptrace/$(DEPDIR)/eztrace-errors.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/errors.c' object='../pptrace/eztrace-errors.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-errors.o `test -f '../pptrace/errors.c' || echo '$(srcdir)/'`../pptrace/errors.c ../pptrace/eztrace-errors.obj: ../pptrace/errors.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-errors.obj -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-errors.Tpo -c -o ../pptrace/eztrace-errors.obj `if test -f '../pptrace/errors.c'; then $(CYGPATH_W) '../pptrace/errors.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/errors.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-errors.Tpo ../pptrace/$(DEPDIR)/eztrace-errors.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/errors.c' object='../pptrace/eztrace-errors.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-errors.obj `if test -f '../pptrace/errors.c'; then $(CYGPATH_W) '../pptrace/errors.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/errors.c'; fi` ../pptrace/eztrace-hijack.o: ../pptrace/hijack.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-hijack.o -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-hijack.Tpo -c -o ../pptrace/eztrace-hijack.o `test -f '../pptrace/hijack.c' || echo '$(srcdir)/'`../pptrace/hijack.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-hijack.Tpo ../pptrace/$(DEPDIR)/eztrace-hijack.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/hijack.c' object='../pptrace/eztrace-hijack.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-hijack.o `test -f '../pptrace/hijack.c' || echo '$(srcdir)/'`../pptrace/hijack.c ../pptrace/eztrace-hijack.obj: ../pptrace/hijack.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-hijack.obj -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-hijack.Tpo -c -o ../pptrace/eztrace-hijack.obj `if test -f '../pptrace/hijack.c'; then $(CYGPATH_W) '../pptrace/hijack.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/hijack.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-hijack.Tpo ../pptrace/$(DEPDIR)/eztrace-hijack.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/hijack.c' object='../pptrace/eztrace-hijack.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-hijack.obj `if test -f '../pptrace/hijack.c'; then $(CYGPATH_W) '../pptrace/hijack.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/hijack.c'; fi` ../pptrace/eztrace-isize.o: ../pptrace/isize.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-isize.o -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-isize.Tpo -c -o ../pptrace/eztrace-isize.o `test -f '../pptrace/isize.c' || echo '$(srcdir)/'`../pptrace/isize.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-isize.Tpo ../pptrace/$(DEPDIR)/eztrace-isize.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/isize.c' object='../pptrace/eztrace-isize.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-isize.o `test -f '../pptrace/isize.c' || echo '$(srcdir)/'`../pptrace/isize.c ../pptrace/eztrace-isize.obj: ../pptrace/isize.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-isize.obj -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-isize.Tpo -c -o ../pptrace/eztrace-isize.obj `if test -f '../pptrace/isize.c'; then $(CYGPATH_W) '../pptrace/isize.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/isize.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-isize.Tpo ../pptrace/$(DEPDIR)/eztrace-isize.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/isize.c' object='../pptrace/eztrace-isize.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-isize.obj `if test -f '../pptrace/isize.c'; then $(CYGPATH_W) '../pptrace/isize.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/isize.c'; fi` ../pptrace/eztrace-memory.o: ../pptrace/memory.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-memory.o -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-memory.Tpo -c -o ../pptrace/eztrace-memory.o `test -f '../pptrace/memory.c' || echo '$(srcdir)/'`../pptrace/memory.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-memory.Tpo ../pptrace/$(DEPDIR)/eztrace-memory.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/memory.c' object='../pptrace/eztrace-memory.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-memory.o `test -f '../pptrace/memory.c' || echo '$(srcdir)/'`../pptrace/memory.c ../pptrace/eztrace-memory.obj: ../pptrace/memory.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-memory.obj -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-memory.Tpo -c -o ../pptrace/eztrace-memory.obj `if test -f '../pptrace/memory.c'; then $(CYGPATH_W) '../pptrace/memory.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/memory.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-memory.Tpo ../pptrace/$(DEPDIR)/eztrace-memory.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/memory.c' object='../pptrace/eztrace-memory.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-memory.obj `if test -f '../pptrace/memory.c'; then $(CYGPATH_W) '../pptrace/memory.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/memory.c'; fi` ../pptrace/eztrace-opcodes.o: ../pptrace/opcodes.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-opcodes.o -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-opcodes.Tpo -c -o ../pptrace/eztrace-opcodes.o `test -f '../pptrace/opcodes.c' || echo '$(srcdir)/'`../pptrace/opcodes.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-opcodes.Tpo ../pptrace/$(DEPDIR)/eztrace-opcodes.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/opcodes.c' object='../pptrace/eztrace-opcodes.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-opcodes.o `test -f '../pptrace/opcodes.c' || echo '$(srcdir)/'`../pptrace/opcodes.c ../pptrace/eztrace-opcodes.obj: ../pptrace/opcodes.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-opcodes.obj -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-opcodes.Tpo -c -o ../pptrace/eztrace-opcodes.obj `if test -f '../pptrace/opcodes.c'; then $(CYGPATH_W) '../pptrace/opcodes.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/opcodes.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-opcodes.Tpo ../pptrace/$(DEPDIR)/eztrace-opcodes.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/opcodes.c' object='../pptrace/eztrace-opcodes.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-opcodes.obj `if test -f '../pptrace/opcodes.c'; then $(CYGPATH_W) '../pptrace/opcodes.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/opcodes.c'; fi` ../pptrace/eztrace-tracing.o: ../pptrace/tracing.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-tracing.o -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-tracing.Tpo -c -o ../pptrace/eztrace-tracing.o `test -f '../pptrace/tracing.c' || echo '$(srcdir)/'`../pptrace/tracing.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-tracing.Tpo ../pptrace/$(DEPDIR)/eztrace-tracing.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/tracing.c' object='../pptrace/eztrace-tracing.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-tracing.o `test -f '../pptrace/tracing.c' || echo '$(srcdir)/'`../pptrace/tracing.c ../pptrace/eztrace-tracing.obj: ../pptrace/tracing.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT ../pptrace/eztrace-tracing.obj -MD -MP -MF ../pptrace/$(DEPDIR)/eztrace-tracing.Tpo -c -o ../pptrace/eztrace-tracing.obj `if test -f '../pptrace/tracing.c'; then $(CYGPATH_W) '../pptrace/tracing.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/tracing.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) ../pptrace/$(DEPDIR)/eztrace-tracing.Tpo ../pptrace/$(DEPDIR)/eztrace-tracing.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='../pptrace/tracing.c' object='../pptrace/eztrace-tracing.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o ../pptrace/eztrace-tracing.obj `if test -f '../pptrace/tracing.c'; then $(CYGPATH_W) '../pptrace/tracing.c'; else $(CYGPATH_W) '$(srcdir)/../pptrace/tracing.c'; fi` eztrace_avail-eztrace_avail.o: eztrace_avail.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_avail_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT eztrace_avail-eztrace_avail.o -MD -MP -MF $(DEPDIR)/eztrace_avail-eztrace_avail.Tpo -c -o eztrace_avail-eztrace_avail.o `test -f 'eztrace_avail.c' || echo '$(srcdir)/'`eztrace_avail.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/eztrace_avail-eztrace_avail.Tpo $(DEPDIR)/eztrace_avail-eztrace_avail.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_avail.c' object='eztrace_avail-eztrace_avail.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_avail_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o eztrace_avail-eztrace_avail.o `test -f 'eztrace_avail.c' || echo '$(srcdir)/'`eztrace_avail.c eztrace_avail-eztrace_avail.obj: eztrace_avail.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_avail_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT eztrace_avail-eztrace_avail.obj -MD -MP -MF $(DEPDIR)/eztrace_avail-eztrace_avail.Tpo -c -o eztrace_avail-eztrace_avail.obj `if test -f 'eztrace_avail.c'; then $(CYGPATH_W) 'eztrace_avail.c'; else $(CYGPATH_W) '$(srcdir)/eztrace_avail.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/eztrace_avail-eztrace_avail.Tpo $(DEPDIR)/eztrace_avail-eztrace_avail.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_avail.c' object='eztrace_avail-eztrace_avail.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_avail_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o eztrace_avail-eztrace_avail.obj `if test -f 'eztrace_avail.c'; then $(CYGPATH_W) 'eztrace_avail.c'; else $(CYGPATH_W) '$(srcdir)/eztrace_avail.c'; fi` eztrace_convert-eztrace_convert.o: eztrace_convert.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_convert_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT eztrace_convert-eztrace_convert.o -MD -MP -MF $(DEPDIR)/eztrace_convert-eztrace_convert.Tpo -c -o eztrace_convert-eztrace_convert.o `test -f 'eztrace_convert.c' || echo '$(srcdir)/'`eztrace_convert.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/eztrace_convert-eztrace_convert.Tpo $(DEPDIR)/eztrace_convert-eztrace_convert.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert.c' object='eztrace_convert-eztrace_convert.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_convert_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o eztrace_convert-eztrace_convert.o `test -f 'eztrace_convert.c' || echo '$(srcdir)/'`eztrace_convert.c eztrace_convert-eztrace_convert.obj: eztrace_convert.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_convert_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT eztrace_convert-eztrace_convert.obj -MD -MP -MF $(DEPDIR)/eztrace_convert-eztrace_convert.Tpo -c -o eztrace_convert-eztrace_convert.obj `if test -f 'eztrace_convert.c'; then $(CYGPATH_W) 'eztrace_convert.c'; else $(CYGPATH_W) '$(srcdir)/eztrace_convert.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/eztrace_convert-eztrace_convert.Tpo $(DEPDIR)/eztrace_convert-eztrace_convert.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert.c' object='eztrace_convert-eztrace_convert.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_convert_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o eztrace_convert-eztrace_convert.obj `if test -f 'eztrace_convert.c'; then $(CYGPATH_W) 'eztrace_convert.c'; else $(CYGPATH_W) '$(srcdir)/eztrace_convert.c'; fi` eztrace_loaded-eztrace_loaded.o: eztrace_loaded.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_loaded_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT eztrace_loaded-eztrace_loaded.o -MD -MP -MF $(DEPDIR)/eztrace_loaded-eztrace_loaded.Tpo -c -o eztrace_loaded-eztrace_loaded.o `test -f 'eztrace_loaded.c' || echo '$(srcdir)/'`eztrace_loaded.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/eztrace_loaded-eztrace_loaded.Tpo $(DEPDIR)/eztrace_loaded-eztrace_loaded.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_loaded.c' object='eztrace_loaded-eztrace_loaded.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_loaded_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o eztrace_loaded-eztrace_loaded.o `test -f 'eztrace_loaded.c' || echo '$(srcdir)/'`eztrace_loaded.c eztrace_loaded-eztrace_loaded.obj: eztrace_loaded.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_loaded_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT eztrace_loaded-eztrace_loaded.obj -MD -MP -MF $(DEPDIR)/eztrace_loaded-eztrace_loaded.Tpo -c -o eztrace_loaded-eztrace_loaded.obj `if test -f 'eztrace_loaded.c'; then $(CYGPATH_W) 'eztrace_loaded.c'; else $(CYGPATH_W) '$(srcdir)/eztrace_loaded.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/eztrace_loaded-eztrace_loaded.Tpo $(DEPDIR)/eztrace_loaded-eztrace_loaded.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_loaded.c' object='eztrace_loaded-eztrace_loaded.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_loaded_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o eztrace_loaded-eztrace_loaded.obj `if test -f 'eztrace_loaded.c'; then $(CYGPATH_W) 'eztrace_loaded.c'; else $(CYGPATH_W) '$(srcdir)/eztrace_loaded.c'; fi` eztrace_stats-eztrace_stats.o: eztrace_stats.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_stats_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT eztrace_stats-eztrace_stats.o -MD -MP -MF $(DEPDIR)/eztrace_stats-eztrace_stats.Tpo -c -o eztrace_stats-eztrace_stats.o `test -f 'eztrace_stats.c' || echo '$(srcdir)/'`eztrace_stats.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/eztrace_stats-eztrace_stats.Tpo $(DEPDIR)/eztrace_stats-eztrace_stats.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_stats.c' object='eztrace_stats-eztrace_stats.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_stats_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o eztrace_stats-eztrace_stats.o `test -f 'eztrace_stats.c' || echo '$(srcdir)/'`eztrace_stats.c eztrace_stats-eztrace_stats.obj: eztrace_stats.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_stats_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT eztrace_stats-eztrace_stats.obj -MD -MP -MF $(DEPDIR)/eztrace_stats-eztrace_stats.Tpo -c -o eztrace_stats-eztrace_stats.obj `if test -f 'eztrace_stats.c'; then $(CYGPATH_W) 'eztrace_stats.c'; else $(CYGPATH_W) '$(srcdir)/eztrace_stats.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/eztrace_stats-eztrace_stats.Tpo $(DEPDIR)/eztrace_stats-eztrace_stats.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_stats.c' object='eztrace_stats-eztrace_stats.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(eztrace_stats_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o eztrace_stats-eztrace_stats.obj `if test -f 'eztrace_stats.c'; then $(CYGPATH_W) 'eztrace_stats.c'; else $(CYGPATH_W) '$(srcdir)/eztrace_stats.c'; fi` mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs -rm -rf submodules/.libs submodules/_libs install-inputDATA: $(input_DATA) @$(NORMAL_INSTALL) @list='$(input_DATA)'; test -n "$(inputdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(inputdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(inputdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(inputdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(inputdir)" || exit $$?; \ done uninstall-inputDATA: @$(NORMAL_UNINSTALL) @list='$(input_DATA)'; test -n "$(inputdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(inputdir)'; $(am__uninstall_files_from_dir) install-includeHEADERS: $(include_HEADERS) @$(NORMAL_INSTALL) @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(includedir)'"; \ $(MKDIR_P) "$(DESTDIR)$(includedir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_HEADER) $$files '$(DESTDIR)$(includedir)'"; \ $(INSTALL_HEADER) $$files "$(DESTDIR)$(includedir)" || exit $$?; \ done uninstall-includeHEADERS: @$(NORMAL_UNINSTALL) @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(includedir)'; $(am__uninstall_files_from_dir) ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am $(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS) check: check-am all-am: Makefile $(LTLIBRARIES) $(PROGRAMS) $(SCRIPTS) $(DATA) \ $(HEADERS) install-binPROGRAMS: install-libLTLIBRARIES installdirs: for dir in "$(DESTDIR)$(libdir)" "$(DESTDIR)$(bindir)" "$(DESTDIR)$(bindir)" "$(DESTDIR)$(inputdir)" "$(DESTDIR)$(includedir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: -test -z "$(CLEANFILES)" || rm -f $(CLEANFILES) distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) -rm -f ../pptrace/$(DEPDIR)/$(am__dirstamp) -rm -f ../pptrace/$(am__dirstamp) -rm -f submodules/$(DEPDIR)/$(am__dirstamp) -rm -f submodules/$(am__dirstamp) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-binPROGRAMS clean-checkPROGRAMS clean-generic \ clean-libLTLIBRARIES clean-libtool mostlyclean-am distclean: distclean-am -rm -rf ../pptrace/$(DEPDIR) ./$(DEPDIR) submodules/$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-includeHEADERS install-inputDATA install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-binPROGRAMS install-binSCRIPTS \ install-libLTLIBRARIES install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ../pptrace/$(DEPDIR) ./$(DEPDIR) submodules/$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-binPROGRAMS uninstall-binSCRIPTS \ uninstall-includeHEADERS uninstall-inputDATA \ uninstall-libLTLIBRARIES .MAKE: check-am install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ clean-binPROGRAMS clean-checkPROGRAMS clean-generic \ clean-libLTLIBRARIES clean-libtool cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-binPROGRAMS \ install-binSCRIPTS install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-includeHEADERS install-info \ install-info-am install-inputDATA install-libLTLIBRARIES \ install-man install-pdf install-pdf-am install-ps \ install-ps-am install-strip installcheck installcheck-am \ installdirs maintainer-clean maintainer-clean-generic \ mostlyclean mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf pdf-am ps ps-am tags tags-am uninstall \ uninstall-am uninstall-binPROGRAMS uninstall-binSCRIPTS \ uninstall-includeHEADERS uninstall-inputDATA \ uninstall-libLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/src/core/ev_codes.h000066400000000000000000000037161265506773700166570ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef __EV_CODES_H__ #define __EV_CODES_H__ #define NB_BITS 24 #define NB_BITS_PREFIX 8 #define NB_BITS_EVENTS (NB_BITS - NB_BITS_PREFIX) #define SYSTEM_MODULE_MASK (0<<(NB_BITS_PREFIX-1)) #define USER_MODULE_MASK (1<<(NB_BITS_PREFIX-1)) #define USER_MODULE_ID(id) (id | USER_MODULE_MASK) #define SYSTEM_MODULE_ID(id) (id | SYSTEM_MODULE_MASK) #define GENERATE_USER_MODULE_PREFIX(id) ((id) << NB_BITS_EVENTS) #define GENERATE_SYSTEM_MODULE_PREFIX(id) ((id) << NB_BITS_EVENTS) #define PTHREAD_CORE_EVENTS_ID 0x00 #define PTHREAD_CORE_PREFIX GENERATE_SYSTEM_MODULE_PREFIX(PTHREAD_CORE_EVENTS_ID) #define USER_CORE_EVENTS_ID 0x08 #define USER_CORE_PREFIX GENERATE_SYSTEM_MODULE_PREFIX(USER_CORE_EVENTS_ID) /* thread creation/destruction */ #define EZTRACE_NEW_THREAD (PTHREAD_CORE_PREFIX | 0x0001) #define EZTRACE_END_THREAD (PTHREAD_CORE_PREFIX | 0x0002) #define EZTRACE_START_THREAD_JOIN (PTHREAD_CORE_PREFIX | 0x0004) #define EZTRACE_STOP_THREAD_JOIN (PTHREAD_CORE_PREFIX | 0x0005) #define EZTRACE_START_THREAD_CREATE (PTHREAD_CORE_PREFIX | 0x0006) #define EZTRACE_STOP_THREAD_CREATE (PTHREAD_CORE_PREFIX | 0x0007) #define EZTRACE_SIGNAL_RECEIVED (PTHREAD_CORE_PREFIX | 0xf000) #define EZTRACE_CALLING_FUNCTION (PTHREAD_CORE_PREFIX | 0xf001) #define EZTRACE_START_FLUSH_CODE 0xfff5 #define EZTRACE_STOP_FLUSH_CODE 0xfff4 #define EZTRACE_ENTER_EVENT_RED (USER_CORE_PREFIX | 0x0008) #define EZTRACE_ENTER_EVENT_YELLOW (USER_CORE_PREFIX | 0x0010) #define EZTRACE_ENTER_EVENT_BLUE (USER_CORE_PREFIX | 0x0011) #define EZTRACE_ENTER_EVENT_PINK (USER_CORE_PREFIX | 0x0012) #define EZTRACE_ENTER_EVENT_GREEN (USER_CORE_PREFIX | 0x0013) #define EZTRACE_LEAVE_EVENT (USER_CORE_PREFIX | 0x0009) #endif /* __EV_CODES_H__ */ eztrace-1.1-2/src/core/ezt_demangle.c000066400000000000000000000015641265506773700175200ustar00rootroot00000000000000#include #include #if HAVE_DEMANGLE #include const char* ezt_demangle(const char* mangled_str) { /* todo: add an option to get only the function name */ /* get the full function prototype (including parameters and return type) */ char* res_str = cplus_demangle(mangled_str, DMGL_AUTO | DMGL_PARAMS); if(!res_str) { /* demangling failed. return the mangled string */ int len = strlen(mangled_str) + 1; res_str = malloc(sizeof(char*) * len); strncpy(res_str, mangled_str, len); } return res_str; } #else /* HAVE_DEMANGLE */ /* Libiberty is not available, return a copy of the mangled string */ const char* ezt_demangle(const char* mangled_str) { int len = strlen(mangled_str) + 1; char* res_str = malloc(sizeof(char*) * len); strncpy(res_str, mangled_str, len); return res_str; } #endif /* HAVE_DEMANGLE */ eztrace-1.1-2/src/core/ezt_demangle.h000066400000000000000000000002671265506773700175240ustar00rootroot00000000000000#ifndef EZT_DEMANGLE_H #define EZT_DEMANGLE_H /* demangle a string into a newly allocated buffer. */ const char* ezt_demangle(const char* mangled_str); #endif /* EZT_DEMANGLE_H */ eztrace-1.1-2/src/core/eztrace.c000066400000000000000000000164301265506773700165150ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include #include #include #include #include #include "pptrace.h" #include "eztrace.h" extern int pptrace_debug_level; void set_launcher_env() { setenv("TESTLAUNCHER", "1", 1); } void unset_launcher_env() { setenv("TESTLAUNCHER", "0", 1); } int file_exists(const char *pathname) { if (access(pathname, F_OK) != -1) { return 1; // file exists } return 0; } int str_ends_with(char *str, char *end) { size_t str_len = strlen(str); size_t end_len = strlen(end); char *str_end = str + str_len - end_len; return strcmp(str_end, end) == 0; } void usage(const char *prog_name) { printf("Usage: %s [OPTION] program [arg1 arg2 ...]\n", prog_name); printf("\t-t \"plugin1 plugin2 ... pluginN\" Select a list of plugins\n"); printf("\t-o Select the output directory\n"); printf("\t-l Select a plugin directory\n"); printf("\t-f Enable EZTRACE_FLUSH\n"); printf("\t-d Debug mode\n"); printf("\t-? -h Display this help and exit\n"); /* todo: add a verbose mode */ } static char* get_env_str(const char* env_name, const char* suffix) { char* tmp = getenv(env_name); int string_length = 1; char* res = NULL; if ((tmp == NULL || tmp[0] == '\0') && suffix == NULL) return NULL; if (tmp && !suffix) return strdup(tmp); if (!tmp && suffix) return strdup(suffix); string_length += strlen(tmp) + strlen(suffix); res = calloc(string_length, sizeof(char)); sprintf(res, "%s%s", tmp, suffix); return res; } /* add to_add to an already allocated string */ static char* add_to_str(char* dest_str, const char* to_add) { int len = strlen(dest_str) + strlen(to_add) + 1; dest_str = realloc(dest_str, len); strcat(dest_str, to_add); return dest_str; } int main(int argc, char **argv) { int debug = 0; int i, j = 0; int test = 0; char* libdir=NULL; char *ezt_library_path = NULL; int nb_opts = 0; // options char *prog_name = NULL; // prog_name void *bin = NULL; int nb_modules = 0; for (i = 1; i < argc; i++) { if (!strcmp(argv[i], "-d")) { debug = 1; nb_opts++; } else if (!strcmp(argv[i], "-p")) { test = 1; nb_opts++; } else if (!strcmp(argv[i], "-t")) { setenv("EZTRACE_TRACE", argv[i + 1], 1); i++; nb_opts += 2; } else if (!strcmp(argv[i], "-o")) { setenv("EZTRACE_TRACE_DIR", argv[i + 1], 1); i++; nb_opts += 2; } else if (!strcmp(argv[i], "-l")) { setenv("EZTRACE_LIBRARY_PATH", argv[i + 1], 1); i++; nb_opts += 2; } else if (!strcmp(argv[i], "-f")) { setenv("EZTRACE_FLUSH", "1", 1); nb_opts++; } else if (!strcmp(argv[i], "-?") || !strcmp(argv[i], "-h")) { usage(argv[0]); return EXIT_SUCCESS; } else if (argv[i][0] == '-' && argv[i][1] == 'v') { nb_opts++; for (j = 1; argv[i][j] == 'v'; j++) pptrace_debug_level++; } else { /* Unknown parameter name. It's probably the program name. We can stop * parsing the parameter list. */ break; } } // list of enabled module char *ezt_trace = get_env_str("EZTRACE_TRACE", ""); if(!test) { int len = strlen(EZTRACE_LIB_DIR); libdir=malloc(sizeof(char)*(len+2)); snprintf(libdir, len+2, ":%s", EZTRACE_LIB_DIR); } // user libs env variable ezt_library_path = get_env_str("EZTRACE_LIBRARY_PATH", libdir); prog_name = argv[nb_opts + 1]; if (prog_name == NULL) { usage(argv[0]); return EXIT_SUCCESS; } // init binary & catch all modules bin = pptrace_prepare_binary(prog_name); if (!bin) { fprintf(stderr, "Unable to load binary %s\n", prog_name); return EXIT_FAILURE; } // modules in ezt_trace if (ezt_trace != NULL) { char *module = strtok(ezt_trace, " "); while (module != NULL && ++nb_modules) module = strtok(NULL, " "); free(ezt_trace); } char *modules[nb_modules]; if (nb_modules != 0) { // we have to get EZTRACE_TRACE again because we strtok-ed it ezt_trace = get_env_str("EZTRACE_TRACE", ""); char *module = strtok(ezt_trace, " "); i = 0; while (module != NULL) { modules[i++] = module; module = strtok(NULL, " "); } } // dirs in ezt_library_path int nb_dirs = 0; if (ezt_library_path != NULL) { char *dir = strtok(ezt_library_path, ":"); while (dir != NULL && ++nb_dirs) dir = strtok(NULL, ":"); free(ezt_library_path); } char *dirs[nb_dirs]; if (nb_dirs != 0) { // we have to get EZTRACE_LIBRARY_PATH again because we strtok-ed it ezt_library_path = get_env_str("EZTRACE_LIBRARY_PATH",libdir); char *dir = strtok(ezt_library_path, ":"); i = 0; while (dir != NULL) { dirs[i++] = dir; dir = strtok(NULL, ":"); } } // libeztrace should always be preloaded! char *files = NULL; if (test) { fprintf(stderr, "Eztrace test Mode\n"); files = strdup(EZTRACE_ABS_TOP_BUILDDIR); files = add_to_str(files, "src/core/.libs/libeztrace-autostart.so"); } else { files = strdup(EZTRACE_LIB_DIR); files = add_to_str(files, "libeztrace-autostart.so"); } if (pptrace_add_preload(bin, files)) { fprintf(stderr, "Unable to add %s to LD_PRELOAD\n", files); return EXIT_FAILURE; } set_launcher_env(); if (ezt_trace != NULL) { for (i = 0; i < nb_modules; i++) { int module_found=0; for (j = 0; j < nb_dirs; j++) { char *pathname = strdup(dirs[j]); pathname = add_to_str(pathname, "/libeztrace-autostart-"); pathname = add_to_str(pathname, modules[i]); pathname = add_to_str(pathname, ".so"); if (file_exists(pathname)) { module_found=1; if (pptrace_load_module(bin, pathname)) { fprintf(stderr, "Unable to add %s to LD_PRELOAD\n", pathname); return EXIT_FAILURE; } files = add_to_str(files, ":"); files = add_to_str(files, pathname); } free(pathname); } if(!module_found) { fprintf(stderr,"[EZTrace] cannot find module %s\n", modules[i]); } } free(ezt_trace); } else { for (i = 0; i < nb_dirs; i++) { char *pathname = dirs[i]; struct dirent *dirent; DIR *d = opendir(pathname); while ((dirent = readdir(d))) { if (!strncmp(dirent->d_name, "libeztrace-autostart-", 21) && str_ends_with(dirent->d_name, ".so")) { char *file = strdup(pathname); file = add_to_str(file, "/"); file = add_to_str(file, dirent->d_name); if (pptrace_load_module(bin, file)) { fprintf(stderr, "Unable to add %s to LD_PRELOAD\n", file); return EXIT_FAILURE; } files = add_to_str(files, ":"); files = add_to_str(files, file); free(file); } } closedir(d); } } free(ezt_library_path); unset_launcher_env(); // run if (debug) { // TODO: make it configurable char *debugger[5]; debugger[0] = "gdb"; debugger[1] = "-quiet"; debugger[2] = "{name}"; debugger[3] = "{pid}"; debugger[4] = NULL; pptrace_add_debugger(bin, debugger); } if (pptrace_run(bin, argv + nb_opts + 1, environ)) { fprintf(stderr, "Unable to run the target\n"); return EXIT_FAILURE; } return EXIT_SUCCESS; } eztrace-1.1-2/src/core/eztrace.c.in000066400000000000000000000165211265506773700171230ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include #include #include #include #include #include "pptrace.h" #include "eztrace.h" extern int pptrace_debug_level; void set_launcher_env() { setenv("TESTLAUNCHER", "1", 1); } void unset_launcher_env() { setenv("TESTLAUNCHER", "0", 1); } int file_exists(const char *pathname) { if (access(pathname, F_OK) != -1) { return 1; // file exists } return 0; } int str_ends_with(char *str, char *end) { size_t str_len = strlen(str); size_t end_len = strlen(end); char *str_end = str + str_len - end_len; return strcmp(str_end, end) == 0; } void usage(const char *prog_name) { printf("Usage: %s [OPTION] program [arg1 arg2 ...]\n", prog_name); printf("\t-t \"plugin1 plugin2 ... pluginN\" Select a list of plugins\n"); printf("\t-o Select the output directory\n"); printf("\t-l Select a plugin directory\n"); printf("\t-f Enable EZTRACE_FLUSH\n"); printf("\t-d Debug mode\n"); printf("\t-? -h Display this help and exit\n"); /* todo: add a verbose mode */ } static char* get_env_str(const char* env_name, const char* suffix) { char* tmp = getenv(env_name); int string_length = 1; char* res = NULL; if ((tmp == NULL || tmp[0] == '\0') && suffix == NULL) return NULL; if (tmp && !suffix) return strdup(tmp); if (!tmp && suffix) return strdup(suffix); string_length += strlen(tmp) + strlen(suffix); res = calloc(string_length, sizeof(char)); sprintf(res, "%s%s", tmp, suffix); return res; } /* add to_add to an already allocated string */ static char* add_to_str(char* dest_str, const char* to_add) { int len = strlen(dest_str) + strlen(to_add) + 1; dest_str = realloc(dest_str, len); strcat(dest_str, to_add); return dest_str; } int main(int argc, char **argv) { int debug = 0; int i, j = 0; int test = 0; char* libdir=NULL; char *ezt_library_path = NULL; int nb_opts = 0; // options char *prog_name = NULL; // prog_name void *bin = NULL; int nb_modules = 0; for (i = 1; i < argc; i++) { if (!strcmp(argv[i], "-d")) { debug = 1; nb_opts++; } else if (!strcmp(argv[i], "-p")) { test = 1; nb_opts++; } else if (!strcmp(argv[i], "-t")) { setenv("EZTRACE_TRACE", argv[i + 1], 1); i++; nb_opts += 2; } else if (!strcmp(argv[i], "-o")) { setenv("EZTRACE_TRACE_DIR", argv[i + 1], 1); i++; nb_opts += 2; } else if (!strcmp(argv[i], "-l")) { setenv("EZTRACE_LIBRARY_PATH", argv[i + 1], 1); i++; nb_opts += 2; } else if (!strcmp(argv[i], "-f")) { setenv("EZTRACE_FLUSH", "1", 1); nb_opts++; } else if (!strcmp(argv[i], "-?") || !strcmp(argv[i], "-h")) { usage(argv[0]); return EXIT_SUCCESS; } else if (argv[i][0] == '-' && argv[i][1] == 'v') { nb_opts++; for (j = 1; argv[i][j] == 'v'; j++) pptrace_debug_level++; } else { /* Unknown parameter name. It's probably the program name. We can stop * parsing the parameter list. */ break; } } // list of enabled module char *ezt_trace = get_env_str("EZTRACE_TRACE", ""); if(!test) { int len = strlen(EZTRACE_LIB_DIR); libdir=malloc(sizeof(char)*(len+2)); snprintf(libdir, len+2, ":%s", EZTRACE_LIB_DIR); } // user libs env variable ezt_library_path = get_env_str("EZTRACE_LIBRARY_PATH", libdir); prog_name = argv[nb_opts + 1]; if (prog_name == NULL) { usage(argv[0]); return EXIT_SUCCESS; } // init binary & catch all modules bin = pptrace_prepare_binary(prog_name); if (!bin) { fprintf(stderr, "Unable to load binary %s\n", prog_name); return EXIT_FAILURE; } // modules in ezt_trace if (ezt_trace != NULL) { char *module = strtok(ezt_trace, " "); while (module != NULL && ++nb_modules) module = strtok(NULL, " "); free(ezt_trace); } char *modules[nb_modules]; if (nb_modules != 0) { // we have to get EZTRACE_TRACE again because we strtok-ed it ezt_trace = get_env_str("EZTRACE_TRACE", ""); char *module = strtok(ezt_trace, " "); i = 0; while (module != NULL) { modules[i++] = module; module = strtok(NULL, " "); } } // dirs in ezt_library_path int nb_dirs = 0; if (ezt_library_path != NULL) { char *dir = strtok(ezt_library_path, ":"); while (dir != NULL && ++nb_dirs) dir = strtok(NULL, ":"); free(ezt_library_path); } char *dirs[nb_dirs]; if (nb_dirs != 0) { // we have to get EZTRACE_LIBRARY_PATH again because we strtok-ed it ezt_library_path = get_env_str("EZTRACE_LIBRARY_PATH",libdir); char *dir = strtok(ezt_library_path, ":"); i = 0; while (dir != NULL) { dirs[i++] = dir; dir = strtok(NULL, ":"); } } // libeztrace should always be preloaded! char *files = NULL; if (test) { fprintf(stderr, "Eztrace test Mode\n"); files = strdup(EZTRACE_ABS_TOP_BUILDDIR); files = add_to_str(files, "src/core/.libs/libeztrace-autostart@DYNLIB_EXT@"); } else { files = strdup(EZTRACE_LIB_DIR); files = add_to_str(files, "libeztrace-autostart@DYNLIB_EXT@"); } if (pptrace_add_preload(bin, files)) { fprintf(stderr, "Unable to add %s to @LD_PRELOAD_NAME@\n", files); return EXIT_FAILURE; } set_launcher_env(); if (ezt_trace != NULL) { for (i = 0; i < nb_modules; i++) { int module_found=0; for (j = 0; j < nb_dirs; j++) { char *pathname = strdup(dirs[j]); pathname = add_to_str(pathname, "/libeztrace-autostart-"); pathname = add_to_str(pathname, modules[i]); pathname = add_to_str(pathname, "@DYNLIB_EXT@"); if (file_exists(pathname)) { module_found=1; if (pptrace_load_module(bin, pathname)) { fprintf(stderr, "Unable to add %s to @LD_PRELOAD_NAME@\n", pathname); return EXIT_FAILURE; } files = add_to_str(files, ":"); files = add_to_str(files, pathname); } free(pathname); } if(!module_found) { fprintf(stderr,"[EZTrace] cannot find module %s\n", modules[i]); } } free(ezt_trace); } else { for (i = 0; i < nb_dirs; i++) { char *pathname = dirs[i]; struct dirent *dirent; DIR *d = opendir(pathname); while ((dirent = readdir(d))) { if (!strncmp(dirent->d_name, "libeztrace-autostart-", 21) && str_ends_with(dirent->d_name, "@DYNLIB_EXT@")) { char *file = strdup(pathname); file = add_to_str(file, "/"); file = add_to_str(file, dirent->d_name); if (pptrace_load_module(bin, file)) { fprintf(stderr, "Unable to add %s to @LD_PRELOAD_NAME@\n", file); return EXIT_FAILURE; } files = add_to_str(files, ":"); files = add_to_str(files, file); free(file); } } closedir(d); } } free(ezt_library_path); unset_launcher_env(); // run if (debug) { // TODO: make it configurable char *debugger[5]; debugger[0] = "gdb"; debugger[1] = "-quiet"; debugger[2] = "{name}"; debugger[3] = "{pid}"; debugger[4] = NULL; pptrace_add_debugger(bin, debugger); } if (pptrace_run(bin, argv + nb_opts + 1, environ)) { fprintf(stderr, "Unable to run the target\n"); return EXIT_FAILURE; } return EXIT_SUCCESS; } eztrace-1.1-2/src/core/eztrace.h000066400000000000000000000200661265506773700165220ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef __EZTRACE_H__ #define __EZTRACE_H__ #ifndef _GNU_SOURCE #define _GNU_SOURCE #endif #include #include #include #include "eztrace_config.h" #include #include #include #ifdef USE_GETTID #include #include /* For SYS_xxx definitions */ #else #include #endif /* USE_GETTID */ #include "eztrace_types.h" #include "eztrace_sampling.h" #include "litl_types.h" #include "litl_write.h" #include "eztrace_litl.h" #include "eztrace_litl_packed.h" #define EZTRACE_API_VERSION 0x00000900 /* start the recording of events */ void eztrace_start(); /* stop recording events and write the trace to the disk */ void eztrace_stop(); /* start eztrace but only record some event (thread creation, mpi_init, mpi communicators creation..)*/ void eztrace_silent_start(); /* pre-defined color for manual instrumentation*/ enum ezt_color { EZTRACE_RED, EZTRACE_BLUE, EZTRACE_GREEN, EZTRACE_YELLOW, EZTRACE_PINK }; /* Stop the recording of events */ void eztrace_pause(); /* Restart the recording of events*/ void eztrace_resume(); /* Manually add one event and choose one color for the display */ void eztrace_enter_event(char *, enum ezt_color); /* Set the end of the event */ void eztrace_leave_event(); /* change the trace filename */ void eztrace_set_filename(char* name); void eztrace_code0(uint32_t code); void eztrace_code1(uint32_t code, uint64_t arg1); void eztrace_code2(uint32_t code, uint64_t arg1, uint64_t arg2); void eztrace_code3(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3); void eztrace_code4(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3, uint64_t arg4); void eztrace_code5(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3, uint64_t arg4, uint64_t arg5); void eztrace_code6(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3, uint64_t arg4, uint64_t arg5, uint64_t arg6); void eztrace_code7(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3, uint64_t arg4, uint64_t arg5, uint64_t arg6, uint64_t arg7); void eztrace_code8(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3, uint64_t arg4, uint64_t arg5, uint64_t arg6, uint64_t arg7, uint64_t arg8); void eztrace_code9(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3, uint64_t arg4, uint64_t arg5, uint64_t arg6, uint64_t arg7, uint64_t arg8, uint64_t arg9); typedef void (*eztrace_function_t)(void); /* register a callback to be called when the application calls * eztrace_start(). * This function is only usefull when AUTOSTART is disabled */ void eztrace_register_init_routine(eztrace_function_t init_func); typedef void (*eztrace_atexit_function_t)(void*); /* * register a function to be called before eztrace_stop. */ void eztrace_atexit(eztrace_atexit_function_t f, void* param); #define RECORD_HW_COUNTERS() \ { \ ezt_sampling_check_callbacks(); \ } enum ezt_trace_status { ezt_trace_status_uninitialized, ezt_trace_status_running, ezt_trace_status_paused, ezt_trace_status_stopped, ezt_trace_status_being_finalized, /* atexit functions are being called */ ezt_trace_status_finalized, /* event recording has stopped */ }; #define EZT_NB_MODULES_MAX 32 struct __ezt_write_trace { litl_write_trace_t *litl_trace; enum ezt_trace_status status; int debug_level; int buffer_size; char *filename; /* number of init functions to be called when the eztrace_start * is called. */ int nb_module; eztrace_function_t init_routines[EZT_NB_MODULES_MAX]; }; extern struct __ezt_write_trace __ezt_trace; #define EZT_PRINTF(_debug_level_, args...) { \ if(__ezt_trace.debug_level >= _debug_level_) \ fprintf(stderr, ##args); \ } #define FUNCTION_ENTRY \ { \ EZT_PRINTF(1, "Calling [%s]\n", __FUNCTION__); \ RECORD_HW_COUNTERS(); \ } /* current thread id */ #ifdef USE_GETTID #define CUR_TID syscall(SYS_gettid) #else #define CUR_TID pthread_self() #endif /* * Since litl_write_finalize_trace() from LiTL calls litl_write_probe_reg_0() and flush() that use fwrite as well as pthread_mutex_(un)lock, * litl_write_finalize_trace() needs to be protected in order to avoid being intercepted. */ #define EZTRACE_FIN_TRACE() \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ litl_write_finalize_trace(__ezt_trace.litl_trace); \ EZTRACE_PROTECT_OFF(); \ } \ } /* check whether dlsym returned successfully */ #define TREAT_ERROR() \ do { \ char * error; \ if ((error = dlerror()) != NULL) { \ fputs(error, stderr); \ abort(); \ } \ }while(0) /* intercept function func and store its previous value into var */ #define INTERCEPT(func, var) \ do { \ if(var) break; \ void *__handle = RTLD_NEXT; \ var = (typeof(var)) (uintptr_t) dlsym(__handle, func); \ TREAT_ERROR(); \ } while(0) /* return the offset of the field MEMBER in a structure TYPE */ #define ezt_offset_of(TYPE, MEMBER) ((size_t) &((TYPE *)0)->MEMBER) /* Find the global structure's address * It needs : * - ptr: address of intern field * - type: type of the global structure * - member: name of the intern field of the global structure */ #define ezt_container_of(ptr, type, member) \ ((type *)((char *)(__typeof__ (&((type *)0)->member))(ptr)- \ ezt_offset_of(type,member))) /* record an event (code=EZTRACE_CALLING_FUNCTION) with the calling function name */ void record_backtrace(); /* return 1 if an event is being recorded. */ int recursion_shield_on(); void set_recursion_shield_on(); void set_recursion_shield_off(); /* avoid infinite recursion */ #define EZTRACE_PROTECT if(! recursion_shield_on()) /* Set the recursion shield */ #define EZTRACE_PROTECT_ON() set_recursion_shield_on() #define EZTRACE_PROTECT_OFF() set_recursion_shield_off() /* pptrace stuff */ /* The PPTRACE_HIJACK_FUNCTION is an array that contain the list of functions that a module instrument * It is used by pptrace when insering probes in the binary as well as by eztrace.preload */ #define PPTRACE_INTERCEPT_FULL(function, repl, orig) #function " " #orig " " #repl, #define PPTRACE_INTERCEPT(function) #function " orig_" #function " " #function, #define PPTRACE_START_INTERCEPT(module_name) char* PPTRACE_SYMBOL_LIST(module_name) [] __attribute__((visibility("protected"))) = { #define PPTRACE_END_INTERCEPT(module_name) NULL }; extern char** PPTRACE_SYMBOL_EXTERNAL(module_name) __attribute__((alias(PPTRACE_SYMBOL_ALIAS(module_name)))); #define ezt_is_in_launcher() ((getenv("TESTLAUNCHER") != NULL) && (strcmp(getenv("TESTLAUNCHER"), "1") == 0)) /* check wether dlsym returned successfully */ #define DYNAMIC_INTERCEPTION(func, varName, var) \ do { \ var = (void**) dlsym(NULL, varName); \ if(NULL == var) { \ TREAT_ERROR(); \ } \ if(NULL != *var) break; \ *var = (void*) dlsym((void*)-1l, func); \ TREAT_ERROR(); \ } while(0) #define DYNAMIC_INTERCEPT_ALL_MODULE(module_name) \ do { \ if (ezt_is_in_launcher()) \ return; \ char __buff[1024]; \ int __i; char *__j; char *__k; void **__sym; \ for(__i = 0; PPTRACE_SYMBOL_LIST(module_name)[__i] != NULL; __i++) { \ strncpy(__buff, PPTRACE_SYMBOL_LIST(module_name)[__i], 1024); \ __buff[1023] = 0; \ __j = strchr(__buff, ' '); \ __k = strchr(__j+1, ' '); \ *__k = 0; *__j = 0; \ DYNAMIC_INTERCEPTION(__buff, (__j+1), __sym); \ *__k = *__j = ' '; \ } \ } while(0) #define START_INTERCEPT_MODULE(module_name) PPTRACE_START_INTERCEPT(module_name) #define END_INTERCEPT_MODULE(module_name) PPTRACE_END_INTERCEPT(module_name) #define DYNAMIC_INTERCEPT_ALL() DYNAMIC_INTERCEPT_ALL_MODULE() #define START_INTERCEPT START_INTERCEPT_MODULE() #define END_INTERCEPT END_INTERCEPT_MODULE() #define INTERCEPT2(func, var) func " " #var " " func, #endif /* __EZTRACE_H__ */ eztrace-1.1-2/src/core/eztrace.preload.in000077500000000000000000000060051265506773700203260ustar00rootroot00000000000000#!/bin/bash # Copyright © CNRS, INRIA, Université Bordeaux 1, Télécom SudParis # See COPYING in top-level directory. debug=n mpi=n show_env=n remove_new_file=no usage() { cat << EOF usage: $0 options OPTIONS: -? Show this message -t "plugin1 plugin2 ... pluginN" Select a list of plugins -o Select the output directory -l Select a plugin directory -f Enable EZTRACE_FLUSH -d Run EZtrace with gdb -e Show environment -p PadicoTM mode -m MPI mode EOF } while getopts 't:o:l:fbdmep' OPTION; do case $OPTION in d) debug=y ;; e) show_env=y ;; m) mpi=y ;; p) padico=y ;; t) modules=$OPTARG export EZTRACE_TRACE=$modules ;; o) output_path=$OPTARG export EZTRACE_TRACE_DIR=$output_path ;; l) eztrace_lib_path=$OPTARG export EZTRACE_LIBRARY_PATH=$eztrace_library_path ;; f) export EZTRACE_FLUSH=1 ;; ?) usage exit 2 ;; esac done # remove the options from the command line shift $(($OPTIND - 1)) prefix=@prefix@ exec_prefix=@exec_prefix@ libdir=@libdir@ bindir=@bindir@ # make sure eztrace libs are available export @LD_LIBRARY_PATH_NAME@=$@LD_LIBRARY_PATH_NAME@:$libdir prog_name=$1 shift new_prog_name=$prog_name # libeztrace should always be preloaded! files=${libdir}/libeztrace-autostart@DYNLIB_EXT@ EZTRACE_LIBRARY_PATH=${EZTRACE_LIBRARY_PATH}:${libdir}/ if [ "x$EZTRACE_TRACE" != x ]; then # only use the specified modules for module in $EZTRACE_TRACE do for dir in `echo $EZTRACE_LIBRARY_PATH |sed 's/:/ /g'` do if [ -f ${dir}/libeztrace-autostart-$module@DYNLIB_EXT@ ]; then files="$files:${dir}/libeztrace-autostart-$module@DYNLIB_EXT@" fi done done else # use all the available modules for dir in `echo $EZTRACE_LIBRARY_PATH |sed 's/:/ /g'` do for module in `ls $dir/libeztrace-autostart-*@DYNLIB_EXT@ 2>/dev/null` do files="$files:$module" done done fi if [ x$debug = xy ]; then # generate a gdbinit file that will preload all the modules gdbinit_file=`mktemp` echo "set env @LD_PRELOAD_NAME@ $files" > $gdbinit_file echo "set env @LD_LIBRARY_PATH_NAME@ $@LD_LIBRARY_PATH_NAME@" >> $gdbinit_file echo "echo \n" >> $gdbinit_file echo "echo EZTrace: hook loaded\n" >> $gdbinit_file gdb -x $gdbinit_file --args $new_prog_name $* rm $gdbinit_file elif [ x$show_env = xy ]; then remove_new_file=no echo env @LD_PRELOAD_NAME@=$files @LD_LIBRARY_PATH_NAME@=$@LD_LIBRARY_PATH_NAME@ $new_prog_name $* elif [ x$mpi = xy ]; then remove_new_file=no echo env @LD_PRELOAD_NAME@ $files @LD_LIBRARY_PATH_NAME@ $@LD_LIBRARY_PATH_NAME@ $new_prog_name $* elif [ x$padico = xy ]; then remove_new_file=no echo $files $new_prog_name $* else @LD_PRELOAD_NAME@=$files $new_prog_name $* fi if [ "x$remove_new_file" = "xyes" ]; then echo "removing $new_prog_name" rm $new_prog_name fi eztrace-1.1-2/src/core/eztrace_array.c000066400000000000000000000025261265506773700177140ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (c) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #include #include #include #include "eztrace_array.h" #define DEFAULT_PREALLOC 64 /* initialize an array */ void eztrace_array_create(struct eztrace_array_t* p_array, unsigned item_size, unsigned nb_prealloc) { p_array->item_size = item_size; p_array->nb_items = 0; p_array->values = malloc(item_size * nb_prealloc); p_array->nb_allocated = nb_prealloc; } /* free an array */ void eztrace_array_free(struct eztrace_array_t* p_array) { assert(p_array); free(p_array->values); } /* return a new item of an array (for a specific container) */ void* eztrace_array_new_value(struct eztrace_array_t* p_array) { assert(p_array); if (p_array->nb_items >= p_array->nb_allocated) { /* expand the buffer */ p_array->nb_allocated *= 2; if (!p_array->nb_allocated) p_array->nb_allocated = DEFAULT_PREALLOC; void * ptr = realloc(p_array->values, p_array->item_size * p_array->nb_allocated); if(!ptr) { fprintf(stderr, "In %s: cannot allocate enough memory. Aborting.\n", __FUNCTION__); abort(); } p_array->values = ptr; } p_array->nb_items++; return ITH_VALUE(p_array->nb_items - 1, p_array) ; } eztrace-1.1-2/src/core/eztrace_array.h000066400000000000000000000015461265506773700177220ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_ARRAY_H #define EZTRACE_ARRAY_H #include struct eztrace_array_t { unsigned item_size; unsigned nb_items; void* values; unsigned nb_allocated; }; /* return the ith value of an array */ #define ITH_VALUE(__i__, __array__) (void*)(((__array__)->values) + ((__i__)*(__array__)->item_size)) /* initialize an array */ void eztrace_array_create(struct eztrace_array_t* p_array, unsigned item_size, unsigned nb_prealloc); /* free an array */ void eztrace_array_free(struct eztrace_array_t* p_array); /* return a new item of an array (for a specific container) */ void* eztrace_array_new_value(struct eztrace_array_t* p_array); #endif /* EZTRACE_ARRAY_H */ eztrace-1.1-2/src/core/eztrace_avail.c000066400000000000000000000017541265506773700176740ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #include #include #include #include "eztrace_convert_core.h" /* This program list the available modules */ static void usage(int argc __attribute__((unused)), char **argv) { fprintf(stderr, "Usage : %s -h \n", argv[0]); } static void parse_args(int argc, char **argv) { int i; for (i = 1; i < argc; i++) { if (strcmp(argv[i], "-h") == 0) { usage(argc, argv); exit(-1); } else if (strcmp(argv[i], "-v") == 0) { printf("Verbose mode turned on\n"); (*get_verbose()) = 1; } } } int main(int argc, char**argv) { /* clear the EZTRACE_TRACE environment variable so that all the available modules are listed */ unsetenv("EZTRACE_TRACE"); /* parse the arguments passed to this program */ parse_args(argc, argv); load_modules(0); eztrace_convert_list(); return 0; } eztrace-1.1-2/src/core/eztrace_config.h000066400000000000000000000066261265506773700200550ustar00rootroot00000000000000/* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * config.h -- Configuration parameters * * Created on: 02 juil. 2011 * Author: Damien Martin-Guillerez * */ #ifndef PPTRACE_CONFIG_H_ #define PPTRACE_CONFIG_H_ #include #include #define PPTRACE_DEBUG_LEVEL_NONE 0 #define PPTRACE_DEBUG_LEVEL_INFO 1 #define PPTRACE_DEBUG_LEVEL_VERBOSE 2 #define PPTRACE_DEBUG_LEVEL_DEBUG 3 #define PPTRACE_DEBUG_LEVEL_ALL 4 #define PPTRACE_BINARY_TYPE_BFD 1 // Requires -lbfd #define PPTRACE_BINARY_TYPE_ELF 2 // Requires -lelf #define PPTRACE_ARCH_TYPE_INTEL 1 // What else? #define PTRACE_TRACE_TYPE_LINUX 1 #define PTRACE_TRACE_TYPE_MACOSX 2 // Not Yet Implemented #define PTRACE_TRACE_TYPE_BSD 3 // Not Yet Implemented #define PPTRACE_ISIZE_TYPE_TRACE 1 #define PPTRACE_ISIZE_TYPE_OPCODE 2 // Requires -lopcodes and binary type bfd // Configuration // Syscall dependency #ifndef __PPTRACE_DEBUG_LEVEL #define __PPTRACE_DEBUG_LEVEL 0 #endif // defined __PPTRACE_DEBUG_LEVEL #ifndef __PPTRACE_BINARY_TYPE #define __PPTRACE_BINARY_TYPE 1 #endif // defined __PPTRACE_BINARY_TYPE #define HAVE_LIBOPCODE 1 #define DYNLIB_SUFFIX ".so" #define HAVE_PRCTL_H 1 #ifndef __PPTRACE_USE_PRCTL #if HAVE_PRCTL_H // This flag is set to use prctl for ptrace to allow child to trace its parent on hardened systems // Set it if prtcl.h, the prtcl() function and the PR_SET_PTRACER constant exists #define __PPTRACE_USE_PRCTL #endif /* HAVE_PRCTL_H */ #endif // defined __PPTRACE_USE_PRCTL #ifndef __PPTRACE_ARCH_TYPE #define __PPTRACE_ARCH_TYPE PPTRACE_ARCH_TYPE_INTEL #endif // defined __PPTRACE_ARCH_TYPE #ifndef __PPTRACE_TRACE_TYPE #define __PPTRACE_TRACE_TYPE PTRACE_TRACE_TYPE_LINUX #endif // defined __PPTRACE_TRACE_TYPE #ifndef __PPTRACE_ISIZE_TYPE #define __PPTRACE_ISIZE_TYPE PPTRACE_ISIZE_TYPE_TRACE #endif // defined __PPTRACE_ISIZE_TYPE #if (__PPTRACE_ISIZE_TYPE == PPTRACE_ISIZE_TYPE_OPCODE) && (__PPTRACE_BINARY_TYPE != PPTRACE_BINARY_TYPE_BFD) #undef __PPTRACE_ISIZE_TYPE #define __PPTRACE_ISIZE_TYPE PPTRACE_ISIZE_TYPE_TRACE #endif // (__PPTRACE_ISIZE_TYPE == PPTRACE_ISIZE_TYPE_OPCODE) && (__PPTRACE_BINARY_TYPE != PPTRACE_BINARY_TYPE_BFD) // Obscure internal structures #define PPTRACE_HIJACK_FUNCTION pptrace_hijack_list #define CONC(a,b) a##b #define CONCAT(a, b) CONC(a, b) #define STRINGIFY2(a) # a #define STRINGIFY(a) STRINGIFY2(a) #define PPTRACE_BASENAME PPTRACE_HIJACK_FUNCTION #define PPTRACE_SYMBOL_LIST(module_name) CONCAT(PPTRACE_BASENAME , _ ## module_name) #define PPTRACE_SYMBOL_ALIAS(module_name) STRINGIFY(PPTRACE_SYMBOL_LIST(module_name)) #define PPTRACE_SYMBOL_EXTERNAL(module_name) CONCAT(__ , PPTRACE_SYMBOL_LIST(module_name)) __attribute__ ((unused)) static void __get_pptrace_symbol_external(char*dest, unsigned buffer_size, const char*module_name); /* copy the pptrace external symbol string corresponding to module_name in buffer dest */ __attribute__ ((unused)) static void __get_pptrace_symbol_external(char*dest, unsigned buffer_size, const char*module_name) { char* prefix = STRINGIFY(PPTRACE_SYMBOL_EXTERNAL()); if(buffer_size>strlen(prefix)+strlen(module_name)) { sprintf(dest, "%s%s", prefix, module_name); } else { /* not enough space in the buffer */ dest[0]='\0'; } } #endif /* PPTRACE_CONFIG_H_ */ eztrace-1.1-2/src/core/eztrace_config.h.in000066400000000000000000000067171265506773700204630ustar00rootroot00000000000000/* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * config.h -- Configuration parameters * * Created on: 02 juil. 2011 * Author: Damien Martin-Guillerez * */ #ifndef PPTRACE_CONFIG_H_ #define PPTRACE_CONFIG_H_ #include #include #define PPTRACE_DEBUG_LEVEL_NONE 0 #define PPTRACE_DEBUG_LEVEL_INFO 1 #define PPTRACE_DEBUG_LEVEL_VERBOSE 2 #define PPTRACE_DEBUG_LEVEL_DEBUG 3 #define PPTRACE_DEBUG_LEVEL_ALL 4 #define PPTRACE_BINARY_TYPE_BFD 1 // Requires -lbfd #define PPTRACE_BINARY_TYPE_ELF 2 // Requires -lelf #define PPTRACE_ARCH_TYPE_INTEL 1 // What else? #define PTRACE_TRACE_TYPE_LINUX 1 #define PTRACE_TRACE_TYPE_MACOSX 2 // Not Yet Implemented #define PTRACE_TRACE_TYPE_BSD 3 // Not Yet Implemented #define PPTRACE_ISIZE_TYPE_TRACE 1 #define PPTRACE_ISIZE_TYPE_OPCODE 2 // Requires -lopcodes and binary type bfd // Configuration // Syscall dependency #ifndef __PPTRACE_DEBUG_LEVEL #define __PPTRACE_DEBUG_LEVEL 0 #endif // defined __PPTRACE_DEBUG_LEVEL #ifndef __PPTRACE_BINARY_TYPE #define __PPTRACE_BINARY_TYPE @PPTRACE_BINARY_TYPE@ #endif // defined __PPTRACE_BINARY_TYPE #define HAVE_LIBOPCODE @HAVE_LIBOPCODE@ #define DYNLIB_SUFFIX "@DYNLIB_EXT@" #define HAVE_PRCTL_H @HAVE_PRCTL_H@ #ifndef __PPTRACE_USE_PRCTL #if HAVE_PRCTL_H // This flag is set to use prctl for ptrace to allow child to trace its parent on hardened systems // Set it if prtcl.h, the prtcl() function and the PR_SET_PTRACER constant exists #define __PPTRACE_USE_PRCTL #endif /* HAVE_PRCTL_H */ #endif // defined __PPTRACE_USE_PRCTL #ifndef __PPTRACE_ARCH_TYPE #define __PPTRACE_ARCH_TYPE PPTRACE_ARCH_TYPE_INTEL #endif // defined __PPTRACE_ARCH_TYPE #ifndef __PPTRACE_TRACE_TYPE #define __PPTRACE_TRACE_TYPE PTRACE_TRACE_TYPE_LINUX #endif // defined __PPTRACE_TRACE_TYPE #ifndef __PPTRACE_ISIZE_TYPE #define __PPTRACE_ISIZE_TYPE PPTRACE_ISIZE_TYPE_TRACE #endif // defined __PPTRACE_ISIZE_TYPE #if (__PPTRACE_ISIZE_TYPE == PPTRACE_ISIZE_TYPE_OPCODE) && (__PPTRACE_BINARY_TYPE != PPTRACE_BINARY_TYPE_BFD) #undef __PPTRACE_ISIZE_TYPE #define __PPTRACE_ISIZE_TYPE PPTRACE_ISIZE_TYPE_TRACE #endif // (__PPTRACE_ISIZE_TYPE == PPTRACE_ISIZE_TYPE_OPCODE) && (__PPTRACE_BINARY_TYPE != PPTRACE_BINARY_TYPE_BFD) // Obscure internal structures #define PPTRACE_HIJACK_FUNCTION pptrace_hijack_list #define CONC(a,b) a##b #define CONCAT(a, b) CONC(a, b) #define STRINGIFY2(a) # a #define STRINGIFY(a) STRINGIFY2(a) #define PPTRACE_BASENAME PPTRACE_HIJACK_FUNCTION #define PPTRACE_SYMBOL_LIST(module_name) CONCAT(PPTRACE_BASENAME , _ ## module_name) #define PPTRACE_SYMBOL_ALIAS(module_name) STRINGIFY(PPTRACE_SYMBOL_LIST(module_name)) #define PPTRACE_SYMBOL_EXTERNAL(module_name) CONCAT(__ , PPTRACE_SYMBOL_LIST(module_name)) __attribute__ ((unused)) static void __get_pptrace_symbol_external(char*dest, unsigned buffer_size, const char*module_name); /* copy the pptrace external symbol string corresponding to module_name in buffer dest */ __attribute__ ((unused)) static void __get_pptrace_symbol_external(char*dest, unsigned buffer_size, const char*module_name) { char* prefix = STRINGIFY(PPTRACE_SYMBOL_EXTERNAL()); if(buffer_size>strlen(prefix)+strlen(module_name)) { sprintf(dest, "%s%s", prefix, module_name); } else { /* not enough space in the buffer */ dest[0]='\0'; } } #endif /* PPTRACE_CONFIG_H_ */ eztrace-1.1-2/src/core/eztrace_convert.c000066400000000000000000000124621265506773700202560ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include "ev_codes.h" #include "eztrace_list.h" #include "eztrace_convert.h" #include "eztrace_convert_core.h" #include "eztrace_hook.h" #include "GTG.h" /* name of the output file */ static char *output_filename = "eztrace_output"; static struct eztrace_archive_info *arch_info = NULL, *arch_info_head = NULL; static void usage(int argc __attribute__((unused)), char **argv) { fprintf( stderr, "Usage : %s [-v] [-t PAJE|OTF] [-z] [-o output_filename] input_filename input_filename ... \n", argv[0]); } int compress = 0; static void parse_args(int argc, char **argv) { int i; litl_size_t j; litl_read_trace_t* arch; struct eztrace_archive_info *tmp; for (i = 1; i < argc; i++) { if (strcmp(argv[i], "-o") == 0) output_filename = argv[++i]; else if (strcmp(argv[i], "-v") == 0) VERBOSE = 1; else if (strcmp(argv[i], "-z") == 0) compress = 1; else if (strcmp(argv[i], "-t") == 0) { char* trace_type = argv[++i]; if (strcmp(trace_type, "PAJE") == 0) { printf("Setting trace type to PAJE\n"); setTraceType(PAJE); } else if (strcmp(trace_type, "OTF") == 0) { printf("Setting trace type to OTF\n"); setTraceType(OTF); } else { fprintf(stderr, "Unknown trace type: '%s'\n", trace_type); exit(-1); } } else if (strcmp(argv[i], "-h") == 0) { usage(argc, argv); exit(-1); } else if (argv[i][0] == '-') { fprintf(stderr, "Unknown option %s\n", argv[i]); usage(argc, argv); exit(-1); } else { // count the number of traces including those in archives // open the trace file. Do this here to deal with archives of traces arch = litl_read_open_trace(argv[i]); if (!arch) { perror("litl_read_open_trace:"); exit(-1); } tmp = (struct eztrace_archive_info *) malloc(sizeof(struct eztrace_archive_info)); tmp->block = arch; tmp->filename = argv[i]; tmp->next = NULL; if (arch_info == NULL ) { arch_info = tmp; arch_info_head = arch_info; } else { arch_info->next = tmp; arch_info = arch_info->next; } NB_TRACES += tmp->block->nb_processes; } } if (NB_TRACES < 1) { usage(argc, argv); exit(-1); } // create and initialize traces j = 0; arch_info = arch_info_head; eztrace_convert_init(NB_TRACES); while (arch_info != NULL ) { tmp = arch_info; arch_info = arch_info->next; arch = tmp->block; // init traces for (i = 0; i < tmp->block->nb_processes; i++) { get_traces(i + j)->input_filename = tmp->filename; get_traces(i + j)->block = tmp->block; get_traces(i + j)->trace_index = i; } litl_read_init_processes(arch); j += tmp->block->nb_processes; } } static void __clean_up() { while (arch_info_head != NULL) { arch_info = arch_info_head; arch_info_head = arch_info_head->next; free(arch_info); } } /* * This program should be used to parse the log file generated by LiTL */ int main(int argc, char **argv) { int ret; load_modules(1); setTraceType(PAJE); /* parse the arguments passed to this program */ parse_args(argc, argv); #ifdef GTG_OUT_OF_ORDER ret = initTrace(output_filename, 0, GTG_FLAG_OUTOFORDER); #else ret = initTrace(output_filename, 0, GTG_FLAG_NONE); #endif if (ret != TRACE_SUCCESS) { fprintf(stderr, "fail to initialize GTG\n"); return 1; } if (compress) if (setCompress(9) != TRACE_SUCCESS) fprintf(stderr, "Fail to enable trace compression\n"); eztrace_initialize_gtg(); __init_modules(); int i; /* initialize the traces array */ for (i = 0; i < NB_TRACES; i++) { /* open the trace file */ struct trace_t* cur_trace = get_traces(i); cur_trace->delay = 0; cur_trace->rank = i; cur_trace->id = i; cur_trace->done = 0; cur_trace->skip = 0; cur_trace->line_number = 0; eztrace_create_containers(i); /* if several traces are loaded, this means that MPI was used, * so let's skip all the first events until MPI_Init is detected */ if (NB_TRACES > 1) { cur_trace->start = 0; cur_trace->trace_id = NULL; } else { CREATE_TRACE_ID_STR(cur_trace->trace_id, 0); cur_trace->start = 1; NB_START = 1; addContainer(0.00000, cur_trace->trace_id, "CT_Process", "C_Prog", cur_trace->trace_id, "0"); eztrace_create_ids(cur_trace->rank); } ezt_litl_read_next_event(cur_trace); if (!cur_trace->ev.event) { fprintf(stderr, "no more block ...\n"); break; } cur_trace->start_time = LITL_READ_GET_TIME(&cur_trace->ev); } set_cur_trace(get_traces(0)); set_cur_ev(&get_traces(0)->ev); struct eztrace_event_handler* h_info = NULL; h_info = get_handler_info(); h_info->cur_trace_nb = 0; h_info->nb_done = 0; h_info->nb_handled = 0; sem_init(&h_info->events_processed, 0, 0); /* create the handler thread and wait until it completes */ create_main_thread(); wake_up_handler_thread(); sem_wait(&h_info->events_processed); /* finalize the trace and close the file */ endTrace(); eztrace_convert_finalize(); printf("%d events handled\n", h_info->nb_handled); __clean_up(); return 0; } eztrace-1.1-2/src/core/eztrace_convert.h000066400000000000000000000033521265506773700202610ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_CONVERT_H #define EZTRACE_CONVERT_H #define _GNU_SOURCE #include #include #include #include #include #include #include #include #include #include "eztrace_convert_types.h" #include "eztrace_convert_core.h" #include "eztrace_convert_macros.h" /* register a plugin to eztrace_convert */ void eztrace_convert_register_module(struct eztrace_convert_module *p_module); /* Find the next event to be handled in a trace * Return 0 if there is no more event in this trace, or 1 otherwise */ int next_ev(int cur_trace_num); /* add the current thread to the output trace and initialize * all the corresponding structures. */ void new_thread(unsigned int tid); /* retrieve a container that corresponds to a thread id */ static inline struct eztrace_container_t * get_thread_cont_from_id( int trace_id, int thread_id) { struct eztrace_container_t * cont = (&(get_traces(trace_id)->root_container)); unsigned i; for (i = 0; i < cont->nb_children; i++) { struct eztrace_container_t * child_cont = cont->children[i]; struct thread_info_t *ret = (struct thread_info_t *) child_cont->container_info; if (ret->tid == thread_id) return child_cont; } return NULL; } /* if the verbose option is set (when eztrace_convert is invoked) * this prints the name of the current function */ static inline void __func_name(int id, float time, const char* function) { if (VERBOSE) fprintf(stderr, "[%d] [%f] \t%s\n", id, time, function); } #endif /* EZTRACE_CONVERT_H */ eztrace-1.1-2/src/core/eztrace_convert_core.c000066400000000000000000001076241265506773700212730ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _SVID_SOURCE #define _GNU_SOURCE #include #include #include #include #include #include "eztrace_convert.h" #include "eztrace_convert_core.h" #include "eztrace_stats_core.h" #include "eztrace_convert_types.h" #include "ev_codes.h" #include "eztrace_hierarchical_array.h" #include "submodules/ezt_submodule.h" eztrace_event_t ev; /* a thread just processed the current event, let's handl ethe next one */ sem_t job_processed; /* set to 1 if verbose */ int verbose = 0; /* debug level */ int __ezt_debug_level = 0; /* number of traces currently loaded */ int nb_traces = 0; /* number of traces currently started (i.e. that have reached MPI_Init) */ int nb_start = 0; /* array that contains the loaded traces */ struct trace_t *traces = NULL; /* pointer to the trace being processed */ struct trace_t *cur_trace = NULL; /* pointer to the event being processed */ eztrace_event_t *cur_ev = NULL; struct eztrace_event_handler __handler_info; pthread_t *main_thread; sem_t main_thread_sem; static enum eztrace_mode __cur_mode = EZTRACE_CONVERT; struct pthread_core_thread_info_t { double time_join; double time_create; double last_event; struct thread_info_t *p_thread; }; /* add a hook in the process structure in order to store information * about pending parallel sections */ static struct pthread_core_thread_info_t *__register_process_hook(struct thread_info_t *p_thread) { struct pthread_core_thread_info_t *c_info = (struct pthread_core_thread_info_t*) malloc(sizeof(struct pthread_core_thread_info_t)); c_info->p_thread = p_thread; c_info->time_join = 0; c_info->time_create= 0; c_info->last_event = 0; /* add the hook in the thread info structure */ ezt_hook_list_add(&c_info->p_thread->hooks, c_info, (uint8_t)PTHREAD_CORE_EVENTS_ID); return c_info; } /* declare a var variable that points to the process_info structure */ #define INIT_PTHREAD_CORE_THREAD_INFO(p_thread, var) \ struct pthread_core_thread_info_t *var = (struct pthread_core_thread_info_t*) \ ezt_hook_list_retrieve_data(&p_thread->hooks, (uint8_t)PTHREAD_CORE_EVENTS_ID); \ if(!(var)) { \ var = __register_process_hook(p_thread); \ } void eztrace_convert_init(unsigned __nb_traces) { if (traces) /* already initialized */ return; traces = malloc(sizeof(struct trace_t) * __nb_traces); char* ezt_debug=getenv("EZTRACE_DEBUG"); if(ezt_debug) { __ezt_debug_level = atoi(ezt_debug); printf("Debug mode set to %d\n", __ezt_debug_level); } } void eztrace_initialize_gtg() { /* the thread is waiting for something (sem_P, mutex_lock, etc.) */ addContType("CT_Program", NULL, "Program"); addContType("CT_Process", "CT_Program", "Process"); addContType("CT_Thread", "CT_Process", "Thread"); addStateType("ST_Program", "CT_Program", "Program state"); addStateType("ST_Process", "CT_Process", "Process state"); addStateType("ST_Thread", "CT_Thread", "Thread state"); addStateType("ST_User", "CT_Thread", "User state"); /* the thread is blocked */ addEntityValue("STV_FLUSH", "ST_Thread", "EZTrace Flush", GTG_WHITE); /* the thread is blocked */ addEntityValue("STV_Blocked", "ST_Thread", "Blocked", GTG_RED); /* the thread is computing */ addEntityValue("STV_Working", "ST_Thread", "Working", GTG_BLUE); /* the thread is within a critical section (mutex, spinlock, ...) */ addEntityValue("STV_Critical", "ST_Thread", "Critical Section", GTG_GREEN); addEntityValue("STV_User_Event_Green", "ST_User", "User Event", GTG_GREEN); addEntityValue("STV_User_Event_Red", "ST_User", "User Event", GTG_RED); addEntityValue("STV_User_Event_Blue", "ST_User", "User Event", GTG_SEABLUE); addEntityValue("STV_User_Event_Yellow", "ST_User", "User Event", GTG_YELLOW); addEntityValue("STV_User_Event_Pink", "ST_User", "User Event", GTG_PINK); addEntityValue("STV_EZTRACE_SYNC", "ST_Thread", "EZTrace synchronization", GTG_WHITE); addEventType("E_UserEvent", "CT_Thread", "User Event"); addEventType("E_SigSegv", "CT_Thread", "SIGNAL Received"); addContainer(0.00000, "C_Prog", "CT_Program", NULL, "Program", "0"); ezt_submodule_convert_init(); } struct eztrace_event_handler* get_handler_info() { return &__handler_info; } /* call printf if verbose mode is turned on */ #define DPRINTF(...) \ { \ if(verbose) \ printf(__VA_ARGS__); \ } /* set to 1 if the current trace should be skipped next time. * It is mostly useful when a trace starts with a delay (because * of MPI_Comm_spawn for example) */ int skip; int* get_verbose() { return &verbose; } int* get_nb_traces() { return &nb_traces; } int* get_nb_start() { return &nb_start; } struct trace_t* get_traces(int index) { return &traces[index]; } struct trace_t* get_cur_trace() { return cur_trace; } void set_cur_trace(struct trace_t* p_trace) { cur_trace = p_trace; } eztrace_event_t *get_cur_ev() { return cur_ev; } void set_cur_ev(eztrace_event_t * p_ev) { cur_ev = p_ev; } int* get_skip() { return &skip; } void ezt_litl_read_next_event(struct trace_t*p_trace) { litl_read_event_t *p_ev = litl_read_next_event(p_trace->block); if(p_ev) { memcpy(&p_trace->ev, p_ev, sizeof(litl_read_event_t)); p_trace->line_number++; } else { memset(&p_trace->ev, 0, sizeof(litl_read_event_t)); } } /* Find the next event to be handled in a trace * Return 0 if there is no more event in this trace, or 1 otherwise */ int next_ev(int cur_trace_num) { double cur_time = NS_TO_MS(CUR_TIME(cur_trace_num)); ezt_litl_read_next_event(&traces[cur_trace_num]); if (!traces[cur_trace_num].ev.event) { traces[cur_trace_num].done = 1; fprintf(stderr, "no more block for trace #%d\n", cur_trace_num); return 0; } return 1; } /* Find the next trace event to handle * return the trace id that correspond to the trace to be handled */ static int __get_cur_ev() { int i; uint64_t min_time = -1; int min_trace = -1; int nb_skip=0; /* First, make all the non-started traces progress */ if (NB_START < NB_TRACES) for (i = 0; i < NB_TRACES; i++) if (!get_traces(i)->start) { *get_skip() = 0; return i; } for (i = 0; i < NB_TRACES; i++) { /* Only consider traces that * - have events to be handled * - do not wait for an external event */ #if 0 struct trace_t* cur_trace = get_traces(i); uint64_t cur_time = (uint64_t)((cur_trace->ev->time - cur_trace->start_time) + cur_trace->delay); if ((! cur_trace->done) && (!cur_trace->skip) && (cur_time < min_time)) { min_time = cur_time; min_trace = i; } #else if ((!get_traces(i)->done) && (!get_traces(i)->skip) && (CUR_TIME(i) < min_time)) { min_time = CUR_TIME(i); min_trace = i; } #endif /* reset the skip value so that the trace is not skipped forever */ if (!SKIP) { get_traces(i)->skip = 0; } if(get_traces(i)->skip) nb_skip++; } SKIP = 0; if(min_trace<0 && nb_skip == NB_TRACES) { fprintf(stderr, "Error: deadlock detected in %s\n", __FUNCTION__); abort(); } return min_trace; } /* initialize a container. * if new_container is NULL, a container is malloc'd * Return the address of the new container */ static struct eztrace_container_t* eztrace_create_container( struct eztrace_container_t* new_container, struct eztrace_container_t* parent_container) { if (!new_container) new_container = malloc(sizeof(struct eztrace_container_t)); new_container->parent = parent_container; new_container->nb_children = 0; new_container->children = NULL; new_container->p_trace = NULL; new_container->start_timestamp = 0; new_container->end_timestamp = 0; if (parent_container) { new_container->p_trace = parent_container->p_trace; parent_container->nb_children++; parent_container->children = realloc( parent_container->children, sizeof(struct eztrace_container_t*) * parent_container->nb_children); parent_container->children[parent_container->nb_children - 1] = new_container; } counters_new_container(new_container); hierarchical_array_new_container(new_container); return new_container; } void eztrace_create_containers(int trace_index) { /* initialize the root container */ struct eztrace_container_t *p_container = &get_traces(trace_index)->root_container; eztrace_create_container(p_container, NULL); p_container->container_type = process; p_container->p_trace = get_traces(trace_index); /* create the process_info structure and initialize it */ p_container->container_info = malloc(sizeof(struct process_info_t)); struct process_info_t *p_process = (struct process_info_t *) p_container->container_info; p_process->pid = trace_index; p_process->container = p_container; ezt_hook_list_init(&(p_process->hooks)); } void eztrace_create_ids(int trace_index) { struct eztrace_container_t *p_container = &get_traces(trace_index)->root_container; /* create the id and name strings */ int res __attribute__ ((__unused__)); res = CREATE_PROCESS_ID_STR(p_container->id, p_container->p_trace->trace_id); res = CREATE_PROCESS_NAME_STR(p_container->name, trace_index); } /* create the process corresponding to a trace */ void add_process(int trace_id) { eztrace_create_containers(trace_id); eztrace_create_ids(trace_id); } /* add a thread to the process_info_t structure */ void add_pthread(unsigned int tid) { struct eztrace_container_t *thread_container = eztrace_create_container( NULL, &CUR_TRACE->root_container); struct thread_info_t *p_thread = (struct thread_info_t*) malloc( sizeof(struct thread_info_t)); thread_container->container_type = thread; thread_container->container_info = p_thread; thread_container->start_timestamp = CURRENT; thread_container->end_timestamp = 0; int res __attribute__ ((__unused__)); res = CREATE_THREAD_ID_STR(thread_container->id, CUR_ID, tid); res = CREATE_THREAD_NAME_STR(thread_container->name, CUR_ID, tid); p_thread->tid = tid; p_thread->to_be_killed = 0; p_thread->processing_thread = NULL; p_thread->container = thread_container; p_thread->expected_code = 0; ezt_hook_list_init(&p_thread->hooks); sem_init(&p_thread->to_process, 0, 0); } /* PThread creation/destruction processing */ void new_thread(unsigned int tid) { if (CUR_ID && (NB_TRACES == 1 || CUR_TRACE->start)) { FUNC_NAME; add_pthread(tid); DECLARE_PROCESS_ID_STR(process_id, CUR_INDEX); DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); if (__cur_mode == EZTRACE_CONVERT) { addContainer(CURRENT, thread_id, "CT_Thread", process_id, thread_id, "0"); setState(CURRENT, "ST_Thread", thread_id, "STV_Working"); } } } void handle_new_thread() { new_thread(CUR_THREAD_ID); } void handle_end_thread(void) { FUNC_NAME; if(! CUR_TRACE->start) return; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); struct eztrace_container_t* p_cont = GET_THREAD_CONTAINER(CUR_INDEX, CUR_THREAD_ID); p_cont->end_timestamp = CURRENT; if (__cur_mode == EZTRACE_CONVERT && thread_id) { destroyContainer(CURRENT, thread_id, "CT_Thread"); } } void handle_thread_create(void) { FUNC_NAME; if (NB_TRACES == 1 || CUR_TRACE->start) { add_pthread(CUR_THREAD_ID); DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_PROCESS_ID_STR(process_id, CUR_INDEX); if (__cur_mode == EZTRACE_CONVERT) { addContainer(CURRENT, thread_id, "CT_Thread", process_id, thread_id,"0"); } } } void handle_start_thread_join(void) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_CORE_THREAD_INFO(p_thread, p_info); assert(p_info->last_event == 0); p_info->last_event = CURRENT; CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Blocked"); } void handle_stop_thread_join(void) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_CORE_THREAD_INFO(p_thread, p_info); assert(p_info->last_event > 0); p_info->time_join += CURRENT-p_info->last_event; p_info->last_event = 0; CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_start_thread_create (void) { if (NB_TRACES == 1 || CUR_TRACE->start) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_CORE_THREAD_INFO(p_thread, p_info); assert(p_info->last_event == 0); p_info->last_event = CURRENT; CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Blocked"); } } void handle_stop_thread_create (void) { if (NB_TRACES == 1 || CUR_TRACE->start) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_CORE_THREAD_INFO(p_thread, p_info); assert(p_info->last_event > 0); p_info->time_create += CURRENT-p_info->last_event; p_info->last_event = 0; CHANGE() popState(CURRENT, "ST_Thread", thread_id); } } void handle_enter_event_red (void) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); char *name; name = LITL_READ_RAW(CUR_EV)->data; CHANGE() addEvent(CURRENT, "E_UserEvent", thread_id, name); CHANGE() pushState(CURRENT, "ST_User", thread_id, "STV_User_Event_Red"); } void handle_enter_event_blue (void) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); char *name; name = LITL_READ_RAW(CUR_EV)->data; CHANGE() addEvent(CURRENT, "E_UserEvent", thread_id, name); CHANGE() pushState(CURRENT, "ST_User", thread_id, "STV_User_Event_Blue"); } void handle_enter_event_yellow (void) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); char *name; name = LITL_READ_RAW(CUR_EV)->data; CHANGE() addEvent(CURRENT, "E_UserEvent", thread_id, name); CHANGE() pushState(CURRENT, "ST_User", thread_id, "STV_User_Event_Yellow"); } void handle_enter_event_green (void) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); char *name; name = LITL_READ_RAW(CUR_EV)->data; CHANGE() addEvent(CURRENT, "E_UserEvent", thread_id, name); CHANGE() pushState(CURRENT, "ST_User", thread_id, "STV_User_Event_Green"); } void handle_enter_event_pink (void) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); char *name; name = LITL_READ_RAW(CUR_EV)->data; CHANGE() addEvent(CURRENT, "E_UserEvent", thread_id, name); CHANGE() pushState(CURRENT, "ST_User", thread_id, "STV_User_Event_Pink"); } void handle_leave_event() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); char *name; name = LITL_READ_RAW(CUR_EV)->data; CHANGE() popState(CURRENT, "ST_User", thread_id); } void handle_signal() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); int signo, nb_calls; GET_PARAM_PACKED_2(CUR_EV, signo, nb_calls); char* event_str = NULL; int res __attribute__ ((__unused__)); res = asprintf(&event_str, "Signal %d received. Backtrace:", signo); int i; for (i = 0; i < nb_calls; i++) { // TODO: change to pointers only. As a result, the performance should be improved ezt_litl_read_next_event(CUR_TRACE); assert(LITL_READ_GET_TYPE(CUR_EV) == LITL_TYPE_RAW); char* str = LITL_READ_RAW(CUR_EV)->data; char* tmp = event_str; res = asprintf(&event_str, "%s
[%d] %s", tmp, i, str); free(tmp); } CHANGE() addEvent(CURRENT, "E_SigSegv", thread_id, event_str); free(event_str); } uint64_t add_delay_to_trace(int trace_num, uint64_t old_time, uint64_t new_time, const char* thread_id) { struct trace_t* t = get_traces(trace_num); uint64_t delay = new_time - old_time; t->delay += delay; CHANGE() pushState(NS_TO_MS(old_time), "ST_Thread", thread_id, "STV_EZTRACE_SYNC"); CHANGE() popState(NS_TO_MS(new_time), "ST_Thread", thread_id); return delay; } static struct ezt_list_t module_list; void __core_init(void) __attribute__ ((constructor)); void __core_init(void) { static int module_initialized = 0; if (!module_initialized) { module_initialized = 1; ezt_list_new(&module_list); } } /* This function calls the init handler for all the registered modules */ int __init_modules() { struct ezt_list_token_t *token; ezt_list_foreach(&module_list, token) { struct eztrace_convert_module *p_module = (struct eztrace_convert_module *) token->data; p_module->init(); } return 0; } /* This function calls the handle callback for all the registered modules * It returns 1 if the ev was handled by one module or 0 otherwise */ int __handle_event(eztrace_event_t *ev) { int ret = 0; struct ezt_list_token_t *token; ezt_list_foreach(&module_list, token) { struct eztrace_convert_module *p_module = (struct eztrace_convert_module *) token->data; if (p_module->handle) ret = p_module->handle(ev); /* The module handled the event, let's return directly*/ if (ret) { goto out; } } out: return ret; } static int nb_handled_events = 0; /* This function calls the handle_stats callback for all the registered modules * It returns 1 if the ev was handled by one module or 0 otherwise */ int __handle_stats(eztrace_event_t *ev) { int ret = 0; struct ezt_list_token_t *token; ezt_list_foreach(&module_list, token) { struct eztrace_convert_module *p_module = (struct eztrace_convert_module *) token->data; if (p_module->handle_stats) ret = p_module->handle_stats(ev); /* The module handled the event, let's return directly */ if (ret) { nb_handled_events++; goto out; } } out: return ret; } static void print_pthread_core_stats() { printf("\nPTHREAD_CORE\n"); printf("------------\n"); int i; for(i=0; inb_children; j++) { struct eztrace_container_t* p_thread = p_cont->children[j]; struct thread_info_t *ptr = (struct thread_info_t*)(p_thread->container_info); struct pthread_core_thread_info_t *t_info = (struct pthread_core_thread_info_t*) ezt_hook_list_retrieve_data(&ptr->hooks, (uint8_t)PTHREAD_CORE_EVENTS_ID); if(!t_info) continue; if(t_info->time_join>0 || t_info->time_create >0) { printf("\nThread %s:\n", p_thread->name); printf("\ttime spent in pthread_join : %lf ms\n", t_info->time_join); printf("\ttime spent in pthread_create: %lf ms\n", t_info->time_create); total_time_join += t_info->time_join; total_time_create += t_info->time_create; } } if(total_time_join>0 ||total_time_create>0) { printf("\nTotal for %s\n", p_cont->name); printf("\ttime spent in pthread_join : %lf ms\n", total_time_join); printf("\ttime spent in pthread_create: %lf ms\n", total_time_create); } } } /* This function calls the handle_stats callback for all the registered modules * It returns 1 if the ev was handled by one module or 0 otherwise */ void __print_stats() { struct ezt_list_token_t *token; ezt_list_foreach(&module_list, token) { struct eztrace_convert_module *p_module = (struct eztrace_convert_module *) token->data; if (p_module->print_stats) p_module->print_stats(); } /* printf time_join */ print_pthread_core_stats(); printf("%d events handled\n", nb_handled_events); } void eztrace_convert_list() { struct ezt_list_token_t *token; ezt_list_foreach(&module_list, token) { struct eztrace_convert_module *p_module = (struct eztrace_convert_module *) token->data; printf("%d\t%s", p_module->module_prefix, p_module->name); printf("\t%s\n", p_module->description); } } /* set to 0 if the loading of module should be silent */ int module_verbose = 0; void eztrace_convert_register_module(struct eztrace_convert_module *p_module) { if (p_module->api_version != EZTRACE_API_VERSION) fprintf( stderr, "Warning: module %s uses API version %x, but current version is %x\n", p_module->name, p_module->api_version, EZTRACE_API_VERSION); struct ezt_list_token_t *token; /* Let's check wether another module with the same prefix is already registered */ezt_list_foreach(&module_list, token) { struct eztrace_convert_module *p_mod = (struct eztrace_convert_module *) token->data; if (p_module->module_prefix == p_mod->module_prefix) { fprintf( stderr, "Trying to register a module that is already registered. Module prefix is %x\n", p_mod->module_prefix); return; } } ezt_list_add(&module_list, &p_module->token); if (module_verbose) printf("module %s loaded\n", p_module->name); } char* cur_module_name = NULL; #define SO_STRING DYNLIB_EXT /* return 1 if the filename matches "eztrace_convert_*.so" */ static int filter(const struct dirent *entry) { const char* filename = entry->d_name; /* check wether the string starts with "eztrace-convert-" */ if (strncmp(filename, "libeztrace-convert-", strlen("libeztrace-convert-"))) /* the string doesn't start with "eztrace-convert-" */ return 0; /* check wether the next chars correspond to the module name * that we are looking for */ filename += strlen("libeztrace-convert-"); if (cur_module_name) { if (strncmp(filename, cur_module_name, strlen(cur_module_name))) /* the string doesn't start with "eztrace-convert-" */ return 0; filename += strlen(cur_module_name); } else { filename = entry->d_name + strlen(entry->d_name) - strlen(SO_STRING); } if (strncmp(filename, SO_STRING, strlen(SO_STRING))) /* the string doesn't end with ".so" */ return 0; /* check wether there are remaining chars after .so */ filename += strlen(SO_STRING); if (filename[0]) return 0; return 1; } /* Load a module from a specific libdir * if module_name is NULL, this function loads all the available * modules. * return the number of modules loaded */ static int __load_module_from_libdir(const char*module_name, const char*libdir) { int res __attribute__ ((__unused__)), nb_loaded = 0; /* update the module name we're looking for so that the filter function * can work as expected. */ cur_module_name = (char*) module_name; if (module_name) DPRINTF("Looking for module %s in directory %s\n", module_name, libdir) else DPRINTF("Looking for any module in directory %s\n", libdir) struct dirent **namelist; int n; /* Get the list of files that match the module name in the libdir directory */ n = scandir(libdir, &namelist, filter, alphasort); if (n < 0) perror("scandir"); else { while (n--) { /* Get the full name of the file (path/libname.so) */ char* libname = NULL; res = asprintf(&libname, "%s/%s", libdir, namelist[n]->d_name); /* Open the lib. The constructor of this lib is called and should register * the module by calling eztrace_convert_register_module() */ void* dlret = dlopen(libname, RTLD_NOW); if (!dlret) { fprintf(stderr, "%s\n", dlerror()); } DPRINTF("\tloaded: %s\n", libname) nb_loaded++; free(namelist[n]); if (module_name) { /* the module was loaded, return from the function so that the same module is not loaded again */ free(namelist); goto out; } } free(namelist); } out: return nb_loaded; } /* Search a module and load it. * if module_name is NULL, this function loads all the available * modules. * return the number of modules loaded */ static int __load_all_modules(const char*module_name) { /* number of modules loaded */ int nb_loaded = 0; char* save_ptr = NULL; char* cur_path = NULL; char* lib_path = NULL; /* First, let's try in the default lib_path */ nb_loaded = __load_module_from_libdir(module_name, EZTRACE_LIB_DIR); if (module_name && nb_loaded) { /* the module was loaded, return from the function so that the same module is not loaded again */ goto out; } /* Module not found, let's try the lib_path specified by the user */ lib_path = getenv("EZTRACE_LIBRARY_PATH"); if (!lib_path) { /* No lib_path specify, we can't find any more plugin */ goto out; } /* Iterate over the lib_path specified. * lib_path are separated by ':' */ save_ptr = lib_path; cur_path = strtok_r(lib_path, ":", &save_ptr); while (cur_path) { nb_loaded += __load_module_from_libdir(module_name, cur_path); if (module_name && nb_loaded) { /* the module was loaded, return from the function so that the same module is not loaded again */ goto out; } cur_path = strtok_r(NULL, ":", &save_ptr); } out: return nb_loaded; } void load_modules(int mod_verb) { char* module_list = getenv("EZTRACE_TRACE"); module_verbose = mod_verb; int nb_loaded = 0; char* save_ptr = NULL; char* module = NULL; if (!module_list) { /* no env declares, so let's load everything */ nb_loaded = __load_all_modules(NULL); /* We have loaded the pthread_core module which is not a * 'real' module, so let's decrement nb_loaded */ nb_loaded--; goto out; } DPRINTF("loading modules\n") /* EZTRACE_TRACE is declared. * it should contain modules separated by " ", such * as "mpi coreblas pthread" * Let's iterate over these modules and load them once at a time */ save_ptr = module_list; module = strtok_r(module_list, " ", &save_ptr); while (module) { DPRINTF("loading module %s\n", module); int loaded = __load_all_modules(module); if (!loaded) fprintf(stderr, "Cannot find module '%s'\n", module); nb_loaded += loaded; module = strtok_r(NULL, " ", &save_ptr); } out: if (mod_verb) printf("%d modules loaded\n", nb_loaded); return; } /* Tell the main thread that the current event has been processed */ void set_job_completed() { sem_post(&job_processed); } /* Wait for the next event to handle */ void wait_for_next_job(struct thread_info_t * thread_id) { sem_wait(&thread_id->to_process); } void set_cur_mode(enum eztrace_mode mode) { __cur_mode = mode; } eztrace_mode_t get_mode() { return __cur_mode; } void handle_start_flush() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_FLUSH"); } void handle_stop_flush() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState(CURRENT, "ST_Thread", thread_id); } int process_one_event(eztrace_event_t *ev) { /* we just woke up, the event to handle is CUR_EV */ int ret = 0; if (__cur_mode == EZTRACE_CONVERT) ret = __handle_event(ev); else ret = __handle_stats(ev); if(!ret) { ret = ezt_submodule_convert_handle(ev); } if (!ret) { switch (LITL_READ_GET_CODE(ev)) { case EZTRACE_START_FLUSH_CODE: handle_start_flush(); ret = 1; break; case EZTRACE_STOP_FLUSH_CODE: handle_stop_flush(); ret = 1; break; /* Handle the pthread_core related codes */ case EZTRACE_NEW_THREAD: /* already processed by the main thread, we can ignore this event */ ret = 1; break; case EZTRACE_END_THREAD: handle_end_thread(); ret = 1; /* this thread won't be used anymore */ return -1; break; case EZTRACE_START_THREAD_JOIN: handle_start_thread_join(); ret = 1; break; case EZTRACE_STOP_THREAD_JOIN: handle_stop_thread_join(); ret = 1; break; case EZTRACE_START_THREAD_CREATE: handle_start_thread_create (); ret = 1; break; case EZTRACE_STOP_THREAD_CREATE: handle_stop_thread_create (); ret = 1; break; case EZTRACE_SIGNAL_RECEIVED: handle_signal(); ret = 1; break; case EZTRACE_ENTER_EVENT_RED: handle_enter_event_red(); ret = 1; break; case EZTRACE_ENTER_EVENT_PINK: handle_enter_event_pink(); ret = 1; break; case EZTRACE_ENTER_EVENT_GREEN: handle_enter_event_green(); ret = 1; break; case EZTRACE_ENTER_EVENT_YELLOW: handle_enter_event_yellow(); ret = 1; break; case EZTRACE_ENTER_EVENT_BLUE: handle_enter_event_blue(); ret = 1; break; case EZTRACE_LEAVE_EVENT: handle_leave_event(); ret = 1; break; default: ret = 0; } } if(ret) { struct eztrace_container_t *p_cont = GET_PROCESS_CONTAINER(CUR_INDEX); p_cont->end_timestamp = CURRENT; } if (!ret && NB_START >= NB_TRACES) { /* This event is unknown :-( */ fprintf(stderr, "[%d] unknown event.. %x at time %lf\n", CUR_INDEX, (unsigned) LITL_READ_GET_CODE(ev), CURRENT); abort(); } return ret; } void wait_for_main_thread() { sem_wait(&main_thread_sem); } static int __handle_event_generic(eztrace_event_t *ev) { /* initialize stuff */ static int first_time = 1; if (first_time) { first_time = 0; sem_init(&job_processed, 0, 0); } DECLARE_CUR_THREAD(cur_thread); if (cur_thread) { /* check whether another is waiting for this event */ struct expected_code_t* exp = cur_thread->expected_code; while (exp) { if (exp->code == LITL_READ_GET_CODE(ev)) { /* a thread is waiting for this event */ /* wake up this thread */ sem_post(&exp->semaphore); /* wait until the thread has processed the event */ wait_for_main_thread(); return 1; } else { exp = exp->next; } } } /* we just woke up, the event to handle is CUR_EV */ int ret = process_one_event(ev); ret = ((ret <= 0) ? 0 : 1); if (cur_thread && cur_thread->to_be_killed) { /* the current thread is marked "to be killed" * This means that for processing the current event, we had to block * and create a new thread for handling the following events. Now that * the event is processed, there are two handling threads, so let's * wake up the other thread and destroy the current thread. */ cur_thread->to_be_killed = 0; wake_up_handler_thread(); pthread_exit(NULL); } return ret; } int handle_event(eztrace_event_t *ev) { set_cur_mode(EZTRACE_CONVERT); return __handle_event_generic(ev); } int stats_handle_events(eztrace_event_t *ev) { set_cur_mode(EZTRACE_STATS); return __handle_event_generic(ev); } /* ask the event scheduler to call handle(data) next time trace #trace_index is scheduled */ void ask_for_replay(int trace_index, void (*handle)(void*), void* data); struct __ezt_replay { void (*handle)(void*); void* data; }; struct __ezt_replay *replays = NULL; /* ask the event scheduler to call handle(data) next time trace #trace_index is scheduled * see handle_mpi_stop_waitall in src/modules/mpi/eztrace_convert_mpi.c for an example */ void ask_for_replay(int trace_index, void (*handle)(void*), void* data) { if (!replays) { /* first time this function is called. allocate replays */ int nb_traces = *(get_nb_traces()); replays = malloc(sizeof(struct __ezt_replay) * nb_traces); int i; for (i = 0; i < nb_traces; i++) { replays[i].handle = NULL; replays[i].data = NULL; } } assert(replays[trace_index].handle == NULL); replays[trace_index].handle = handle; replays[trace_index].data = data; } /* execute a replay */ static void __execute_replay(struct __ezt_replay *r) { void (*handle)(void*) = r->handle; void* data = r->data; /* remove the replay so that we don't loop infinitely */ r->handle = NULL; r->data = NULL; /* execute the function */ handle(data); } void* handle_one_event(void* arg __attribute__((unused))) { /* get the next event to process */ __handler_info.cur_trace_nb = __get_cur_ev(); set_cur_trace(get_traces(__handler_info.cur_trace_nb)); set_cur_ev(&get_cur_trace()->ev); int ret = 0; if (replays && replays[__handler_info.cur_trace_nb].handle) { /* execute the replay */ __execute_replay(&replays[__handler_info.cur_trace_nb]); } else { ret = (__cur_mode == EZTRACE_CONVERT) ? handle_event(CUR_EV) : stats_handle_events(CUR_EV); __handler_info.nb_handled += ret; } /* If current event was skipped, do not step forward the trace or this event will be 'lost' */ if (!SKIP && !next_ev(__handler_info.cur_trace_nb)) __handler_info.nb_done++; return NULL; } void* handle_all_events(void* arg) { wait_for_main_thread(); while (__handler_info.nb_done < NB_TRACES) { handle_one_event(arg); } sem_post(&__handler_info.events_processed); return NULL; } void wake_up_handler_thread() { sem_post(&main_thread_sem); } void wait_for_an_event(int trace_index, uint64_t code) { /* This declaration *has to be* before the call to next_ev * since next_ev may change the current thread */ DECLARE_THREAD_INFO(p_thread, CUR_INDEX, CUR_THREAD_ID); if (!next_ev(trace_index)) { fprintf(stderr, "Warning: trace %d ends, but I am waiting for an event !\n", trace_index); return; } if (LITL_READ_GET_CODE(&CUR_TRACE->ev) == code) return; /* The current thread expects a specific event, but another code appeared. * (This usually happens due to a race condition between thread when instrumenting) */ /* create another thread for processing the unneeded events */ new_handler_thread(); /* add the {code,semaphore} to the list of expected events */ struct expected_code_t* exp_code = malloc(sizeof(struct expected_code_t)); exp_code->code = code; sem_init(&exp_code->semaphore, 0, 0); exp_code->next = p_thread->expected_code; p_thread->expected_code = exp_code; /* wake up the thread we just created */ wake_up_handler_thread(); /* wait until the processing thread finds our events */ sem_wait(&exp_code->semaphore); /* make sure the event code is the right one */ assert(LITL_READ_GET_CODE(&CUR_TRACE->ev) == code); /* remove the {code,semaphore} from the list of expected events */ struct expected_code_t* cur_code, *prev_code; cur_code = p_thread->expected_code; prev_code = NULL; while(cur_code != exp_code) { prev_code = cur_code; cur_code = cur_code->next; } if(!prev_code) { p_thread->expected_code = cur_code->next; } else { prev_code->next = cur_code->next; } free(cur_code); /* Now that the event is processed, there are two handling threads, we need to destroy * the current thread. We can't do this right now (because we need to process the event * we were expecting). So, mark the thread "to be killed" so that someone destroys it * later (this is done in __handle_event_generic) */ p_thread->to_be_killed = 1; } void new_handler_thread() { DECLARE_CUR_THREAD(p_thread); pthread_t *p_new_thread = malloc(sizeof(pthread_t)); pthread_create(p_new_thread, NULL, handle_all_events, NULL); p_thread->processing_thread = main_thread; main_thread = p_new_thread; } void create_main_thread() { main_thread = malloc(sizeof(pthread_t)); pthread_create(main_thread, NULL, handle_all_events, NULL); } /* destroy a container and its children */ static void __finalize_container(struct eztrace_container_t* p_cont) { if (!p_cont) return; unsigned int i; /* finalize the children */ for (i = 0; i < p_cont->nb_children; i++) { __finalize_container(p_cont->children[i]); free(p_cont->children[i]); } /* finalize the container */ if (p_cont->container_type == thread) { struct thread_info_t *p_thread = (struct thread_info_t*) p_cont->container_info; /* free the pthread pointer */ if (p_thread->processing_thread) { free(p_thread->processing_thread); } /* free the thread hooks */ ezt_hook_list_free(&p_thread->hooks); } else { /* the container is a process */ struct process_info_t *p_process = (struct process_info_t*) p_cont->container_info; ezt_hook_list_free(&p_process->hooks); } free(p_cont->container_info); } void eztrace_convert_finalize() { int i; /* free all the containers */ for (i = 0; i < NB_TRACES; i++) { struct trace_t* cur_trace = get_traces(i); struct eztrace_container_t* cur_cont = &(cur_trace->root_container); __finalize_container(cur_cont); } free(main_thread); } eztrace-1.1-2/src/core/eztrace_convert_core.h000066400000000000000000000102541265506773700212700ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_CONVERT_CORE_H #define EZTRACE_CONVERT_CORE_H #include "eztrace_convert_types.h" eztrace_mode_t get_mode(); /* return a pointer to the verbose variable */ int* get_verbose(); /* return a pointer to the nb_traces variable */ int* get_nb_traces(); /* return a pointer to the nb_start variable */ int* get_nb_start(); /* return a pointer to trace #index */ struct trace_t* get_traces(int index); /* return a pointer to the trace whose event is being considered */ struct trace_t* get_cur_trace(); /* change the trace whose event is being considered */ void set_cur_trace(struct trace_t* p_trace); /* select convert/stat mode */ void set_cur_mode(enum eztrace_mode mode); /* return a pointer to the current event */ eztrace_event_t *get_cur_ev(); /* change the current event */ void set_cur_ev(eztrace_event_t *p_ev); /* The current event has not been handled, because requires another event (used in MPI_Comm_spawn) */ int* get_skip(); /* PThread creation/destruction processing */ void new_thread(unsigned int tid); /* add a thread to the process_info_t structure */ void add_pthread(unsigned int tid); /* initialize the container structures. */ void eztrace_create_containers(int trace_index); /* initialize the id and name fields of the process container structures */ void eztrace_create_ids(int trace_index); /* Initialize eztrace_convert_core */ void eztrace_convert_init(unsigned nb_traces); /* Initialize GTG (define the default States used in EZTrace) */ void eztrace_initialize_gtg(); /* Finalize eztrace_convert_core */ void eztrace_convert_finalize(); /* load available modules */ void load_modules(int verbose); /* print the list of currently loaded modules */ void eztrace_convert_list(); int __init_modules(); int __handle_event(eztrace_event_t *ev); int __handle_stats(eztrace_event_t *ev); void __print_stats(); void handle_new_thread(); void handle_end_thread(); void handle_thread_create(); void handle_start_thread_join(); void handle_stop_thread_join(); void* handle_one_event(void* arg); int handle_event(eztrace_event_t *ev); void set_job_completed(); void wait_for_next_job(struct thread_info_t * thread_id); /* add a delay to trace trace_num * @param trace_num index of the trace to modify * @param old_time original time in the trace * @param new_time new time in the trace * @param thread_id identifier of the thread that detects the delay */ uint64_t add_delay_to_trace(int trace_num, uint64_t old_time, uint64_t new_time, const char* thread_id); /* In order to avoid some deadlocks that may occur when an event handler handles * several events in a raw (because it records too many parameters to fit in one * call to EZTRACE_EVENT), eztrace_convert is multithreaded. * * In most cases, only one thread is run. However, when a handler needs to wait for * a particular event, it creates a new thread that becomes the main thread. The * previous main thread then blocks on a semaphore until the appropriate event is found. * It can then handle the event. This thread should then call pthread_exit(). */ void create_main_thread(); /* 'duplicate' the main thread. The new main_thread run handle_events. * The 'old' main_thread (ie. the current thread) then has to wait until the * main thread wakes it up. */ void new_handler_thread(); /* Wake up an handler thread */ void wake_up_handler_thread(); /* Wait until the main thread notifies that an event has to be processed * for a particular thread. */ void wait_for_an_event(int trace_index, uint64_t code); void* handle_all_events(void* arg); struct eztrace_event_handler* get_handler_info(); /* Ask the event scheduler to call handle(data) next time trace #trace_index is scheduled * This can be used when the processing of an event has started but has to wait for an * event to happen before resuming the processing. * see handle_mpi_stop_waitall in src/modules/mpi/eztrace_convert_mpi.c for an example */ void ask_for_replay(int trace_index, void (*handle)(void*), void* data); void ezt_litl_read_next_event(struct trace_t*p_trace); #endif /* EZTRACE_CONVERT_CORE_H */ eztrace-1.1-2/src/core/eztrace_convert_macros.h000066400000000000000000000135011265506773700216220ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_CONVERT_MACROS_H #define EZTRACE_CONVERT_MACROS_H #include #define VERBOSE (*get_verbose()) #define NB_TRACES (*get_nb_traces()) #define NB_START (*get_nb_start()) #define CUR_TRACE (get_cur_trace()) #define SKIP (*get_skip()) #define STARTED (CUR_TRACE->start != 0) #define CUR_EV (get_cur_ev()) #define CUR_THREAD_ID LITL_READ_GET_TID(&CUR_TRACE->ev) #define CURRENT (double)(((LITL_READ_GET_TIME(&CUR_TRACE->ev) - CUR_TRACE->start_time)+CUR_TRACE->delay)/1000000.0) #define CUR_TIME(i) (uint64_t)((LITL_READ_GET_TIME(&get_traces(i)->ev) - get_traces(i)->start_time) + get_traces(i)->delay) #define NS_TO_MS(ns) ((double)(ns)/1000000.0) #define CUR_RANK (CUR_TRACE->rank) #define CUR_ID (CUR_TRACE->trace_id) #define CUR_INDEX (CUR_TRACE->id) #define FUNC_NAME __func_name(CUR_TRACE->id, CURRENT, __FUNCTION__) extern int __ezt_debug_level; #define EZT_CONVERT_PRINTF(_debug_level_, args...) { \ if(__ezt_debug_level >= _debug_level_) \ fprintf(stderr, ##args); \ } #define CREATE_TRACE_ID_STR(__var__, __trace_index__) \ asprintf (&(__var__), "P#%d", __trace_index__) /* create the process id string */ #define CREATE_PROCESS_ID_STR(__var__, __trace_id__) \ asprintf (&(__var__), "%s", __trace_id__) /* create the thread id string */ #define CREATE_THREAD_ID_STR(__var__, __trace_id__, __tid__) \ asprintf (&(__var__), "%s_T#%u", __trace_id__, __tid__) /* create the process name string */ #define CREATE_PROCESS_NAME_STR(__var__, __trace_index__) \ asprintf (&(__var__), "CT_Process #%d", __trace_index__) /* create the thread name string */ #define CREATE_THREAD_NAME_STR(__var__, __trace_id__, __tid__) \ asprintf (&(__var__), "%s_T#%llu", __trace_id__, (long long unsigned int) __tid__) static inline struct eztrace_container_t * get_thread_cont_from_id( int trace_id, int thread_id); /* get a pointer to container */ static inline struct eztrace_container_t* GET_ROOT_CONTAINER(int trace_index) { struct trace_t* ret = get_traces(trace_index); if (ret) return &ret->root_container; return NULL; } #define GET_PROCESS_CONTAINER(__trace_index__) GET_ROOT_CONTAINER(__trace_index__) #define GET_THREAD_CONTAINER(__trace_index__, __thread_id__) get_thread_cont_from_id(__trace_index__, __thread_id__) /* get a pointer to the info structure */ static inline struct process_info_t* GET_PROCESS_INFO(int trace_index) { struct eztrace_container_t* ret = GET_PROCESS_CONTAINER(trace_index); if (ret) return (struct process_info_t*) (ret->container_info); return NULL; } static inline struct thread_info_t* GET_THREAD_INFO(int trace_index, int thread_id) { struct eztrace_container_t* ret = GET_THREAD_CONTAINER(trace_index, thread_id); if (ret) return (struct thread_info_t*) (ret->container_info); return NULL; } /* get a pointer to the id string */ static inline char* GET_PROCESS_ID_STR(int trace_index) { struct eztrace_container_t* ret = GET_ROOT_CONTAINER(trace_index); if (ret) return ret->id; return NULL; } ; static inline char* GET_THREAD_ID_STR(int trace_index, int thread_id) { struct eztrace_container_t* ret = GET_THREAD_CONTAINER(trace_index, thread_id); if (ret) return ret->id; return NULL; } ; /* get a pointer to the name string */ static inline char* GET_PROCESS_NAME_STR(int trace_index) { struct eztrace_container_t* ret = GET_ROOT_CONTAINER(trace_index); if (ret) return ret->name; return NULL; } ; static inline char* GET_THREAD_NAME_STR(int trace_index, int thread_id) { struct eztrace_container_t* ret = GET_THREAD_CONTAINER(trace_index, thread_id); if (ret) return ret->name; return NULL; } ; /* Same as above, but the variable is declared. */ #define DECLARE_PROCESS_INFO(__var__, __trace_index__) \ struct process_info_t* __var__ = GET_PROCESS_INFO(__trace_index__); #define DECLARE_THREAD_INFO(__var__, __trace_index__, __thread_id__) \ struct thread_info_t* __var__ = GET_THREAD_INFO(__trace_index__, __thread_id__) #define DECLARE_PROCESS_ID_STR(__var__, __trace_index__) \ char* __var__ = GET_PROCESS_ID_STR(__trace_index__) #define DECLARE_PROCESS_NAME_STR(__var__, __trace_index__) \ char* __var__ = GET_PROCESS_NAME_STR(__trace_index__) #define DECLARE_THREAD_ID_STR(__var__, __trace_index__, __thread_id__) \ char *__var__ __attribute__ ((__unused__)); \ __var__ = GET_THREAD_ID_STR(__trace_index__, __thread_id__) #define DECLARE_THREAD_NAME_STR(__var__, __trace_index__, __thread_id__) \ char* __var__ = GET_THREAD_NAME_STR(__trace_index__, __thread_id__) /* declare a var variable that points to the current process */ #define DECLARE_CUR_PROCESS(var) \ struct process_info_t * var = GET_PROCESS_INFO(CUR_INDEX); \ { if(!(var)) handle_new_thread (); } /* declare a var variable that points to the current thread */ #define DECLARE_CUR_THREAD(var) \ struct thread_info_t * var = GET_THREAD_INFO(CUR_INDEX, CUR_THREAD_ID); \ { \ if(!(var)) { \ handle_new_thread (); \ var = GET_THREAD_INFO(CUR_INDEX, CUR_THREAD_ID); \ } \ } /* Use the CHANGE macro before any trace function that modifies a thread/process state. * Otherwise, when MPI_Init is grabbed and the timer reset, the trace will be a mess. */ #define CHANGE() if(CUR_TRACE->start) /* create an identifier for a specific application pointer * This identifier is only valid within the current process. */ #define CREATE_OBJECT_ID(varname, ptr) \ char *varname; \ { \ int __attribute__((unused)) \ ret = asprintf (&varname, \ "%s_ptr_%p", \ GET_PROCESS_ID_STR(CUR_INDEX), \ (app_ptr) ptr); \ } #endif /* EZTRACE_CONVERT_MACROS_H */ eztrace-1.1-2/src/core/eztrace_convert_types.h000066400000000000000000000066531265506773700215140ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_CONVERT_TYPES_H #define EZTRACE_CONVERT_TYPES_H #include #include #include "eztrace_types.h" #include "litl_types.h" #include "litl_read.h" #include "eztrace_hook.h" // Define a general event type typedef litl_read_event_t eztrace_event_t; typedef litl_read_trace_t* eztrace_block_t; struct eztrace_convert_module; struct process_info_t; struct thread_info_t; struct trace_t; enum eztrace_mode { EZTRACE_STATS, EZTRACE_CONVERT, }; typedef enum eztrace_mode eztrace_mode_t; /* Describe a plugin */ struct eztrace_convert_module { uint32_t api_version; int (*init)(); int (*handle)(eztrace_event_t* ev); int (*handle_stats)(eztrace_event_t* ev); void (*print_stats)(); uint8_t module_prefix; char* name; char* description; struct ezt_list_token_t token; }; enum container_type_t { process, thread, }; /* contains generic information about a process or a thread */ struct eztrace_container_t { char* id; /* string that identify the object */ char* name; /* string that describes the object */ struct eztrace_container_t *parent; /* parent container */ unsigned nb_children; /* number of children containers */ struct eztrace_container_t **children; /* list of children containers */ enum container_type_t container_type; void* container_info; /* pointer to a process_info_t or thread_info_t */ struct trace_t *p_trace; /* pointer to the trace that describe this process */ struct hierarchical_array* arrays; struct eztrace_counter* counters; double start_timestamp; /* date of creation */ double end_timestamp; /* date of destruction */ }; struct expected_code_t { uint64_t code; sem_t semaphore; struct expected_code_t* next; }; /* Contains information about a thread. */ struct thread_info_t { int tid; /* thread id */ struct eztrace_container_t *container; /* container that corresponds to this thread */ int to_be_killed; struct expected_code_t *expected_code; sem_t to_process; pthread_t *processing_thread; struct ezt_hook_list_t hooks; /* list of hooks */ }; /* Contains information about a process. */ struct process_info_t { int pid; /* process id */ struct eztrace_container_t *container; /* container that corresponds to this process */ struct ezt_hook_list_t hooks; }; struct trace_t { uint64_t start_time; /* first timestamp of the trace */ uint64_t delay; /* if the trace started later than the other ones (ie. comm_spawn) */ char* input_filename; char* trace_id; /* Identifier of the trace in the output file */ eztrace_block_t block; litl_size_t trace_index; eztrace_event_t ev; int id; /* identifier in the traces array */ int rank; /* MPI rank. It may be different from the id */ int start; /* set to 0 until the MPI_Init happen */ int done; /* No more event to handle */ int skip; /* Skip this trace. This is used when we have to wait for another trace to produce an event (mpi_comm_spawn for example) */ int line_number; struct eztrace_container_t root_container; /* process corresponding to the trace */ }; struct eztrace_event_handler { int cur_trace_nb; int nb_done; int nb_handled; sem_t events_processed; }; struct eztrace_archive_info { char* filename; eztrace_block_t block; struct eztrace_archive_info *next; }; #endif /* EZTRACE_CONVERT_TYPES_H */ eztrace-1.1-2/src/core/eztrace_core.c000066400000000000000000000353621265506773700175320ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include #include #include #include #include #include #include #include #include #include #include "ev_codes.h" #include "eztrace.h" static void __eztrace_run_atexit_functions(); static pthread_key_t protect_on; struct __ezt_write_trace __ezt_trace; static void init_recursion_shield() { static int init_done = 0; if (!init_done) { pthread_key_create(&protect_on, NULL); init_done = 1; } } #ifndef EZTRACE_AUTOSTART void eztrace_register_init_routine(eztrace_function_t init_func) { __ezt_trace.init_routines[__ezt_trace.nb_module++] = init_func; } #endif /* EZTRACE_AUTOSTART */ static void __eztrace_set_buffer_size() { char* res = getenv("EZTRACE_BUFFER_SIZE"); if (res) { __ezt_trace.buffer_size = atoi(res); } } static char* __eztrace_get_filedir() { char* res = getenv("EZTRACE_TRACE_DIR"); if (!res) asprintf(&res, "/tmp"); return res; } void eztrace_set_filename(char* name) { int total_size = strlen(__eztrace_get_filedir()); total_size += strlen(getenv("USER")); total_size += strlen(name); total_size += 3; /* add 3 chars ('/', '_', '\0') */ if(__ezt_trace.filename) free(__ezt_trace.filename); __ezt_trace.filename = malloc(total_size); sprintf(__ezt_trace.filename, "%s/%s_%s", __eztrace_get_filedir(), getenv("USER"), name); litl_write_set_filename(__ezt_trace.litl_trace, __ezt_trace.filename); } /* return the library name from a symbol string */ static char* get_lib_name(char*symbol) { char* ret; int begin = 0; int end = -1; int i = 0; /* the format of symbol is : '/path/to/libxxx.so (function+0xoffset) [0xaddress]*/ /* so we need to locate the last / and the first ( */ while (symbol[i] != 0) { if (symbol[i] == '/') begin = i + 1; if (symbol[i] == '(') { end = i; break; } i++; } ret = &symbol[begin]; /* replace ( with a \0 */ if (end >= 0) symbol[end] = 0; return ret; } /* return the function name (or library name if the function name is unknown) * from a symbol string. * This function may alter the symbol string. */ static char* get_function_name(char* symbol) { char* ret = symbol; int len = strlen(symbol); int begin; int end; int i; /* the format of symbol is : 'libxxx.so (function+0xoffset) [0xaddress]*/ /* the goal is to retrieve the function+0xoffset string */ for (i = 0; i < len; i++) { if (symbol[i] == '(') { begin = i; if (symbol[i + 1] == '+' || symbol[i + 1] == ')') { return get_lib_name(symbol); } } if (symbol[i] == ')') { end = i; break; } } ret = &symbol[begin + 1]; symbol[end] = 0; return ret; } void eztrace_error_handler(int signo) { static volatile int shield = 0; /* in case several thread receive signals simultaneously, only the first one * handle it. */ while (shield) ; shield = 1; set_recursion_shield_on(); EZT_PRINTF(0, "[EZTrace] signal %d catched.\n", signo); void* buffer[50]; /* get pointers to functions */ int nb_calls = backtrace(buffer, 50); char **functions; functions = backtrace_symbols(buffer, nb_calls); int i; EZTRACE_EVENT2(EZTRACE_SIGNAL_RECEIVED, signo, nb_calls); for (i = 0; i < nb_calls; i++) { char* ptr = get_function_name(functions[i]); litl_write_probe_raw(__ezt_trace.litl_trace, EZTRACE_CALLING_FUNCTION, strlen(ptr), (void*)ptr); } free(functions); set_recursion_shield_off(); } void eztrace_signal_handler(int signo) { static volatile int shield = 0; /* in case several thread receive signals simultaneously, only the first one * handle it. */ while (shield) ; shield = 1; EZT_PRINTF(0, "EZTrace received signal %d...\n", signo); if (signo == SIGSEGV) eztrace_error_handler(signo); eztrace_stop(); EZT_PRINTF(0, "Signal handling done\n"); exit(EXIT_FAILURE); //signal(signo, SIG_DFL); } /* when an alarm signal is received, check for sampling information */ void __eztrace_alarm_sighandler(int signo __attribute__((unused))){ ezt_sampling_check_callbacks(); } #ifdef __linux__ long __ezt_alarm_interval = 0; void eztrace_set_alarm() { if(__ezt_alarm_interval>=0) { struct sigevent sevp; sevp.sigev_notify=SIGEV_THREAD_ID | SIGEV_SIGNAL; sevp.sigev_signo=SIGALRM; sevp.sigev_value.sival_int=0; sevp.sigev_notify_function = NULL; sevp.sigev_notify_attributes=NULL; sevp._sigev_un._tid = syscall(__NR_gettid); timer_t *t = malloc(sizeof(timer_t)); int ret = timer_create(CLOCK_REALTIME, &sevp, t); if(ret != 0){ perror("timer create failed"); abort(); } struct itimerspec new_value, old_value; new_value.it_interval.tv_sec=0; new_value.it_interval.tv_nsec=__ezt_alarm_interval; new_value.it_value.tv_sec=0; new_value.it_value.tv_nsec=__ezt_alarm_interval; ret = timer_settime(*t,0, &new_value, &old_value); if(ret != 0){ perror("timer settime failed"); abort(); } } } #endif static void __eztrace_set_sighandler() { char* res = getenv("EZTRACE_NO_SIGNAL_HANDLER"); if (!res || !strncmp(res, "0", 2)) { signal(SIGSEGV, eztrace_signal_handler); signal(SIGINT, eztrace_signal_handler); signal(SIGTERM, eztrace_signal_handler); signal(SIGABRT, eztrace_signal_handler); signal(SIGHUP, eztrace_signal_handler); } #ifdef __linux__ res = getenv("EZTRACE_SIGALARM"); if(res && (strncmp(res, "0", 2) != 0)) { /* convert from ms to ns */ __ezt_alarm_interval = atoi(res)*1000000; printf("[EZTrace] Setting an alarm every %d ms\n", atoi(res)); signal(SIGALRM, __eztrace_alarm_sighandler); eztrace_set_alarm(); } #endif } void eztrace_start_() { eztrace_start(); } void eztrace_start() { /* avoid executing this function several times */ if(__ezt_trace.status >= ezt_trace_status_running) return; __ezt_trace.status = ezt_trace_status_uninitialized; __ezt_trace.debug_level = 0; __ezt_trace.buffer_size = (16 * 1024 * 1024); // 16MB char* debug_mode = getenv("EZTRACE_DEBUG"); if (debug_mode) { __ezt_trace.debug_level = atoi(debug_mode); EZT_PRINTF(0, "EZTrace Debug mode enabled (trace level: %d)\n", __ezt_trace.debug_level); } EZT_PRINTF(0, "Starting EZTrace... "); __eztrace_set_buffer_size(); /* make sure eztrace_stop is called when the program stops */ atexit(eztrace_stop); __eztrace_set_sighandler(); char* allow_flush = getenv("EZTRACE_FLUSH"); // start LiTL __ezt_trace.litl_trace = litl_write_init_trace(__ezt_trace.buffer_size); // the recording should be paused, because some further functions, e.g. *_set_filename() can be intercepted by eztrace litl_write_pause_recording(__ezt_trace.litl_trace); litl_write_tid_recording_on(__ezt_trace.litl_trace); if (allow_flush && strncmp(allow_flush, "0", 2)) { litl_write_buffer_flush_on(__ezt_trace.litl_trace); EZT_PRINTF(0, "EZTrace Flush enabled\n"); } eztrace_set_filename("eztrace_log_rank_1"); litl_write_resume_recording(__ezt_trace.litl_trace); init_recursion_shield(); __ezt_trace.status = ezt_trace_status_running; /* the current thread needs to be registered since eztrace won't * intercept any pthread_create for this one */ EZTRACE_EVENT0(EZTRACE_NEW_THREAD); #ifndef EZTRACE_AUTOSTART /* call the initialisation routines that were registered */ int i; for (i = 0; i < __ezt_trace.nb_module; i++) __ezt_trace.init_routines[i](); #endif /* EZTRACE_AUTOSTART */ EZT_PRINTF(0, "done\n"); } void eztrace_stop_() { eztrace_stop(); } void eztrace_stop() { if(__ezt_trace.status >= ezt_trace_status_being_finalized || __ezt_trace.status < ezt_trace_status_running) return; __ezt_trace.status = ezt_trace_status_being_finalized; __eztrace_run_atexit_functions(); EZTRACE_EVENT0(EZTRACE_END_THREAD); __ezt_trace.status = ezt_trace_status_finalized; EZTRACE_FIN_TRACE(); EZT_PRINTF(0, "Stopping EZTrace... saving trace %s\n", __ezt_trace.filename); } void eztrace_silent_start() { eztrace_start(); __ezt_trace.status = ezt_trace_status_paused; } void eztrace_pause() { __ezt_trace.status = ezt_trace_status_paused; } void eztrace_resume() { __ezt_trace.status = ezt_trace_status_running; } void eztrace_enter_event(char *name, enum ezt_color color) { EZTRACE_PROTECT { EZTRACE_PROTECT_ON(); switch (color) { case EZTRACE_RED: litl_write_probe_raw(__ezt_trace.litl_trace, EZTRACE_ENTER_EVENT_RED, strlen(name) + 1, (litl_data_t*) name); break; case EZTRACE_YELLOW: litl_write_probe_raw(__ezt_trace.litl_trace, EZTRACE_ENTER_EVENT_YELLOW, strlen(name) + 1, (litl_data_t*) name); break; case EZTRACE_BLUE: litl_write_probe_raw(__ezt_trace.litl_trace, EZTRACE_ENTER_EVENT_BLUE, strlen(name) + 1, (litl_data_t*) name); break; case EZTRACE_GREEN: litl_write_probe_raw(__ezt_trace.litl_trace, EZTRACE_ENTER_EVENT_GREEN, strlen(name) + 1, (litl_data_t*) name); break; case EZTRACE_PINK: litl_write_probe_raw(__ezt_trace.litl_trace, EZTRACE_ENTER_EVENT_PINK, strlen(name) + 1, (litl_data_t*) name); break; } EZTRACE_PROTECT_OFF(); } } void eztrace_leave_event(char *name) { EZTRACE_EVENT0(EZTRACE_LEAVE_EVENT); } void eztrace_generic(uint32_t code, int nbargs, ...) { int i; va_list args; uint64_t arg_array[9]; va_start(args, nbargs); for (i = 0; i < nbargs; i++) arg_array[i] = va_arg(args, uint64_t); switch (nbargs) { case 0: EZTRACE_EVENT0(code) ; break; case 1: EZTRACE_EVENT1(code, arg_array[0]) ; break; case 2: EZTRACE_EVENT2(code, arg_array[0], arg_array[1]) ; break; case 3: EZTRACE_EVENT3(code, arg_array[0], arg_array[1], arg_array[2]) ; break; case 4: EZTRACE_EVENT4(code, arg_array[0], arg_array[1], arg_array[2], arg_array[3]) ; break; case 5: EZTRACE_EVENT5(code, arg_array[0], arg_array[1], arg_array[2], arg_array[3], arg_array[4]); break; case 6: EZTRACE_EVENT6(code, arg_array[0], arg_array[1], arg_array[2], arg_array[3], arg_array[4], arg_array[5]); break; case 7: EZTRACE_EVENT7(code, arg_array[0], arg_array[1], arg_array[2], arg_array[3], arg_array[4], arg_array[5], arg_array[6]); break; case 8: EZTRACE_EVENT8(code, arg_array[0], arg_array[1], arg_array[2], arg_array[3], arg_array[4], arg_array[5], arg_array[6], arg_array[7]); break; case 9: EZTRACE_EVENT9(code, arg_array[0], arg_array[1], arg_array[2], arg_array[3], arg_array[4], arg_array[5], arg_array[6], arg_array[7], arg_array[8]); break; } } void eztrace_code0(uint32_t code) { EZTRACE_EVENT0(code); } void eztrace_code1(uint32_t code, uint64_t arg1) { EZTRACE_EVENT1(code, arg1); } void eztrace_code2(uint32_t code, uint64_t arg1, uint64_t arg2) { EZTRACE_EVENT2(code, arg1, arg2); } void eztrace_code3(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3) { EZTRACE_EVENT3(code, arg1, arg2, arg3); } void eztrace_code4(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3, uint64_t arg4) { EZTRACE_EVENT4(code, arg1, arg2, arg3, arg4); } void eztrace_code5(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3, uint64_t arg4, uint64_t arg5) { EZTRACE_EVENT5(code, arg1, arg2, arg3, arg4, arg5); } void eztrace_code6(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3, uint64_t arg4, uint64_t arg5, uint64_t arg6) { EZTRACE_EVENT6(code, arg1, arg2, arg3, arg4, arg5, arg6); } void eztrace_code7(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3, uint64_t arg4, uint64_t arg5, uint64_t arg6, uint64_t arg7) { EZTRACE_EVENT7(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7); } void eztrace_code8(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3, uint64_t arg4, uint64_t arg5, uint64_t arg6, uint64_t arg7, uint64_t arg8) { EZTRACE_EVENT8(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8); } void eztrace_code9(uint32_t code, uint64_t arg1, uint64_t arg2, uint64_t arg3, uint64_t arg4, uint64_t arg5, uint64_t arg6, uint64_t arg7, uint64_t arg8, uint64_t arg9) { EZTRACE_EVENT9(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9); } int recursion_shield_on() { init_recursion_shield(); void* ret = NULL; ret = pthread_getspecific(protect_on); return (ret != NULL); } void set_recursion_shield_on() { init_recursion_shield(); pthread_setspecific(protect_on, (void*) 1); } void set_recursion_shield_off() { pthread_setspecific(protect_on, (void*) NULL); } #ifdef RECORD_BACKTRACES /* record an event (code=EZTRACE_CALLING_FUNCTION) with the calling function name */ void record_backtrace() { set_recursion_shield_on(); /* the current backtrace looks like this: * 0 - record_backtrace() * 1 - eztrace_callback() * 2 - calling_function * * So, we need to get the name of the function in frame 2. */ void* buffer[3]; /* get pointers to functions */ int nb_calls = backtrace(buffer, 3); assert(nb_calls>=3); char **functions; functions = backtrace_symbols(buffer, nb_calls); litl_write_probe_raw(__ezt_trace.litl_trace, EZTRACE_CALLING_FUNCTION, strlen(functions[2]), functions[2]); free(functions); set_recursion_shield_off(); } #else void record_backtrace() { } #endif struct eztrace_atexit_token_t { eztrace_atexit_function_t func; void* param; }; struct eztrace_atexit_list_t { struct eztrace_atexit_token_t* list; int nb_allocated; int nb_functions; }; struct eztrace_atexit_list_t* atexit_list = NULL; /* register a function to be called before eztrace_stop. */ void eztrace_atexit(eztrace_atexit_function_t f, void* param) { if(!atexit_list) { /* first time this function is called. Allocate/initialize the atexit_list structure */ atexit_list = malloc(sizeof(struct eztrace_atexit_list_t)); atexit_list->nb_allocated = 10; atexit_list->list = malloc(sizeof(struct eztrace_atexit_token_t) * atexit_list->nb_allocated); atexit_list->nb_functions = 0; } int num = atexit_list->nb_functions++; if(num >= atexit_list->nb_allocated) { /* too many atexit callbacks. We need to expand the array */ atexit_list->nb_allocated *= 2; void* ptr = realloc(atexit_list->list, sizeof(struct eztrace_atexit_token_t)*atexit_list->nb_allocated); assert(ptr); atexit_list->list = ptr; } atexit_list->list[num].func = f; atexit_list->list[num].param = param; } /* run all the atexit callbacks that were registered */ static void __eztrace_run_atexit_functions() { if(atexit_list) { int i; for(i=0; i< atexit_list->nb_functions; i++) { atexit_list->list[i].func(atexit_list->list[i].param); } } } eztrace-1.1-2/src/core/eztrace_create_plugin.in000077500000000000000000000600671265506773700216120ustar00rootroot00000000000000#!/usr/bin/perl -w # Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. my $prefix; my $exec_prefix; my $libdir; my $includedir; my $bindir; BEGIN { $prefix="@prefix@"; $exec_prefix="@exec_prefix@"; $libdir="@libdir@"; $includedir="@includedir@"; $bindir="@bindir@"; $topdatadir="@datadir@"; } use lib "$bindir"; use function; use Getopt::Long; use Pod::Usage; my $gtg_cflags="@GTG_EXT_CPPFLAGS@"; my $gtg_ldflags="@GTG_EXT_LDFLAGS@"; my $tl_cflags="@TL_EXT_CPPFLAGS@"; my $tl_ldflags="@TL_EXT_LDFLAGS@"; my $common_cflags="$gtg_cflags $tl_cflags"; my $common_ldflags=""; my $convert_ldflags="$gtg_ldflags $tl_ldflags"; my $record_ldflags="$tl_ldflags"; my $header_name; my $module_name; my $module_desc; my $module_type="LIBRARY"; my $module_id=99; my $language; my $record_callbacks = ""; my $record_functions = ""; my $sampling_functions = ""; my $post_init = ""; my $record_intercepts = ""; my $event_definition = ""; my $convert_functions_prototypes = ""; my $convert_case = ""; my $convert_function_body = ""; my $convert_init = ""; my $next_event_id = 0x0001; my $cur_line = 0; my $cur_function; my $cur_event_start_name; my $cur_event_stop_name; my $cur_event_start_code; my $cur_event_stop_code; my $next_gtg_state_id = 0; my $next_gtg_event_id = 0; my %variables; my $include_str=""; my $header_user=""; my $output_dir="output"; my $input_dir="${topdatadir}/eztrace"; my $keep_this_line = 0; sub parse_options { my $man = 0; my $help = 0; my $includedir_str = ""; GetOptions ('include_dir|I=s' => \$includedir_str, 'output|o=s' => \$output_dir, 'help|h' => \$help, man => \$man) or pod2usage(2); pod2usage(1) if $help; pod2usage(-exitstatus => 0, -verbose => 2) if $man; # Convert list of include directories to -I option foreach my $dir ( split( ',', $includedir_str ) ) { $common_cflags .= " -I$dir"; } } parse_options(); sub convert_add_prototype( $ ) { my $suffix = shift; $convert_functions_prototypes .= <create_asprintf("opt_value_${ev_code}"); $convert_function_body .= <convert_declare_parameters($cur_event_name); convert_add_prototype($ev_code); convert_add_switch_case($ev_code); $convert_function_body .= <convert_declare_parameters($cur_event_name); convert_add_prototype($ev_code); convert_add_switch_case($ev_code); $convert_function_body .= <convert_declare_parameters($cur_event_name); convert_add_prototype($ev_code); convert_add_switch_case($ev_code); $convert_function_body .= <add_event($cur_event_name); convert_function_push_state($cur_event_name, $state_description); } # Add an LiTL event and the fills the convert file in order to interpret # it as a pop_state # params: # $fname function name sub add_POP_STATE( $ ) { my $fname = shift; new_event($fname); $cur_function->add_event($cur_event_name); convert_function_pop_state($cur_event_name); } # Add an LiTL event and fills the convert file in order to interpret # it as a addEvent # params: # $fname function name # $event_description description of the event in the output trace sub add_EVENT($$) { my $fname = shift; my $event_description = shift; new_event($fname); $cur_function->add_event($cur_event_name); convert_function_event($cur_event_name, $event_description); } # Add an LiTL event and fills the convert file in order to interpret # it as a set_var # params: # $fname function name # $var_name Name of the variable # $var_value Value of the variable sub add_SET_VAR($$$) { my $fname = shift; my $var_name = shift; my $var_value = shift; $var_id = register_var_name($var_name); new_event($fname); $cur_function->add_event($cur_event_name); convert_function_set_var($cur_event_name, $var_id, $var_value); } # Add an LiTL event and fills the convert file in order to interpret # it as a add_var # params: # $fname function name # $var_name Name of the variable # $var_value Value of the variable sub add_ADD_VAR( $$$ ) { my $fname = shift; my $var_name = shift; my $var_value = shift; $var_id = register_var_name($var_name); new_event($fname); $cur_function->add_event($cur_event_name); convert_function_add_var($cur_event_name, $var_id, $var_value); } # Add an LiTL event and fills the convert file in order to interpret # it as a sub_var # params: # $fname function name # $var_name Name of the variable # $var_value Value of the variable sub add_SUB_VAR( $$$ ) { my $fname = shift; my $var_name = shift; my $var_value = shift; $var_id = register_var_name($var_name); new_event($fname); $cur_function->add_event($cur_event_name); convert_function_sub_var($cur_event_name, $var_id, $var_value); } sub write_sampling_function( $$$ ) { my $fname = shift; my $interval = shift; my $code = shift; @liste = split("\n",$code); foreach $instruction (@liste) { if( $instruction =~ m/\s*SAMPLING_RECORD\s*\([^\,]+\s*\,\s*[^\,]+\s*\)/ ) { # detect SAMPLING_RECORD(value, description) # and replace it by: # EZTRACE_RECORD1($event_name, value) ($value, $description) = ($instruction =~ m/\s*SAMPLING_RECORD\s*\(([^\,]+)\s*\,\s*([^\,]+)\s*\)/); new_event($fname); $sampling_functions .= "$`EZTRACE_EVENT_PACKED_1($cur_event_name, $value)$'"; # in the _convert file: # create the prototype (int handle_xxx();) # and add the switch case that calls the processing function convert_add_prototype($cur_event_name); convert_add_switch_case($cur_event_name); # Create the variable during initialisation $convert_init .= <); out: write_sampling_function($fname, $interval, $function_code); } sub handle_function { my $rettype; my $fname=""; my @args; my $nb_arg; $nb_arg=0; my $new_callback = ""; my $new_function; my $function_body=""; $cur_function = Function->new(); $cur_function->set_type($module_type); # retrieve the return type and the function name my $proto_string = ""; do { SWITCH: { /^$/ && do { next; }; /.*\.\.\..*/ && do { $proto_string.=$_; printf "Cannot process Function '%s'\n", $proto_string; return; }; /\(/ && ($fname eq "") && do { # this line contains ( so let's copy the beginning # of the line in the prototype. my $line_len = index($_, "\("); $proto_string .= substr($_, 0, $line_len); # in order to ease the parsing, add a space after each * we find $proto_string =~ s/\*/\* /g; # extract the return type and the function name ($rettype, $fname) = ($proto_string =~ m/^\s*([\S+\s*]+\**)\s+(\S+)\s*$/); substr($_, 0, $line_len, ""); s/\s*\(\s*//; $proto_string = ""; }; /\)/ && do { my $line_len = index($_, "\)"); $proto_string .= substr($_, 0, $line_len); # remove multiple spaces/newlines $proto_string =~ s/\s+/ /g; $proto_string =~ s/\n+/ /g; $proto_string =~ s/^\s*//g; $proto_string =~ s/\s*$//g; goto body; next; }; do { $proto_string .= $_; }; } } while(<>); body: # first, let's fill the Function object $cur_function->set_fname($fname); $cur_function->set_ret_type($rettype); # extract all the parameters for this function and give them # once at a time to the Function class my @params= (split m/,\s*/, $proto_string); my $i; my $nb_param=0; for($i=0; $i<@params; $i++) { my $cur_param = $params[$i]; #remove trailing white spaces $cur_param =~ s/^\s*//g; $cur_param =~ s/\s*$//g; my $arg_name =""; my $arg_type=""; my $suffix=""; # extract [] (if any) if( $cur_param =~ m/((\[\s*\]\s*)+)/) { ($suffix) = ($cur_param =~ m/((\[\s*\]\s*)+)/); $cur_param =~ s/((\[\s*\]\s*)+)/ /g; # convert [] into * (so that we can declare the parameter as "int []a") $suffix =~ s/\[\s*\]/\*/g; } # extract * (if any) if( $cur_param =~ m/((\*\s*)+)/) { ($suffix) = ($cur_param =~ m/((\*\s*)+)/); $cur_param =~ s/((\*\s*)+)/ /g; } # extract the parameter name $arg_name = (split m/\s+/, $cur_param)[-1]; # the remaining is the parameter type $arg_type = $cur_param; # escape special characters in arg_name (eg. []) so that they are not # interpreted during the substitution my $arg_name_pat=quotemeta($arg_name); $arg_type =~ s/\s*$arg_name_pat\s*$//; # add the [] or * that were found $arg_type .= $suffix; if($arg_name ne "" && $arg_type ne "") { $nb_param++; $cur_function->add_arg($arg_type, $arg_name); } } my $begin_detected = 0; while(<>) { SWITCH: { /^$/ && do { next; }; /^\s*BEGIN\s/ && do { $begin_detected = 1; $new_callback = $cur_function->create_callback(); next; }; /^\s*CALL_FUNC/ && do { chomp; $cur_function->add_fcall(); next; }; # handling of states /^\s*PUSH_STATE/ && do { chomp; s/^\s*PUSH_STATE\s*\(\"//; s/\s*\"\)//; s/\s*$//; $state_description=$_; $event = add_PUSH_STATE($fname, $state_description); next; }; /^\s*POP_STATE/ && do { chomp; $event = add_POP_STATE($fname); next; }; /^\s*RECORD_STATE/ && do { chomp; s/^\s*RECORD_STATE\s*\(\"//; s/\s*\"\)//; s/\s*$//; $state_description=$_; # push my $event = add_PUSH_STATE($fname, $state_description); # fcall $cur_function->add_fcall(); # pop $event = add_POP_STATE($fname); next; }; # handling of events /^\s*EVENT/ && do { chomp; s/^\s*EVENT\s*\(\"//; s/\s*\"\)//; s/\s*$//; $event_description=$_; $event = add_EVENT($fname, $event_description); next; }; # handling of variables /^\s*SET_VAR/ && do { chomp; s/^\s*SET_VAR\s*\(\"//; # retrieve the var name $var_name_len = index($_, "\""); if($var_name_len < 0) { printf "line $cur_line: syntax error in SET_VAR\n"; exit(1); } $var_name=substr($_, 0, $var_name_len); # remove the var name and the trailing ", s/^$var_name\",\s*//; # remove the ')' at the end of the line s/\s*\)\s*$//; $var_value=$_; $event = add_SET_VAR($fname, $var_name, $var_value); next; }; /^\s*ADD_VAR/ && do { chomp; s/^\s*ADD_VAR\s*\(\"//; # retrieve the var name $var_name_len = index($_, "\""); if($var_name_len < 0) { printf "line $cur_line: syntax error in ADD_VAR\n"; exit(1); } $var_name=substr($_, 0, $var_name_len); # remove the var name and the trailing ", s/^$var_name\",\s*//; # remove the ')' at the end of the line s/\s*\)\s*$//; $var_value=$_; $event = add_ADD_VAR($fname, $var_name, $var_value); next; }; /^\s*SUB_VAR/ && do { chomp; s/^\s*SUB_VAR\s*\(\"//; # retrieve the var name $var_name_len = index($_, "\""); if($var_name_len < 0) { printf "line $cur_line: syntax error in SUB_VAR\n"; exit(1); } $var_name=substr($_, 0, $var_name_len); # remove the var name and the trailing ", s/^$var_name\",\s*//; # remove the ')' at the end of the line s/\s*\)\s*$//; $var_value=$_; $event = add_SUB_VAR($fname, $var_name, $var_value); next; }; /^\s*END\s/ && do { $new_function = $cur_function->create_function(); goto out; }; if($begin_detected == 0) { # there was only the function prototype # Let's say that the user wants RECORD_STATE printf "\temulate record_state for '$fname'\n"; $new_callback = $cur_function->create_callback(); # push my $event = add_PUSH_STATE($fname, "Doing function $fname"); # fcall $cur_function->add_fcall(); # pop $event = add_POP_STATE($fname); $new_function = $cur_function->create_function(); $keep_this_line = 1; goto out; } printf "line $cur_line: unknown command '$_'\n"; exit 1; } $cur_line++; }; out: $new_intercept = $cur_function->create_intercept(); $record_intercepts .= "$new_intercept\n"; $record_callbacks .= "$new_callback\n"; $record_functions .= "$new_function\n"; printf "Function '%s' done\n", $fname; } sub handle_includes { while(<>) { $cur_line++; SWITCH: { /^\s*END_INCLUDE/ && do { return; }; do { $header_user .= $_; }; } } } sub handle_cflags { my $cflags = " "; while(<>) { $cur_line++; SWITCH: { /^\s*END_CFLAGS/ && do { goto end; }; /^\s*#/ && do { next; }; do { $cflags .= $_; }; } } end: $cflags =~ s/\n/ /g; $common_cflags .= $cflags } sub handle_ldflags { my $ldflags = " "; while(<>) { $cur_line++; SWITCH: { /^\s*END_LDFLAGS/ && do { goto end; }; /^\s*#/ && do { next; }; do { $ldflags .= $_; }; } } end: $ldflags =~ s/\n/ /g; $common_ldflags .= $ldflags } while (<>) { $cur_line++; main_loop: if($keep_this_line == 1) { $keep_this_line = 0; } SWITCH: { /^\s*$/ && do { next; }; /^\s*BEGIN_MODULE/ && do { printf "New Module\n"; next; }; /^\s*END_MODULE/ && do { printf "End of Module $module_name\n"; goto end_module; }; /^\s*BEGIN_INCLUDE/ && do { s/^\s*BEGIN_INCLUDE\s*//; # remove trailing whitespaces s/\s*$//; handle_includes; next; }; /^\s*BEGIN_CFLAGS/ && do { s/^\s*BEGIN_CFLAGS\s*//; # remove trailing whitespaces s/\s*$//; handle_cflags; next; }; /^\s*BEGIN_LDFLAGS/ && do { s/^\s*BEGIN_LDFLAGS\s*//; # remove trailing whitespaces s/\s*$//; handle_ldflags; next; }; /^\s*NAME/ && do { s/^\s*NAME\s*//; # remove trailing whitespaces s/\s*$//; chomp; $module_name=$_; if (!$module_name) { print "Choose a name for your module : operation stopped\n"; exit 1; } printf "Module name : '$module_name'\n"; next; }; /^\s*ID/ && do { s/^\s*ID\s*//; # remove trailing whitespaces s/\s*$//; chomp; $module_id=$_; printf "Module id : '$module_id'\n"; next; }; /^\s*DESC/ && do { chomp; s/^\s*DESC\s*//; # remove trailing whitespaces s/\s*$//; $module_desc=$_; printf "Module description : '$module_desc'\n"; next; }; /^\s*LANGUAGE/ && do { chomp; s/^\s*LANGUAGE\s*//; # remove trailing whitespaces s/\s*$//; $language=$_; printf "Language : '$language'\n"; next; }; /^\s*TYPE/ && do { chomp; s/^\s*TYPE\s*//; # remove trailing whitespaces s/\s*$//; my $type=$_; if($type eq "LIBRARY") { printf "Type : library\n"; } elsif($type eq "APPLICATION") { printf "Type : application\n"; } else { printf "line $cur_line: Unknown module type: '$type'\n"; printf "\tfailing back to default ($module_type)\n"; $type = $module_type; } $module_type = $type; next; }; # DEFINE_SAMPLING_FUNCTION(function_name, interval) # code function # END_DEFINE /^\s*DEFINE_SAMPLING_FUNCTION/ && do { chomp; s/^\s*DEFINE_SAMPLING_FUNCTION//; define_sampling_function; next; }; /^\s*\#/ && do { # this is a comment, skip this line next; }; do { chomp; handle_function; if($keep_this_line == 1) { goto main_loop; } next; }; } } sub apply_changes($$) { my $ifile = shift; my $ofile = shift; open(OUTPUT_FILE, "> $ofile") or die "can't open $ofile"; open(INPUT_FILE, "< $ifile") or die "can't open $ifile"; while() { s/\@MODULE\@/$module_name/g; s/\@MODULE_DESC\@/$module_desc/g; s/\@HEADER_FILE\@/$output_header/g; s/\@HEADER_USER\@/$header_user/g; s/\@RECORD_CALLBACKS\@/$record_callbacks/g; s/\@RECORD_FUNCTIONS\@/$record_functions/g; s/\@SAMPLING_FUNCTIONS\@/$sampling_functions/g; s/\@POST_INIT\@/$post_init/g; s/\@RECORD_INTERCEPTS\@/$record_intercepts/g; s/\@EVENT_DEFINITION\@/$event_definition/g; s/\@MODULE_ID\@/$module_id/g; s/\@CONVERT_FUNCTIONS_PROTOTYPES\@/$convert_functions_prototypes/g; s/\@CONVERT_FUNCTIONS_BODY\@/$convert_function_body/g; s/\@CONVERT_CASE\@/$convert_case/g; s/\@CONVERT_INIT\@/$convert_init/g; s/\@CUSTOM_CFLAGS\@/$common_cflags/g; s/\@CUSTOM_LDFLAGS\@/$common_ldflags/g; s/\@CONVERT_LDFLAGS\@/$convert_ldflags/g; s/\@RECORD_LDFLAGS\@/$record_ldflags/g; (print OUTPUT_FILE $_); } close(OUTPUT_FILE) or die "can't close $ofile"; close(INPUT_FILE) or die "can't close $ifile"; } end_module: `mkdir -p $output_dir`; my $input_file; my $input_makefile; if($module_type eq "LIBRARY") { $input_file = "${input_dir}/example.c.template"; $input_makefile = "${input_dir}/Makefile.template"; } my $input_eztrace_file="${input_dir}/eztrace_convert_example.c.template"; my $input_header="${input_dir}/example_ev_codes.h.template"; $output_header="${module_name}_ev_codes.h"; $output_eztrace_file="eztrace_convert_${module_name}.c"; $output_file="${module_name}.c"; $output_makefile="Makefile"; apply_changes($input_file, "$output_dir/$output_file"); apply_changes($input_eztrace_file, "$output_dir/$output_eztrace_file"); apply_changes($input_header, "$output_dir/$output_header"); apply_changes($input_makefile, "$output_dir/$output_makefile"); __DATA__ =head1 NAME eztrace_create_plugin - Generate EZTrace plugins =head1 SYNOPSIS Generate EZTrace plugins. eztrace_create_plugin [options] file Options: -I, --include_dir include directories -o, --ouput output directory -h, --help brief help message --man full documentation =head1 OPTIONS =over 8 =item B<-I , --include_dir=> Add specific include directories for the compilation of the generated code. =item B<-o , --output=> Select the output directory. =item B<-h --help> Print a brief help message and exits. =item B<--man> Prints the manual page and exits. =back =head1 DESCRIPTION B will read the given input file(s) and do something useful with the contents thereof. =cut eztrace-1.1-2/src/core/eztrace_hierarchical_array.c000066400000000000000000000102661265506773700224120ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #include #include #include "eztrace_stats_core.h" #include "eztrace_hierarchical_array.h" #define MAX_ARRAYS 16 #define DEFAULT_ALLOC_NB 128 /* todo: make this dynamic */ static struct hierarchical_array root_arrays[MAX_ARRAYS]; static unsigned nb_arrays = 0; struct hierarchical_array* hierarchical_array_find( eztrace_counter_id counter_id, p_eztrace_container p_cont) { struct hierarchical_array* arrays = root_arrays; if (p_cont) arrays = p_cont->arrays; unsigned int i; for (i = 0; i < nb_arrays; i++) { if (arrays[i].id == counter_id) return &arrays[i]; } return NULL; } static void __hierarchical_array_expand(struct hierarchical_array* p_array, unsigned nb_item_to_alloc) { p_array->nb_allocated += nb_item_to_alloc; /* initialize the new array */ struct hierarchical_array_data* new_array = malloc( sizeof(struct hierarchical_array_data)); new_array->p_array = p_array; new_array->next = NULL; new_array->nb_allocated = nb_item_to_alloc; new_array->nb_items = 0; new_array->values = malloc(p_array->item_size * nb_item_to_alloc); /* insert the new array at the end of p_array */ if (p_array->last) { p_array->last->next = new_array; p_array->last = p_array->last->next; } else { /* the array is empty */ p_array->first = new_array; p_array->last = new_array; } } static void __hierarchical_array_init(struct hierarchical_array* p_array, eztrace_counter_id id, unsigned item_size) { assert(p_array); p_array->id = id; p_array->item_size = item_size; p_array->nb_items = 0; p_array->nb_allocated = 0; p_array->first = NULL; p_array->last = NULL; __hierarchical_array_expand(p_array, DEFAULT_ALLOC_NB); } /* Create a new counter whose id is counter_id. This counter contains vectors that consist in * vector_size items. The names of each of the vector item are stores in names */ void hierarchical_array_attach(eztrace_counter_id counter_id, unsigned item_size) { if (nb_arrays >= MAX_ARRAYS) { fprintf(stderr, "Too many arrays\n"); exit(1); } struct hierarchical_array *cur_array = &root_arrays[nb_arrays]; /* check wether counter_id isn't already used */ if (hierarchical_array_find(counter_id, NULL)) { fprintf(stderr, "Error: Counter %d is already used!\n", counter_id); abort(); } /* initialize the array structure */ __hierarchical_array_init(cur_array, counter_id, item_size); nb_arrays++; } /* Allocate counters in a newly created container */ void hierarchical_array_new_container(p_eztrace_container p_cont) { assert(p_cont); p_cont->arrays = malloc(sizeof(struct hierarchical_array) * nb_arrays); unsigned int i; for (i = 0; i < nb_arrays; i++) { __hierarchical_array_init(&(p_cont->arrays[i]), root_arrays[i].id, root_arrays[i].item_size); } } /* return the number of items in the array (for a specific container) */ unsigned hierarchical_array_size(p_eztrace_container p_cont, eztrace_counter_id counter_id) { struct hierarchical_array* array = hierarchical_array_find(counter_id, p_cont); assert(array); return array->nb_items; } /* return the ith items of an array (for a specific container) */ void* hierarchical_array_get_item(p_eztrace_container p_cont, eztrace_counter_id counter_id, unsigned index) { struct hierarchical_array* array = hierarchical_array_find(counter_id, p_cont); assert(array); assert(array->nb_items > index); return ITH_ITEM(index, array); } /* return a new item of an array (for a specific container) */ void* hierarchical_array_new_item(p_eztrace_container p_cont, eztrace_counter_id counter_id) { struct hierarchical_array* array = hierarchical_array_find(counter_id, p_cont); assert(array); if (array->nb_items >= array->nb_allocated) { /* no space left in the array, expand it */ __hierarchical_array_expand(array, array->nb_allocated); assert(array->nb_items < array->nb_allocated); } void* res = ITH_ITEM(array->nb_items, array); array->nb_items++; return res; } eztrace-1.1-2/src/core/eztrace_hierarchical_array.h000066400000000000000000000047511265506773700224210ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_HIERARCHICAL_ARRAY_H #define EZTRACE_HIERARCHICAL_ARRAY_H #include #include "eztrace_convert.h" #include "eztrace_stats_core.h" struct hierarchical_array; struct hierarchical_array_data { struct hierarchical_array *p_array; struct hierarchical_array_data *next; unsigned nb_allocated; unsigned nb_items; void* values; }; struct hierarchical_array { eztrace_counter_id id; unsigned item_size; unsigned nb_items; unsigned nb_allocated; struct hierarchical_array_data *first; struct hierarchical_array_data *last; }; /* return the ith item of a hierarchical array */ static inline void* ITH_ITEM(int index, struct hierarchical_array* p_array) { unsigned i = index; /* todo: start from the end ? */ struct hierarchical_array_data *p_data = p_array->first; while (p_data) { if (i >= p_data->nb_allocated) { /* not in this array, go to the next one */ i = i - p_data->nb_allocated; p_data = p_data->next; } else { return (void*) (p_data->values + (i * p_array->item_size)); } } assert(1); return NULL; } /* Create a new counter whose id is counter_id. This counter contains vectors that consist in * vector_size items. The names of each of the vector item are stores in names */ void hierarchical_array_attach(eztrace_counter_id counter_id, unsigned item_size); /* Allocate counters in a newly created container */ void hierarchical_array_new_container(p_eztrace_container p_cont); /* return the number of items in the array (for a specific container) */ unsigned hierarchical_array_size(p_eztrace_container p_cont, eztrace_counter_id counter_id); /* return the ith items of an array (for a specific container) */ void* hierarchical_array_get_item(p_eztrace_container p_cont, eztrace_counter_id counter_id, unsigned index); /* return a new item of an array (for a specific container) */ void* hierarchical_array_new_item(p_eztrace_container p_cont, eztrace_counter_id counter_id); struct hierarchical_array* hierarchical_array_find( eztrace_counter_id counter_id, p_eztrace_container p_cont); #endif /* EZTRACE_HIERARCHICAL_ARRAY_H */ eztrace-1.1-2/src/core/eztrace_hook.h000066400000000000000000000100561265506773700175400ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_HOOK_H #define EZTRACE_HOOK_H #include #include "eztrace.h" #include "eztrace_list.h" /* * This file defines a hook mechanism that allow different modules * (ie. eztrace_convert_mpi, eztrace_convert_gomp, etc.) to add * information in EZTrace internal structures. This allows to add * specialized information (such as the current parallel section in * case OpenMP is being used) to any general purpose structure. */ struct ezt_hook_list_t; typedef uint8_t ezt_hook_id_t; struct ezt_hook_t { ezt_hook_id_t hook_id; void* data; struct ezt_hook_list_t* p_hook_list; struct ezt_list_token_t list_token; }; struct ezt_hook_list_t { struct ezt_list_t hook_list; }; /* initialize a hook list */ static inline void ezt_hook_list_init(struct ezt_hook_list_t *p_list); /* free the hook structure. before calling this function, make sure all * the data pointers have been freed. */ static inline void ezt_hook_list_free(struct ezt_hook_list_t *p_list); /* add a new hook to the list. */ static inline void ezt_hook_list_add(struct ezt_hook_list_t *p_list, void*p_data, ezt_hook_id_t hook_id); /* remove a hook from the list. Return 0 if the hook cannot be found in the list */ static inline int ezt_hook_list_remove(struct ezt_hook_list_t *p_list, ezt_hook_id_t hook_id); /* retrive the data corresponding to a hook id or NULL if the hook is not in the list */ static inline void* ezt_hook_list_retrieve_data( struct ezt_hook_list_t *p_hook_list, ezt_hook_id_t hook_id); /* initialize a hook list */ static inline void ezt_hook_list_init(struct ezt_hook_list_t *p_list) { ezt_list_new(&p_list->hook_list); } /* free the hook structure. before calling this function, make sure all * the data pointers have been freed. */ static inline void ezt_hook_list_free(struct ezt_hook_list_t *p_list) { struct ezt_list_token_t *p_token, *temp; ezt_list_foreach_safe(&p_list->hook_list, p_token, temp) { struct ezt_hook_t *p_hook = ezt_container_of(p_token, struct ezt_hook_t, list_token); ezt_list_remove(&p_hook->list_token); if (p_hook->data) free(p_hook->data); free(p_hook); } } /* add a new hook to the list. */ static inline void ezt_hook_list_add(struct ezt_hook_list_t *p_list, void*p_data, ezt_hook_id_t hook_id) { #if DEBUG if( ezt_hook_list_retrieve_data(p_list, hook_id)) { fprintf(stderr, "Trying to add a hook (id %d) in a list that already contains it\n", hook_id); abort(); } #endif /* DEBUG */ struct ezt_hook_t *p_hook = (struct ezt_hook_t*) malloc( sizeof(struct ezt_hook_t)); p_hook->hook_id = hook_id; p_hook->p_hook_list = p_list; p_hook->data = p_data; ezt_list_add(&p_list->hook_list, &p_hook->list_token); return; } /* remove a hook from the list. Return 0 if the hook cannot be found in the list */ static inline int ezt_hook_list_remove(struct ezt_hook_list_t *p_list, ezt_hook_id_t hook_id) { struct ezt_list_token_t *p_token, *temp; ezt_list_foreach_safe(&p_list->hook_list, p_token, temp) { struct ezt_hook_t *p_hook = ezt_container_of(p_token, struct ezt_hook_t, list_token); if (p_hook->hook_id == hook_id) { ezt_list_remove(&p_hook->list_token); free(p_hook); return 1; } } return 0; } /* retrive the data corresponding to a hook id or NULL if the hook is not in the list */ static inline void* ezt_hook_list_retrieve_data(struct ezt_hook_list_t *p_list, ezt_hook_id_t hook_id) { int i = 0; struct ezt_list_token_t *p_token; ezt_list_foreach(&p_list->hook_list, p_token) { i++; struct ezt_hook_t *p_hook = ezt_container_of(p_token, struct ezt_hook_t, list_token); if (p_hook->hook_id == hook_id) return p_hook->data; } return NULL; } #endif /* EZTRACE_HOOK_H */ eztrace-1.1-2/src/core/eztrace_indent_fortran000077500000000000000000000026431265506773700213740ustar00rootroot00000000000000#!/usr/bin/perl -w use strict; use warnings; #############################################################" package main; sub indent_file( $$ ) { my $input_handle = shift; my $output_handle = shift; my $concatenate=0; my $current_concatenation=""; while(<$input_handle>) { my $currentLine = $_; if($currentLine =~ m/^\s*subroutine.+\(/) { $concatenate=1; $current_concatenation=""; } if($concatenate == 1) { $currentLine=~ s/\n//; $currentLine=~ s/^\s*>//; $currentLine=~ s/^\s*\$//; $currentLine=~ s/^\s+//g; $current_concatenation.=$currentLine; if($currentLine =~ m/\)/) { # end of the subroutine prototype $concatenate=0; $currentLine=$current_concatenation."\n"; } } if($concatenate==0) { printf $output_handle "%s", $currentLine; } } } if(@ARGV < 1) { printf STDERR "Usage: $0 input_file [output_file]\n"; exit 1; } my $output_file; my $input_file=$ARGV[0]; my $input_handle; my $output_handle; if(@ARGV != 2) { $output_handle=*STDOUT; } else { $output_file=$ARGV[1]; open($output_handle, '>', $output_file) or die "Couldn't open $output_file for writing!"; } open($input_handle, '<', $input_file) or die "Couldn't open $input_file for reading!"; indent_file($input_handle, $output_handle); if(@ARGV == 2) { close($output_handle); printf "Output trace: %s\n", $output_file; } close($input_handle); eztrace-1.1-2/src/core/eztrace_list.h000066400000000000000000000042401265506773700175510ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_LIST_H #define EZTRACE_LIST_H #include struct ezt_list_t; struct ezt_list_token_t { /* pointer to the user data */ void *data; /* pointer to the list */ struct ezt_list_t *list; /* pointer to the next token in the list */ struct ezt_list_token_t* next; /* pointer to the previous token in the list */ struct ezt_list_token_t* prev; }; struct ezt_list_t { struct ezt_list_token_t *head; struct ezt_list_token_t *tail; int nb_item; }; /* return true if the list is empty */ #define ezt_list_empty(l) ((l)->head == NULL) /* iterate over the list */ #define ezt_list_foreach(l, t) for(t = (l)->head; t != NULL; t = (t)->next) /* same as list_foreach, but supports list modifications * for each iteration, t is the current value (that can be removed from the list) * n is the next value (that should not be modified!) */ #define ezt_list_foreach_safe(l, t, n) for(t = (l)->head, (n) = ((l)->head?t->next:NULL); \ t != NULL; \ t = n, (n) = t?(t)->next:NULL) /* return the first token of the list */ #define ezt_list_get_head(l) ((l)->head) /* return the last token of the list */ #define ezt_list_get_tail(l) ((l)->tail) /* initialize a list */ static inline void ezt_list_new(struct ezt_list_t*l) { l->head = NULL; l->tail = NULL; l->nb_item = 0; } /* add a new token at the list tail */ static inline void ezt_list_add(struct ezt_list_t*l, struct ezt_list_token_t *n) { /* initialize the new token */ n->list = l; n->next = NULL; n->prev = l->tail; if (ezt_list_empty(l)) { l->head = n; } else { l->tail->next = n; } l->tail = n; l->nb_item++; } /* remove a token from the list */ static inline void ezt_list_remove(struct ezt_list_token_t *t) { if (t->prev) t->prev->next = t->next; else t->list->head = t->next; if (t->next) t->next->prev = t->prev; else t->list->tail = t->prev; if (t->list->head && !t->list->tail) abort(); t->list->nb_item--; } #endif /* EZTRACE_LIST_H */ eztrace-1.1-2/src/core/eztrace_litl.h000066400000000000000000000240151265506773700175440ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef __EZTRACE_LITL_H__ #define __EZTRACE_LITL_H__ #include "eztrace.h" #include "litl_read.h" #include "litl_types.h" #include "litl_write.h" #define GET_PARAM(p_ev, num_param) LITL_READ_REGULAR(p_ev)->param[(num_param)] #define GET_NBPARAMS(p_ev) LITL_READ_REGULAR(p_ev)->nb_params #define GET_PARAM_RAW(p_ev, ptr) do { \ memcpy(ptr, LITL_READ_RAW(p_ev)->data, LITL_READ_RAW(p_ev)->size); \ } while(0) #define CHECK_RETVAL(f) do { \ void* retval = NULL; \ if(__ezt_trace.status == ezt_trace_status_running || \ __ezt_trace.status == ezt_trace_status_paused || \ __ezt_trace.status == ezt_trace_status_being_finalized) { \ retval = f; \ if(! retval){ \ fprintf(stderr, "[EZTrace] The buffer for recording events is full. Stop recording. The trace will be truncated\n");\ __ezt_trace.status = ezt_trace_status_stopped; \ } \ } \ } while(0) #define EZTRACE_EVENT_RAW(code, arg1) \ EZTRACE_EVENT_RAW_DATA(code, strlen(arg1) + 1, arg1) #define EZTRACE_EVENT_RAW_DATA(code, nbytes, arg1) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ litl_write_probe_raw(__ezt_trace.litl_trace, code, nbytes, (litl_data_t *) arg1); \ EZTRACE_PROTECT_OFF(); \ } \ } /* create an event without any data */ #define EZTRACE_EVENT0_UNPROTECTED(code) CHECK_RETVAL(litl_write_probe_reg_0(__ezt_trace.litl_trace, code)) /* create an event with one value */ #define EZTRACE_EVENT1_UNPROTECTED(code, arg1) \ CHECK_RETVAL(litl_write_probe_reg_1(__ezt_trace.litl_trace, code, (litl_param_t)arg1)) /* create an event with two value */ #define EZTRACE_EVENT2_UNPROTECTED(code, arg1, arg2) \ CHECK_RETVAL(litl_write_probe_reg_2(__ezt_trace.litl_trace, code, (litl_param_t)arg1, (litl_param_t)arg2)) /* etc. */ #define EZTRACE_EVENT3_UNPROTECTED(code, arg1, arg2, arg3) \ CHECK_RETVAL(litl_write_probe_reg_3(__ezt_trace.litl_trace, code, (litl_param_t) arg1, \ (litl_param_t) arg2, (litl_param_t) arg3)) #define EZTRACE_EVENT4_UNPROTECTED(code, arg1, arg2, arg3, arg4) \ CHECK_RETVAL(litl_write_probe_reg_4(__ezt_trace.litl_trace, code, (litl_param_t) arg1, \ (litl_param_t) arg2, (litl_param_t) arg3, \ (litl_param_t) arg4)) #define EZTRACE_EVENT5_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5) \ CHECK_RETVAL(litl_write_probe_reg_5(__ezt_trace.litl_trace, code, (litl_param_t) arg1, \ (litl_param_t) arg2, (litl_param_t) arg3, \ (litl_param_t) arg4, (litl_param_t) arg5)) #define EZTRACE_EVENT6_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6) \ CHECK_RETVAL(litl_write_probe_reg_6(__ezt_trace.litl_trace, code, (litl_param_t) arg1, \ (litl_param_t) arg2, (litl_param_t) arg3, \ (litl_param_t) arg4, (litl_param_t) arg5, \ (litl_param_t) arg6)) #define EZTRACE_EVENT7_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7) \ CHECK_RETVAL(litl_write_probe_reg_7(__ezt_trace.litl_trace, code, (litl_param_t) arg1, \ (litl_param_t) arg2, (litl_param_t) arg3, \ (litl_param_t) arg4, (litl_param_t) arg5, \ (litl_param_t) arg6, (litl_param_t) arg7)) #define EZTRACE_EVENT8_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8) \ CHECK_RETVAL(litl_write_probe_reg_8(__ezt_trace.litl_trace, code, (litl_param_t) arg1, \ (litl_param_t) arg2, (litl_param_t) arg3, \ (litl_param_t) arg4, (litl_param_t) arg5, \ (litl_param_t) arg6, (litl_param_t) arg7, \ (litl_param_t) arg8)) #define EZTRACE_EVENT9_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9) \ CHECK_RETVAL(litl_write_probe_reg_9(__ezt_trace.litl_trace, code, (litl_param_t) arg1, \ (litl_param_t) arg2, (litl_param_t) arg3, \ (litl_param_t) arg4, (litl_param_t) arg5, \ (litl_param_t) arg6, (litl_param_t) arg7, \ (litl_param_t) arg8, (litl_param_t) arg9)) #define EZTRACE_EVENT0(code) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT0_UNPROTECTED(code); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT1(code, arg1) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT1_UNPROTECTED(code, arg1); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT2(code, arg1, arg2) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT2_UNPROTECTED(code, arg1, arg2); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT3(code, arg1, arg2, arg3) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT3_UNPROTECTED(code, arg1, arg2, arg3); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT4(code, arg1, arg2, arg3, arg4) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT4_UNPROTECTED(code, arg1, arg2, arg3, arg4); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT5(code, arg1, arg2, arg3, arg4, arg5) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT5_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT6(code, arg1, arg2, arg3, arg4, arg5, arg6) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT6_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT7(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT7_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT8(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT8_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT9(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT9_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_FORCE_RECORD_EVENT0(code) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT0_UNPROTECTED(code); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_FORCE_RECORD_EVENT1(code, arg1) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT1_UNPROTECTED(code, arg1); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_FORCE_RECORD_EVENT2(code, arg1, arg2) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT2_UNPROTECTED(code, arg1, arg2); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_FORCE_RECORD_EVENT3(code, arg1, arg2, arg3) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT3_UNPROTECTED(code, arg1, arg2, arg3); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_FORCE_RECORD_EVENT4(code, arg1, arg2, arg3, arg4) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT4_UNPROTECTED(code, arg1, arg2, arg3, arg4); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_FORCE_RECORD_EVENT5(code, arg1, arg2, arg3, arg4, arg5) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT5_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_FORCE_RECORD_EVENT6(code, arg1, arg2, arg3, arg4, arg5, arg6) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT6_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_FORCE_RECORD_EVENT7(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT7_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_FORCE_RECORD_EVENT8(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT8_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_FORCE_RECORD_EVENT9(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT9_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9); \ EZTRACE_PROTECT_OFF(); \ } \ } #endif /* __EZTRACE_LITL_H__ */ eztrace-1.1-2/src/core/eztrace_litl_packed.h000066400000000000000000000262221265506773700210550ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_LITL_PACKED_H #define EZTRACE_LITL_PACKED_H #include "eztrace.h" #include "litl_types.h" #include "litl_write.h" #include "litl_read.h" #define CHECK_RETVAL_PACKED(f) \ do { \ void* retval = NULL; \ if(__ezt_trace.status == ezt_trace_status_running || \ __ezt_trace.status == ezt_trace_status_being_finalized || \ __ezt_trace.status == ezt_trace_status_paused ) { \ f; \ if(! retval){ \ fprintf(stderr, "[EZTrace] The buffer for recording events is full. Stop recording. The trace will be truncated\n");\ __ezt_trace.status = ezt_trace_status_stopped; \ } \ } \ } while(0) #define EZTRACE_EVENT0_PACKED_UNPROTECTED(code) do { \ EZT_PRINTF(5, "EZTRACE_EVENT0_PACKED(code=%x)\n", code); \ CHECK_RETVAL_PACKED(litl_write_probe_pack_0(__ezt_trace.litl_trace, code, retval)); \ } while(0) #define EZTRACE_EVENT1_PACKED_UNPROTECTED(code, arg1) do { \ EZT_PRINTF(5, "EZTRACE_EVENT1_PACKED(code=%x)\n", code); \ CHECK_RETVAL_PACKED(litl_write_probe_pack_1(__ezt_trace.litl_trace, code, arg1, retval)); \ }while(0) #define EZTRACE_EVENT2_PACKED_UNPROTECTED(code, arg1, arg2) do { \ EZT_PRINTF(5, "EZTRACE_EVENT2_PACKED(code=%x)\n", code); \ CHECK_RETVAL_PACKED(litl_write_probe_pack_2(__ezt_trace.litl_trace, code, arg1, arg2, retval)); \ } while(0) #define EZTRACE_EVENT3_PACKED_UNPROTECTED(code, arg1, arg2, arg3) do { \ EZT_PRINTF(5, "EZTRACE_EVENT3_PACKED(code=%x)\n", code); \ CHECK_RETVAL_PACKED(litl_write_probe_pack_3(__ezt_trace.litl_trace, code, arg1, arg2, arg3, retval)); \ } while(0) #define EZTRACE_EVENT4_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4) do { \ EZT_PRINTF(5, "EZTRACE_EVENT4_PACKED(code=%x)\n", code); \ CHECK_RETVAL_PACKED(litl_write_probe_pack_4(__ezt_trace.litl_trace, code, arg1, arg2, arg3, arg4, retval)); \ } while(0) #define EZTRACE_EVENT5_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5) do { \ EZT_PRINTF(5, "EZTRACE_EVENT5_PACKED(code=%x)\n", code); \ CHECK_RETVAL_PACKED(litl_write_probe_pack_5(__ezt_trace.litl_trace, code, arg1, arg2, arg3, arg4, arg5, retval)); \ } while(0) #define EZTRACE_EVENT6_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6) do { \ EZT_PRINTF(5, "EZTRACE_EVENT6_PACKED(code=%x)\n", code); \ CHECK_RETVAL_PACKED(litl_write_probe_pack_6(__ezt_trace.litl_trace, code, arg1, arg2, arg3, arg4, arg5, arg6, retval)); \ } while(0) #define EZTRACE_EVENT7_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7) do { \ EZT_PRINTF(5, "EZTRACE_EVENT7_PACKED(code=%x)\n", code); \ CHECK_RETVAL_PACKED(litl_write_probe_pack_7(__ezt_trace.litl_trace, code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, retval)); \ } while(0) #define EZTRACE_EVENT8_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8) do { \ EZT_PRINTF(5, "EZTRACE_EVENT8_PACKED(code=%x)\n", code); \ CHECK_RETVAL_PACKED(litl_write_probe_pack_8(__ezt_trace.litl_trace, code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, retval)); \ } while(0) #define EZTRACE_EVENT9_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9) do { \ EZT_PRINTF(5, "EZTRACE_EVENT9_PACKED(code=%x)\n", code); \ CHECK_RETVAL_PACKED(litl_write_probe_pack_9(__ezt_trace.litl_trace, code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9, retval)); \ } while(0) #define GET_PARAM_PACKED_1(p_ev, arg1) do { \ litl_read_get_param_1(p_ev, arg1); \ } while(0) #define GET_PARAM_PACKED_2(p_ev, arg1, arg2) do { \ litl_read_get_param_2(p_ev, arg1, arg2); \ } while(0) #define GET_PARAM_PACKED_3(p_ev, arg1, arg2, arg3) do { \ litl_read_get_param_3(p_ev, arg1, arg2, arg3); \ } while(0) #define GET_PARAM_PACKED_4(p_ev, arg1, arg2, arg3, arg4) do { \ litl_read_get_param_4(p_ev, arg1, arg2, arg3, arg4); \ } while(0) #define GET_PARAM_PACKED_5(p_ev, arg1, arg2, arg3, arg4, arg5) do { \ litl_read_get_param_5(p_ev, arg1, arg2, arg3, arg4, arg5); \ } while(0) #define GET_PARAM_PACKED_6(p_ev, arg1, arg2, arg3, arg4, arg5, arg6) do { \ litl_read_get_param_6(p_ev, arg1, arg2, arg3, arg4, arg5, arg6); \ } while(0) #define GET_PARAM_PACKED_7(p_ev, arg1, arg2, arg3, arg4, arg5, arg6, arg7) do { \ litl_read_get_param_7(p_ev, arg1, arg2, arg3, arg4, arg5, arg6, arg7); \ } while(0) #define GET_PARAM_PACKED_8(p_ev, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8) do { \ litl_read_get_param_8(p_ev, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8); \ } while(0) #define GET_PARAM_PACKED_9(p_ev, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9) do { \ litl_read_get_param_9(p_ev, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9); \ } while(0) #define EZTRACE_EVENT_FORCE_RECORD_PACKED_0(code) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT0_PACKED_UNPROTECTED(code); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_FORCE_RECORD_PACKED_1(code, arg1) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT1_PACKED_UNPROTECTED(code, arg1); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_FORCE_RECORD_PACKED_2(code, arg1, arg2) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT2_PACKED_UNPROTECTED(code, arg1, arg2); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_FORCE_RECORD_PACKED_3(code, arg1, arg2, arg3) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT3_PACKED_UNPROTECTED(code, arg1, arg2, arg3); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_FORCE_RECORD_PACKED_4(code, arg1, arg2, arg3, arg4) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT4_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_FORCE_RECORD_PACKED_5(code, arg1, arg2, arg3, arg4, arg5) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT5_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_FORCE_RECORD_PACKED_6(code, arg1, arg2, arg3, arg4, arg5, arg6) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT6_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_FORCE_RECORD_PACKED_7(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT7_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_FORCE_RECORD_PACKED_8(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT8_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_FORCE_RECORD_PACKED_9(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ EZTRACE_EVENT9_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9); \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_PACKED_0(code) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT0_PACKED_UNPROTECTED(code); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_PACKED_1(code, arg1) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT1_PACKED_UNPROTECTED(code, arg1); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_PACKED_2(code, arg1, arg2) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT2_PACKED_UNPROTECTED(code, arg1, arg2); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_PACKED_3(code, arg1, arg2, arg3) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT3_PACKED_UNPROTECTED(code, arg1, arg2, arg3); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_PACKED_4(code, arg1, arg2, arg3, arg4) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT4_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_PACKED_5(code, arg1, arg2, arg3, arg4, arg5) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT5_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_PACKED_6(code, arg1, arg2, arg3, arg4, arg5, arg6) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT6_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_PACKED_7(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT7_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_PACKED_8(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT8_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #define EZTRACE_EVENT_PACKED_9(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9) \ { \ EZTRACE_PROTECT { \ EZTRACE_PROTECT_ON(); \ if (__ezt_trace.status != ezt_trace_status_paused) { \ EZTRACE_EVENT9_PACKED_UNPROTECTED(code, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9); \ } \ EZTRACE_PROTECT_OFF(); \ } \ } #endif /* EZTRACE_LITL_PACKED_H */ eztrace-1.1-2/src/core/eztrace_loaded.c000066400000000000000000000015531265506773700200250ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #include #include #include #include "eztrace_convert_core.h" /* This program list the available modules */ static void usage(int argc __attribute__((unused)), char **argv) { fprintf(stderr, "Usage : %s -h \n", argv[0]); } static void parse_args(int argc, char **argv) { int i; for (i = 1; i < argc; i++) { if (strcmp(argv[i], "-h") == 0) { usage(argc, argv); exit(-1); } else if (strcmp(argv[i], "-v") == 0) { printf("Verbose mode turned on\n"); (*get_verbose()) = 1; } } } int main(int argc, char**argv) { /* parse the arguments passed to this program */ parse_args(argc, argv); load_modules(0); eztrace_convert_list(); return 0; } eztrace-1.1-2/src/core/eztrace_plugin_generator000066400000000000000000000153641265506773700217250ustar00rootroot00000000000000#!/usr/bin/perl -w # Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. use File::Temp qw/ tempfile tempdir /; use File::Copy; my $prefix; my $exec_prefix; my $libdir; my $includedir; my $bindir; BEGIN { $prefix="/home/trahay/Soft/opt/eztrace/master/build/../install"; $exec_prefix="${prefix}"; $libdir="${exec_prefix}/lib"; $includedir="${prefix}/include"; $bindir="${exec_prefix}/bin"; } my $indent_fortran="$prefix/bin/eztrace_indent_fortran"; # format a source file so that function prototypes # are properly formatted (eg. everything on line line) sub format_source_file( $ ) { my $fname = shift; my $fh; my $filename; my $suffix; if( $fname =~ m/.+\.c$/) { $suffix=".c"; } elsif( $fname =~ m/.+\.cpp$/) { $suffix=".cpp"; } elsif( $fname =~ m/.+\.f$/) { # todo .f77, .f90, .F, etc. $suffix=".f"; } ($fh, $filename) = tempfile(SUFFIX=>$suffix); copy($fname, $filename) or die "Copy failed: $!"; if($suffix eq ".c") { `indent -npsl --line-length10000 $filename`; } if($suffix eq ".cpp") { `indent -npsl --line-length10000 $filename`; } if($suffix eq ".f") { `$indent_fortran $fname $filename`; } return $filename; } # return the prototype of function $fname extracted from $filename sub extract_prototype( $$ ) { my $fname=shift; my $filename=shift; # in some cases, fname main contain (). Remove these parenthesis $fname =~ s/\(\s*\)//; # don't instrument the main function if($fname eq "main") { return ""; } # format the source code my $new_filename=format_source_file($filename); # extract symbols my $program_language; my $symbols=""; if ($new_filename =~ m/.\.c/) { $program_language="C"; $symbols=`ctags --c-kinds=pf --fields=+S -x $new_filename`; } elsif ($new_filename =~ m/.\.cpp/) { $program_language="CPP"; $symbols=`ctags --c++-kinds=pf --fields=+S -x $new_filename`; } elsif ($new_filename =~ m/.\.f/) { $prototype = "void ".$fname."()"; $symbols=`ctags --fortran-kinds=pfis --fields=+S -x $new_filename`; } else { # example: f90, c++, etc. # not implemented printf "Cannot extract information about function %s: file format not supported\n", $fname; printf "\tAssuming the function prototype is void %s()\n", $fname; $prototype = "void ".$fname."()"; unlink($new_filename); return $prototype; } my $fortran_fname=$fname; $fortran_fname=~ s/_$//; my @symbol_list = split('\n', $symbols); foreach $symbol(@symbol_list) { # each line should look like this: # function 22 if($symbol =~ m/^($fname)\s+(function)\s+\d+\s+\S+\s+(.+)/) { # fname was found. return the corresponding prototype ($prototype) = ($symbol =~ m/$fname\s+function\s+\d+\s+\S+\s+(.+)$/); unlink($new_filename); # remove any /* ... */ comment that we might have found $prototype =~ s/\/\*.*\*\///g; return $prototype; } # for fortran files, each line looks like this # subroutine 95 subroutine if($symbol =~ m/^($fortran_fname)\s+subroutine/) { # fname was found. return the corresponding prototype printf "$fname found in a subroutine\n"; ($prototype) = ($symbol =~ m/$fortran_fname\s+subroutine\s+\d+\s+\S+\s+(.+)$/); unlink($new_filename); # remove any /* ... */ comment that we might have found $prototype =~ s/\/\*.*\*\///g; # replace ^subroutine with void $prototype =~ s/^subroutine $fortran_fname/void $fname/; $prototype =~ s/>//g; # cast each parameter to int* $prototype =~ s/\(\s*(\S+)/\(int *$1/; $prototype =~ s/,/, int */g; if($prototype !~ m/\(/) { printf("Proto doesnt contain parenthesis!\n"); $prototype .= "( )"; } return $prototype; } } # not found unlink($new_filename); return ""; } if (@ARGV<1) { printf "Usage: eztrace_plugin_generator \n"; exit 1; } my $input_file=$ARGV[0]; my $input_file_parsed=$input_file; $input_file_parsed =~ s/\//_/g; $input_file_parsed =~ s/-/_/g; $input_file_parsed =~ s/\./_/g; my $output_file=$input_file_parsed.".tpl"; my $plugin_dir="plugin_".$input_file_parsed; my $module_name=$input_file_parsed; $module_name =~ s/\./_/g; open($output_handle, '>', $output_file) or die "Couldn't open $output_file for writing!"; printf $output_handle "BEGIN_MODULE\n"; printf $output_handle "NAME %s\n", $module_name; printf $output_handle "DESC \"Module for the %s program\"\n", $input_file; printf $output_handle "\n"; printf $output_handle "# In this section, insert the #include/#define directives that are needed for\n"; printf $output_handle "# compiling\n"; printf $output_handle "BEGIN_INCLUDE\n"; printf $output_handle "\n"; printf $output_handle "END_INCLUDE\n\n"; printf $output_handle "\n"; printf $output_handle "# In this section, insert the CFLAGS that are needed for compiling\n"; printf $output_handle "BEGIN_CFLAGS\n"; printf $output_handle "\n"; printf $output_handle "END_CFLAGS\n"; printf $output_handle "\n"; printf $output_handle "# In this section, insert the LDFLAGS that are needed for compiling\n"; printf $output_handle "BEGIN_LDFLAGS\n"; printf $output_handle "\n"; printf $output_handle "END_LDFLAGS\n"; printf $output_handle "\n"; my $symbols=`nm --demangle --defined -l $input_file`; my @symbol_list = split('\n', $symbols); my $nb_symbols=0; printf "Creating the plugin script %s\n", $output_file; foreach $symbol(@symbol_list) { if( $symbol =~ m/\s+T\s+(.+)\s+(.+)/ ) { ($fname, $file) = ( $symbol =~ m/\s+T\s+(\S+)\s+(.+):/ ); my $proto=extract_prototype($fname, $file); if ($proto ne "") { $nb_symbols++; printf "\tFound '%s'\n", $proto; printf $output_handle "%s\n\n", $proto; } } } printf $output_handle "END_MODULE\n"; close($output_handle); if ( $nb_symbols == 0) { # No symbol found printf "No symbol found!\n"; printf "Make sure the program contains debugging symbols (ie. compile it with -the -g option)\n"; exit ; } printf "%d symbols found\n", $nb_symbols; printf "\nGenerating the plugin...\n"; printf "\t\$ %s/eztrace_create_plugin -o %s %s\n", $bindir, $plugin_dir, $output_file; `$bindir/eztrace_create_plugin -o $plugin_dir $output_file`; if ( $? != 0) { die "Plugin creation failed !\n"; } printf "\nCompiling the plugin...\n"; printf "\t\$ make -C %s\n", $plugin_dir; `make -C $plugin_dir`; if ( $? != 0) { die "Compilation failed ! Please fix the ".$output_file." template file and re-run the eztrace_create_plugin command\n"; } printf "\nYou can now use the generated plugin by setting the following environment variables:\n"; printf "\t\$ export EZTRACE_LIBRARY_PATH=\$EZTRACE_LIBRARY_PATH:%s\n", `readlink -f $plugin_dir`; eztrace-1.1-2/src/core/eztrace_plugin_generator.in000077500000000000000000000152621265506773700223320ustar00rootroot00000000000000#!/usr/bin/perl -w # Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. use File::Temp qw/ tempfile tempdir /; use File::Copy; my $prefix; my $exec_prefix; my $libdir; my $includedir; my $bindir; BEGIN { $prefix="@prefix@"; $exec_prefix="@exec_prefix@"; $libdir="@libdir@"; $includedir="@includedir@"; $bindir="@bindir@"; } my $indent_fortran="$prefix/bin/eztrace_indent_fortran"; # format a source file so that function prototypes # are properly formatted (eg. everything on line line) sub format_source_file( $ ) { my $fname = shift; my $fh; my $filename; my $suffix; if( $fname =~ m/.+\.c$/) { $suffix=".c"; } elsif( $fname =~ m/.+\.cpp$/) { $suffix=".cpp"; } elsif( $fname =~ m/.+\.f$/) { # todo .f77, .f90, .F, etc. $suffix=".f"; } ($fh, $filename) = tempfile(SUFFIX=>$suffix); copy($fname, $filename) or die "Copy failed: $!"; if($suffix eq ".c") { `indent -npsl --line-length10000 $filename`; } if($suffix eq ".cpp") { `indent -npsl --line-length10000 $filename`; } if($suffix eq ".f") { `$indent_fortran $fname $filename`; } return $filename; } # return the prototype of function $fname extracted from $filename sub extract_prototype( $$ ) { my $fname=shift; my $filename=shift; # in some cases, fname main contain (). Remove these parenthesis $fname =~ s/\(\s*\)//; # don't instrument the main function if($fname eq "main") { return ""; } # format the source code my $new_filename=format_source_file($filename); # extract symbols my $program_language; my $symbols=""; if ($new_filename =~ m/.\.c/) { $program_language="C"; $symbols=`ctags --c-kinds=pf --fields=+S -x $new_filename`; } elsif ($new_filename =~ m/.\.cpp/) { $program_language="CPP"; $symbols=`ctags --c++-kinds=pf --fields=+S -x $new_filename`; } elsif ($new_filename =~ m/.\.f/) { $prototype = "void ".$fname."()"; $symbols=`ctags --fortran-kinds=pfis --fields=+S -x $new_filename`; } else { # example: f90, c++, etc. # not implemented printf "Cannot extract information about function %s: file format not supported\n", $fname; printf "\tAssuming the function prototype is void %s()\n", $fname; $prototype = "void ".$fname."()"; unlink($new_filename); return $prototype; } my $fortran_fname=$fname; $fortran_fname=~ s/_$//; my @symbol_list = split('\n', $symbols); foreach $symbol(@symbol_list) { # each line should look like this: # function 22 if($symbol =~ m/^($fname)\s+(function)\s+\d+\s+\S+\s+(.+)/) { # fname was found. return the corresponding prototype ($prototype) = ($symbol =~ m/$fname\s+function\s+\d+\s+\S+\s+(.+)$/); unlink($new_filename); # remove any /* ... */ comment that we might have found $prototype =~ s/\/\*.*\*\///g; return $prototype; } # for fortran files, each line looks like this # subroutine 95 subroutine if($symbol =~ m/^($fortran_fname)\s+subroutine/) { # fname was found. return the corresponding prototype printf "$fname found in a subroutine\n"; ($prototype) = ($symbol =~ m/$fortran_fname\s+subroutine\s+\d+\s+\S+\s+(.+)$/); unlink($new_filename); # remove any /* ... */ comment that we might have found $prototype =~ s/\/\*.*\*\///g; # replace ^subroutine with void $prototype =~ s/^subroutine $fortran_fname/void $fname/; $prototype =~ s/>//g; # cast each parameter to int* $prototype =~ s/\(\s*(\S+)/\(int *$1/; $prototype =~ s/,/, int */g; if($prototype !~ m/\(/) { printf("Proto doesnt contain parenthesis!\n"); $prototype .= "( )"; } return $prototype; } } # not found unlink($new_filename); return ""; } if (@ARGV<1) { printf "Usage: eztrace_plugin_generator \n"; exit 1; } my $input_file=$ARGV[0]; my $input_file_parsed=$input_file; $input_file_parsed =~ s/\//_/g; $input_file_parsed =~ s/-/_/g; $input_file_parsed =~ s/\./_/g; my $output_file=$input_file_parsed.".tpl"; my $plugin_dir="plugin_".$input_file_parsed; my $module_name=$input_file_parsed; $module_name =~ s/\./_/g; open($output_handle, '>', $output_file) or die "Couldn't open $output_file for writing!"; printf $output_handle "BEGIN_MODULE\n"; printf $output_handle "NAME %s\n", $module_name; printf $output_handle "DESC \"Module for the %s program\"\n", $input_file; printf $output_handle "\n"; printf $output_handle "# In this section, insert the #include/#define directives that are needed for\n"; printf $output_handle "# compiling\n"; printf $output_handle "BEGIN_INCLUDE\n"; printf $output_handle "\n"; printf $output_handle "END_INCLUDE\n\n"; printf $output_handle "\n"; printf $output_handle "# In this section, insert the CFLAGS that are needed for compiling\n"; printf $output_handle "BEGIN_CFLAGS\n"; printf $output_handle "\n"; printf $output_handle "END_CFLAGS\n"; printf $output_handle "\n"; printf $output_handle "# In this section, insert the LDFLAGS that are needed for compiling\n"; printf $output_handle "BEGIN_LDFLAGS\n"; printf $output_handle "\n"; printf $output_handle "END_LDFLAGS\n"; printf $output_handle "\n"; my $symbols=`nm --demangle --defined -l $input_file`; my @symbol_list = split('\n', $symbols); my $nb_symbols=0; printf "Creating the plugin script %s\n", $output_file; foreach $symbol(@symbol_list) { if( $symbol =~ m/\s+T\s+(.+)\s+(.+)/ ) { ($fname, $file) = ( $symbol =~ m/\s+T\s+(\S+)\s+(.+):/ ); my $proto=extract_prototype($fname, $file); if ($proto ne "") { $nb_symbols++; printf "\tFound '%s'\n", $proto; printf $output_handle "%s\n\n", $proto; } } } printf $output_handle "END_MODULE\n"; close($output_handle); if ( $nb_symbols == 0) { # No symbol found printf "No symbol found!\n"; printf "Make sure the program contains debugging symbols (ie. compile it with -the -g option)\n"; exit ; } printf "%d symbols found\n", $nb_symbols; printf "\nGenerating the plugin...\n"; printf "\t\$ %s/eztrace_create_plugin -o %s %s\n", $bindir, $plugin_dir, $output_file; `$bindir/eztrace_create_plugin -o $plugin_dir $output_file`; if ( $? != 0) { die "Plugin creation failed !\n"; } printf "\nCompiling the plugin...\n"; printf "\t\$ make -C %s\n", $plugin_dir; `make -C $plugin_dir`; if ( $? != 0) { die "Compilation failed ! Please fix the ".$output_file." template file and re-run the eztrace_create_plugin command\n"; } printf "\nYou can now use the generated plugin by setting the following environment variables:\n"; printf "\t\$ export EZTRACE_LIBRARY_PATH=\$EZTRACE_LIBRARY_PATH:%s\n", `readlink -f $plugin_dir`; eztrace-1.1-2/src/core/eztrace_sampling.c000066400000000000000000000104171265506773700204060ustar00rootroot00000000000000#include #include #include #include #include "eztrace_sampling.h" /* perform dest = src+interval on timeval structures */ #define UPDATE_TIMEVAL(dest, src, interval) do {\ (dest).tv_sec = (src).tv_sec + ((interval)/((unsigned)1e6)); \ (dest).tv_usec = (src).tv_usec + ((interval)%((unsigned)1e6)); \ } while(0) #define TIME_DIFF(t1, t2) \ ((t2.tv_sec - t1.tv_sec) * 1000000 + (t2.tv_usec - t1.tv_usec)) #define MAX_SAMPLING_CALLBACKS 100 static struct ezt_sampling_callback_instance callback_instances[MAX_SAMPLING_CALLBACKS]; static int nb_sampling_callbacks = 0; static struct timeval next_call={.tv_sec=0, .tv_usec=0}; struct __ezt_sampling_thread_instance { struct ezt_sampling_callback_instance callback[MAX_SAMPLING_CALLBACKS]; int nb_callbacks; struct timeval next_call; }; static pthread_key_t __ezt_sampling_thread_key; static pthread_once_t once_control; /* Initialize thread-specific data */ struct __ezt_sampling_thread_instance * __ezt_sampling_init_thread() { if(!nb_sampling_callbacks) /* nothing to process */ return NULL; static int first = 1; if(first) /* This is the first thread that is initialized. We need to create the pthread_key */ pthread_key_create(&__ezt_sampling_thread_key, NULL ); first = 0; struct __ezt_sampling_thread_instance * ptr = NULL; /* Allocate the thread-specific data */ ptr = malloc(sizeof(struct __ezt_sampling_thread_instance)); ptr->nb_callbacks = nb_sampling_callbacks; struct timeval cur_time; gettimeofday(&cur_time, NULL); /* copy the callbacks */ unsigned min_interval = callback_instances[0].interval; int i; for(i=0; i< ptr->nb_callbacks; i++) { if(callback_instances[i].interval < min_interval) min_interval = callback_instances[i].interval; ptr->callback[i].callback = callback_instances[i].callback; ptr->callback[i].interval = callback_instances[i].interval; UPDATE_TIMEVAL(ptr->callback[i].last_call, cur_time, 0); ptr->callback[i].plugin_data = NULL; } UPDATE_TIMEVAL(ptr->next_call, cur_time, min_interval); /* set the structure Thread-specific */ (void) pthread_setspecific(__ezt_sampling_thread_key, ptr); return ptr; } /* Calls registered callbacks if needed */ void ezt_sampling_check_callbacks() { if(nb_sampling_callbacks) { struct __ezt_sampling_thread_instance *ptr = NULL; struct timeval cur_time; gettimeofday(&cur_time, NULL ); pthread_once(&once_control, (void (*)(void))__ezt_sampling_init_thread); if ((ptr = pthread_getspecific(__ezt_sampling_thread_key)) == NULL ) { /* First time this thread check for callbacks */ ptr = __ezt_sampling_init_thread(); if (!ptr) { return; } } if(TIME_DIFF(cur_time, ptr->next_call) < 0) { /* we need to call add least one callback */ int i; /* browse the list of registered callbacks */ for(i=0; inb_callbacks; i++) { struct ezt_sampling_callback_instance *callback = &ptr->callback[i]; if(TIME_DIFF(callback->last_call, cur_time) >= (long long)callback->interval) { /* execute the callback */ int ret = callback->callback(callback); if(ret == 0) { /* update the timer */ UPDATE_TIMEVAL(callback->last_call, cur_time, 0); /* update ptr->next_call */ if(TIME_DIFF(cur_time, ptr->next_call) > callback->interval) { /* this callback is the next one */ UPDATE_TIMEVAL(ptr->next_call, cur_time, callback->interval); } } } } } } } /* todo: distinguish thread-specific callbacks from process-specific callbacks * todo: add the possibility to add an alarm */ /* interval: time in microsecond between calls to callback */ void ezt_sampling_register_callback(ezt_sampling_callback_t callback, unsigned interval) { nb_sampling_callbacks++; callback_instances[nb_sampling_callbacks-1].callback = callback; callback_instances[nb_sampling_callbacks-1].interval = interval; callback_instances[nb_sampling_callbacks-1].last_call.tv_sec = 0; callback_instances[nb_sampling_callbacks-1].last_call.tv_usec = 0; struct timeval cur_time; gettimeofday(&cur_time, NULL); if(TIME_DIFF(cur_time, next_call) > interval) { /* this callback is the next one */ UPDATE_TIMEVAL(next_call, cur_time, interval); } } eztrace-1.1-2/src/core/eztrace_sampling.h000066400000000000000000000025331265506773700204130ustar00rootroot00000000000000#ifndef EZTRACE_SAMPLING_H #define EZTRACE_SAMPLING_H #include struct ezt_sampling_callback_instance; /* The callback shall return 0 if successfull. * If successfull, eztrace core will wait interval microseconds before invoking * the callback again. * If unsuccessfull, eztrace core may invoke the callback at any time */ typedef int (*ezt_sampling_callback_t)(struct ezt_sampling_callback_instance*instance); /* This structure is passed to sampling callbacks. The callback should not modify any field apart * from plugin_data. */ struct ezt_sampling_callback_instance { ezt_sampling_callback_t callback; unsigned interval; struct timeval last_call; void* plugin_data; }; /* Register a sampling callback * \param callback: the sampling callback * \param interval: time in microsecond between each call to callback * * NB: the interval is thread-specific. Interval corresponds to the minimum * time difference between two calls (within one thread). Please note that * we use a lazy system: the callback is only called if eztrace intercepts a function. * Thus, if the application performs a long computing phase, the callback may not be * called very often. */ void ezt_sampling_register_callback(ezt_sampling_callback_t callback, unsigned interval); void ezt_sampling_check_callbacks(); #endif /* EZTRACE_SAMPLING_H */ eztrace-1.1-2/src/core/eztrace_stack.h000066400000000000000000000020721265506773700177040ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_STACK_H #define EZTRACE_STACK_H #include "eztrace_list.h" typedef struct ezt_list_t ezt_stack_t; typedef struct ezt_list_token_t ezt_stack_token_t; /* todo: a stack is just like a list, but with different functions */ #define ezt_stack_empty(s) (ezt_list_empty(l)) /* create an empty stack */ static inline void ezt_stack_new(ezt_stack_t *s) { ezt_list_new(s); } /* add a new token to the stack */ static inline void ezt_stack_push(ezt_stack_t *s, ezt_stack_token_t *n) { ezt_list_add(s, n); } /* return a pointer to the token on top of the stack */ static inline ezt_stack_token_t* ezt_stack_get_top(ezt_stack_t *s) { return s->tail; } /* remove the token on top of the stack and return it. */ static inline ezt_stack_token_t* ezt_stack_pop(ezt_stack_t *s) { if (!s->tail) return NULL; ezt_stack_token_t* res = s->tail; ezt_list_remove(res); return res; } #endif /* EZTRACE_STACK_H */ eztrace-1.1-2/src/core/eztrace_stats.c000066400000000000000000000100111265506773700177200ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include "ev_codes.h" #include "eztrace_convert_core.h" #include "eztrace_list.h" #include "eztrace_convert.h" #include "eztrace_convert_core.h" #include "eztrace_hook.h" #include "eztrace_stats_core.h" #include "eztrace_litl.h" static struct eztrace_archive_info *arch_info = NULL, *arch_info_head = NULL; static void usage(int argc __attribute__((unused)), char **argv) { fprintf(stderr, "Usage : %s [-v] input_filename input_filename ... \n", argv[0]); } static void parse_args(int argc, char **argv) { int i; litl_size_t j; litl_read_trace_t* arch; struct eztrace_archive_info *tmp; for (i = 1; i < argc; i++) { if (strcmp(argv[i], "-v") == 0) VERBOSE = 1; else if (strcmp(argv[i], "-h") == 0) { usage(argc, argv); exit(-1); } else { /* count the number of traces including those in archives */ /* open the trace file. Do this here to deal with archives of traces */ arch = litl_read_open_trace(argv[i]); if (!arch) { perror("litl_read_open_trace:"); exit(-1); } tmp = (struct eztrace_archive_info *) malloc(sizeof(struct eztrace_archive_info)); tmp->block = arch; tmp->filename = argv[i]; tmp->next = NULL; if (arch_info == NULL ) { arch_info = tmp; arch_info_head = arch_info; } else { arch_info->next = tmp; arch_info = arch_info->next; } NB_TRACES += tmp->block->nb_processes; } } if (NB_TRACES < 1) { usage(argc, argv); exit(-1); } /* create and initialize traces */ j = 0; arch_info = arch_info_head; eztrace_convert_init(NB_TRACES); while (arch_info != NULL ) { tmp = arch_info; arch_info = arch_info->next; arch = tmp->block; // init traces for (i = 0; i < tmp->block->nb_processes; i++) { get_traces(i + j)->input_filename = tmp->filename; get_traces(i + j)->block = tmp->block; get_traces(i + j)->trace_index = i; } litl_read_init_processes(arch); j += tmp->block->nb_processes; } } static void __clean_up() { while (arch_info_head != NULL) { arch_info = arch_info_head; arch_info_head = arch_info_head->next; free(arch_info); } } /* * This program should be used to parse the log file generated by LiTL */ int main(int argc, char **argv) { set_cur_mode(EZTRACE_STATS); char* output_path = NULL; asprintf(&output_path, "/tmp/eztrace_stats_%s", getenv("USER")); eztrace_stats_set_output_dir(output_path); load_modules(1); /* parse the arguments passed to this program */ parse_args(argc, argv); if (!output_path) asprintf(&output_path, "/tmp/eztrace_stats_%s", getenv("USER")); eztrace_stats_set_output_dir(output_path); __init_modules(); int i; /* initialize the traces array */ for (i = 0; i < NB_TRACES; i++) { /* open the trace file */ get_traces(i)->delay = 0; get_traces(i)->rank = i; get_traces(i)->id = i; get_traces(i)->done = 0; get_traces(i)->skip = 0; eztrace_create_containers(i); /* if several traces are loaded, this means that MPI was used, * so let's skip all the first events until MPI_Init is detected */ if (NB_TRACES > 1) get_traces(i)->start = 0; else { CREATE_TRACE_ID_STR(get_traces(i)->trace_id, 0); get_traces(i)->start = 1; NB_START = 1; eztrace_create_ids(get_traces(i)->rank); } ezt_litl_read_next_event(get_traces(i)); get_traces(i)->start_time = LITL_READ_GET_TIME(&get_traces(i)->ev); } /* todo: 0 or i ? */ set_cur_trace(get_traces(0)); set_cur_ev(&get_traces(i)->ev); struct eztrace_event_handler* handler_info = get_handler_info(); /* OK, let's work ! */ while (handler_info->nb_done < NB_TRACES) { set_cur_mode(EZTRACE_STATS); handle_one_event(NULL); } /* finally, call the print_stats callback for all plugins */ __print_stats(); __clean_up(); return 0; } eztrace-1.1-2/src/core/eztrace_stats_core.c000066400000000000000000000140551265506773700207440ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE /* See feature_test_macros(7) */ #include #include #include #include #include #include "eztrace_stats_core.h" #define MAX_COUNTERS 16 struct eztrace_counter { eztrace_counter_id id; unsigned nb_values; double* values; char** value_names; char* name; }; /* todo: make this dynamic */ static struct eztrace_counter root_counters[MAX_COUNTERS]; static unsigned nb_counters = 0; char* __output_stats_dir = NULL; void eztrace_stats_set_output_dir(const char*path) { assert(path); fprintf(stderr, "setting output dir to %s\n", path); asprintf(&__output_stats_dir, "%s", path); int ret = mkdir(path, S_IRWXU); if (ret < 0 && errno != EEXIST) perror("mkdir"); } const char* eztrace_stats_get_output_dir() { return __output_stats_dir; } static struct eztrace_counter* find_counter(eztrace_counter_id counter_id, p_eztrace_container p_cont) { struct eztrace_counter* counter_array = root_counters; if (p_cont) counter_array = p_cont->counters; unsigned int i; for (i = 0; i < nb_counters; i++) { if (counter_array[i].id == counter_id) return &counter_array[i]; } return NULL; } /* Create a new counter whose id is counter_id. This counter contains vectors that consist in * vector_size items. The names of each of the vector item are stores in names */ void attach_counter(eztrace_counter_id counter_id, unsigned vector_size, char**names) { if (nb_counters >= MAX_COUNTERS) { fprintf(stderr, "Too many counters\n"); exit(1); } struct eztrace_counter *cur_counter = &root_counters[nb_counters]; /* check wether counter_id isn't already used */ if (find_counter(counter_id, NULL)) { fprintf(stderr, "Error: Counter %d is already used!\n", counter_id); abort(); } /* initialize the counter structure */ cur_counter->id = counter_id; cur_counter->nb_values = vector_size; cur_counter->values = malloc(sizeof(double) * vector_size); cur_counter->value_names = malloc(sizeof(char*) * vector_size); unsigned int i; /* copy the values names */ for (i = 0; i < vector_size; i++) { asprintf(&(cur_counter->value_names[i]), "%s", names[i]); cur_counter->values[i] = 0; } asprintf(&(cur_counter->name), "Total"); nb_counters++; } /* Return a pointer to the vector item #index from the counter #counter_id of a specific container */ double* get_counter(p_eztrace_container container, eztrace_counter_id counter_id, unsigned index) { struct eztrace_counter* cur_counter = find_counter(counter_id, container); if (cur_counter) return &(cur_counter->values[index]); return NULL; } /* Allocate counters in a newly created container */ void counters_new_container(p_eztrace_container p_cont) { assert(p_cont); p_cont->counters = malloc(sizeof(struct eztrace_counter) * nb_counters); unsigned int i; for (i = 0; i < nb_counters; i++) { p_cont->counters[i].id = root_counters[i].id; p_cont->counters[i].name = root_counters[i].name; p_cont->counters[i].nb_values = root_counters[i].nb_values; p_cont->counters[i].values = malloc( sizeof(double) * p_cont->counters[i].nb_values); p_cont->counters[i].value_names = malloc( sizeof(char*) * p_cont->counters[i].nb_values); unsigned int j; for (j = 0; j < p_cont->counters[i].nb_values; j++) { p_cont->counters[i].values[j] = 0; /* don't copy the value name. So be carefull where freeing it! */ p_cont->counters[i].value_names[j] = root_counters[i].value_names[j]; } } } static void reduce_counters(p_eztrace_container p_cont, eztrace_counter_id counter_id) { if (!p_cont) return; struct eztrace_counter* counter = find_counter(counter_id, p_cont); assert(counter); /* for each sub container, reduce its counters and append them to the local counter */ unsigned int i, j; for (i = 0; i < p_cont->nb_children; i++) { reduce_counters(p_cont->children[i], counter_id); struct eztrace_counter* children_counter = find_counter( counter_id, p_cont->children[i]); assert(children_counter); for (j = 0; j < counter->nb_values; j++) { counter->values[j] += children_counter->values[j]; } } } static void __print_containers_recurse(int depth, eztrace_counter_id id, p_eztrace_container p_cont) { if (!p_cont) return; struct eztrace_counter *counter = find_counter(id, p_cont); assert(counter); /* We assume that the reduction already happened */ unsigned int i; double sum_values = 0; /* compute and print the sum of values */ for (i = 0; i < counter->nb_values; i++) { sum_values += counter->values[i]; } int j = 0; for (j = 0; j < depth; j++) printf(" "); printf("%s -- \t%s: %lf\t", p_cont->name, counter->name, sum_values); /* print each value */ for (i = 0; i < counter->nb_values; i++) { printf("%s: %lf\t", counter->value_names[i], counter->values[i]); } printf("\n"); /* call the container children so that they print their values */ for (i = 0; i < p_cont->nb_children; i++) { __print_containers_recurse(depth + 1, id, p_cont->children[i]); } } static void __print_counter(struct eztrace_counter* counter) { unsigned int j; int i; /* todo: print the total of counters */ for (i = 0; i < NB_TRACES; i++) { /* reduce each trace counter */ p_eztrace_container p_cont = GET_PROCESS_CONTAINER(i); reduce_counters(p_cont, counter->id); struct eztrace_counter* children_counter = find_counter(counter->id, p_cont); assert(children_counter); for (j = 0; j < children_counter->nb_values; j++) { counter->values[j] += children_counter->values[j]; } __print_containers_recurse(0, counter->id, p_cont); } } /* Print the values of a specific counter */ void print_counter(eztrace_counter_id id) { unsigned int i; for (i = 0; i < nb_counters; i++) { if (root_counters[i].id == id) __print_counter(&root_counters[i]); } } eztrace-1.1-2/src/core/eztrace_stats_core.h000066400000000000000000000102471265506773700207500ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_STATS_CORE_H #define EZTRACE_STATS_CORE_H #include "eztrace_convert.h" void eztrace_stats_set_output_dir(const char*path); const char* eztrace_stats_get_output_dir(); /* This defines a hierarchical counter mechanism that permits to summarize * counters in a hierarchical way: a counter is maintained for each thread/process/whatever. * Example of output: CT_Process #0 -- Total: 43812.000000 MPI: 20464.000000 OpenMP: 23348.000000 P#0_T#3923150688 -- Total: 10832.000000 MPI: 5370.000000 OpenMP: 5462.000000 P#0_T#3733358336 -- Total: 10321.000000 MPI: 4741.000000 OpenMP: 5580.000000 P#0_T#3724965632 -- Total: 15568.000000 MPI: 7082.000000 OpenMP: 8486.000000 P#0_T#3715507968 -- Total: 7091.000000 MPI: 3271.000000 OpenMP: 3820.000000 */ /* Each counter contains a vector of double (in the example, the vector contains ) * for each eztrace_container. */ typedef uint32_t eztrace_counter_id; typedef struct eztrace_container_t* p_eztrace_container; /* Create a new counter whose id is counter_id. This counter contains vectors that consist in * vector_size items. The names of each of the vector item are stores in names */ void attach_counter(eztrace_counter_id counter_id, unsigned vector_size, char**names); /* Allocate counters in a newly created container */ void counters_new_container(p_eztrace_container p_cont); /* Return a pointer to the vector item #index from the counter #counter_id of a specific container */ double* get_counter(p_eztrace_container container, eztrace_counter_id counter_id, unsigned index); /* Print the values of a specific counter */ void print_counters(eztrace_counter_id id); /* Add /value/ to a counter for the current thread */ static inline void counter_add(uint32_t counter_id, uint32_t module_id, double value) { double* v = get_counter(GET_THREAD_CONTAINER(CUR_INDEX, CUR_THREAD_ID), counter_id, module_id); if (v) { (*v) += value; } } /* define a 'generic' counter that counts min/max/average */ #define STAT_COUNTER_T(type) \ struct stat_##type##_counter_t { \ type sum; \ type min; \ type max; \ } #define stat_counter_t(type) struct stat_##type##_counter_t /* define uint64_t counters */ STAT_COUNTER_T(uint64_t); /* define double counters */ STAT_COUNTER_T(double); /* initialize a double counter */ #define __init_double_stat_counter(counter) \ { \ ((struct stat_double_counter_t* ) counter)->sum = 0; \ ((struct stat_double_counter_t* ) counter)->min = DBL_MAX; \ ((struct stat_double_counter_t* ) counter)->max = DBL_MIN; \ } /* initialize a uint64_t counter */ #define __init_uint64_t_stat_counter(counter) \ { \ ((struct stat_uint64_t_counter_t*)counter)->sum = 0; \ ((struct stat_uint64_t_counter_t*)counter)->min = UINT64_MAX; \ ((struct stat_uint64_t_counter_t*)counter)->max = 0; \ } /* initialize a counter */ #define __init_stat_counter(type, counter) \ { \ stat_counter_t(type) * _c_ = (stat_counter_t(type) *) (counter); \ __init_##type##_stat_counter(_c_); \ } /* update a counter */ #define __update_stat_counter(type, counter, new_value) \ { \ stat_counter_t(type) * _c_ = (stat_counter_t(type) *) (counter); \ _c_ -> sum += (new_value); \ if((new_value) < _c_->min) \ _c_->min = (new_value); \ if((new_value) > _c_->max) \ _c_->max = (new_value); \ } /* reduce a counter */ #define __reduce_stat_counter(type, src_counter, dest_counter) \ { \ stat_counter_t(type) *_src_ = (stat_counter_t(type) *)(src_counter); \ stat_counter_t(type) *_dest_ = (stat_counter_t(type) *)(dest_counter); \ \ _dest_->sum += _src_->sum; \ \ if(_src_->min < _dest_->min) \ _dest_->min = _src_->min; \ \ if(_src_->max > _dest_->max) \ _dest_->max = _src_->max; \ } #endif /* EZTRACE_STATS_CORE_H */ eztrace-1.1-2/src/core/eztrace_types.h000066400000000000000000000007741265506773700177520ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_TYPES_H #define EZTRACE_TYPES_H /* This header contains the data types that are used by both eztrace and * eztrace_convert/eztrace_stats */ /* application pointer. This pointer is invalid in the current * process, but its value corresponds to an object in the * application. */ typedef intptr_t app_ptr; #endif/* EZTRACE_TYPES_H */ eztrace-1.1-2/src/core/function.pm000066400000000000000000000175171265506773700171060ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. package Function; use warnings; use strict; use Carp; #contructor sub new { my ($classe) = @_; $classe = ref($classe) || $classe; my $this = {}; bless($this, $classe); $this->{RET_TYPE}="null"; $this->{FNAME}="null"; $this->{ARGS}=[]; $this->{NB_ARGS}=0; $this->{ALREADY_CALLED}=0; $this->{TYPE}="LIBRARY"; $this->{ENTRY_CODE}= 0; $this->{EXIT_CODE}= 0; $this->{BODY_BEGIN}=" FUNCTION_ENTRY\n"; $this->{BODY_FCALL}=""; $this->{BODY_END}=""; $this->{USE_VARGS}=0; return $this; } sub add_body { my ($this, $new_line) = @_; if($this->{ALREADY_CALLED} == 0) { $this->{BODY_BEGIN}.="\t${new_line}"; } else { $this->{BODY_END}.="\t${new_line}"; } } sub convert_declare_parameters { my ($this, $code) = @_; my $nb_param = get_arg_num($this); $nb_param-- if ( $this->{USE_VARGS} ); if($nb_param > 4) { $nb_param = 4; } my $string = ""; if ($this->{TYPE} eq "LIBRARY") { my $i; my $get_param_str="GET_PARAM_PACKED_".$nb_param."(CUR_EV, "; for($i=0; $i<$nb_param; $i++) { # declare a variable $string .= get_arg_type($this, $i). " ".get_arg_name($this, $i). ";\n" ; # put the i_th parameter of the event in the variable $get_param_str.= get_arg_name($this, $i); if($i+1 < $nb_param) { #there is another parameter after this one $get_param_str .= ", "; } } $get_param_str .= ");\n"; if($nb_param > 0) { $string .= $get_param_str; } } return $string; } sub add_event { my ($this, $code) = @_; my $nb_param = get_arg_num($this); if($this->{ALREADY_CALLED} == 0) { $this->{ENTRY_CODE}= $code; } else { $this->{EXIT_CODE}= $code; } $nb_param-- if ( $this->{USE_VARGS} ); if($nb_param > 4) { $nb_param = 4; } my $string = ""; if ($this->{TYPE} eq "LIBRARY") { $string .= "EZTRACE_EVENT_PACKED_${nb_param} ($code"; my $i; for($i=0; $i<$nb_param; $i++) { $string .= ", "; $string .= get_arg_name($this, $i); } $string .= ");\n"; } add_body($this, $string); } sub create_intercept { my ($this) = @_; my $ret = ""; if ($this->{TYPE} eq "LIBRARY") { $ret = "INTERCEPT2(\"".$this->{FNAME}."\", lib".$this->{FNAME}.")\n"; } return $ret; } # Create a string that has the following pattern: # asprintf(&varname, "arg1=%x, arg2=%x", arg1, arg2); # return the generated string sub create_asprintf { my ($this, $output_var_name) = @_; my $format = ""; my $args = ""; my $i; my $nb_param = $this->get_arg_num; # construct the format and args at the same time for($i=0; $i<$nb_param; $i++) { my $var_name = $this->get_arg_name($i); my $index = $i + 1; $args .= ", GET_PARAM(CUR_EV, ".$index.")"; $format .= "$var_name = %x"; my $num_remaining_args=$nb_param - $i; if($num_remaining_args>1) { $format .= ", "; } } my $ret = "asprintf(&${output_var_name}, \"${format}\" ${args} );"; return $ret; } sub add_fcall { my ($this) = @_; if($this->{ALREADY_CALLED} != 0) { print "Error: calling twice function ".$this->{FNAME}."\n"; exit 1; } $this->{ALREADY_CALLED} = 1; if ($this->{TYPE} eq "LIBRARY") { if (index($this->{RET_TYPE}, "void") == -1){ $this->{BODY_FCALL} .= "\t".$this->{RET_TYPE}." ret = lib".$this->{FNAME}." ("; } else { $this->{BODY_FCALL} .= "\tlib".$this->{FNAME}." ("; } my $i; my $array_size = get_arg_num($this); for($i=0; $i<$array_size; $i++) { $this->{BODY_FCALL} .= get_arg_name($this, $i); my $num_remaining_args=$array_size - $i; if($num_remaining_args>1) { $this->{BODY_FCALL} .= ", "; } } $this->{BODY_FCALL} .= ");\n"; } } # Create the callback string (type (*libfname)(arg1, arg2...)) # returns the string to insert sub create_callback { my ($this) = @_; # create the ' (*lib) (' string my $ret = $this->{RET_TYPE}." (*lib".$this->{FNAME}.") ("; my $i; my $nb_arg = get_arg_num($this); # add the parameters to the string for($i=0; $i<$nb_arg; $i++) { $ret .= get_arg_type($this, $i)." ".get_arg_name($this, $i); my $num_remaining_args=$nb_arg - $i; if($num_remaining_args>1) { $ret .=", "; } } # finalize the string $ret .= ");\n"; return $ret; } # Create the function string (type fname(arg1, arg2...)) # returns the string to insert sub create_function { my ($this) = @_; # create the ' (' string my $ret = $this->{RET_TYPE}." ".$this->{FNAME}." ("; my $i; my $nb_arg = get_arg_num($this); # add the parameters to the string for($i=0; $i<$nb_arg; $i++) { $ret .= get_arg_type($this, $i)." ".get_arg_name($this, $i); my $num_remaining_args=$nb_arg - $i; if($num_remaining_args>1) { $ret .=", "; } } # finalize the string $ret .= ") {\n"; # Add block for va_arg parameters if ( $this->{USE_VARGS} ) { $ret .= "\tva_list myargs;\n"; $ret .= "\tva_start(myargs, ".$this->get_arg_name($nb_arg-2).");\n"; } $ret .= $this->{BODY_BEGIN}; if($this->{ALREADY_CALLED} == 0) { $this->add_fcall(); } $ret .= $this->{BODY_FCALL}; $ret .= $this->{BODY_END}; if (index($this->{RET_TYPE},"void") == -1){ $ret .="\treturn ret;\n"; } $ret .="}\n"; return $ret; } # return the number of parameters for the function sub get_arg_num { my ($this) = @_; return $this->{NB_ARGS}; } # return the ith parameter type # params # $arg_num i sub get_arg_type { my ($this, $arg_num) = @_; my @args = @{$this->{ARGS}}; my @ith_arg = @{$args[$arg_num]}; return $ith_arg[0]; } # return the ith parameter name # params # $arg_num i sub get_arg_name { my ($this, $arg_num) = @_; my @args = @{$this->{ARGS}}; my @ith_arg = @{$args[$arg_num]}; return $ith_arg[1]; } sub get_fname { my ($this) = @_; return $this->{FNAME}; } # print information on the function for debugging # params # $arg_num i sub print { my ($this) = @_; printf "\tret type = ".$this->{RET_TYPE}."\n"; printf "\tfname = ".$this->{FNAME}."\n"; my $i; for($i=0; $i<$this->get_arg_num(); $i++) { print "type '".$this->get_arg_type($i)."'\t"; print "name '".$this->get_arg_name($i)."'\n"; } } # change the type returned by the function # params # $ret_type return type sub set_ret_type { my ($this, $ret_type) = @_; $this->{RET_TYPE} = $ret_type; } # change the function name # params # $fname function name sub set_fname( $$ ) { my ($this, $fname) = @_; $this->{FNAME} = $fname; } # change the function name # params # $fname function name sub set_type( $$ ) { my ($this, $type) = @_; $this->{TYPE} = $type; } # add a parameter to the function # params # $new_arg_type parameter type # $new_arg_name parameter name sub add_arg( $$$ ) { my ($this, $new_arg_type, $new_arg_name) = @_; my @new_arg = [$new_arg_type, $new_arg_name]; push ((@{$this->{ARGS}}), @new_arg); $this->{NB_ARGS}++; $this->{USE_VARGS} = 1 if ($new_arg_name eq "..." ); } # initialize the current library sub lib_init { my ($libname, @func_tab) = @_; my $ret="START_INTERCEPT\n"; foreach (@func_tab){ $ret .= "\t".create_intercept($_); } $ret .="END_INTERCEPT\n"; $ret .= "static void __".$libname."_init (void) __attribute__ ((constructor));\n"; $ret .= "static void __".$libname."_init (void) {\n"; $ret .= "#ifdef EZTRACE_AUTOSTART\n"; $ret .= "\teztrace_start ();\n"; $ret .= "#endif\n"; $ret .= "}\n"; return $ret; } sub lib_conclude { my ($libname) = @_; my $ret = "static void __".$libname."_conclude (void) __attribute__ ((destructor));\n"; $ret .= "static void __".$libname."_conclude (void){\n"; $ret .= "\teztrace_stop ();\n"; $ret .="}\n"; return $ret; } # end of the module 1; __END__ eztrace-1.1-2/src/core/input/000077500000000000000000000000001265506773700160475ustar00rootroot00000000000000eztrace-1.1-2/src/core/input/Makefile.template000066400000000000000000000021631265506773700213230ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. prefix=/home/trahay/Soft/opt/eztrace/master/build/../install exec_prefix=${prefix} libdir=${exec_prefix}/lib includedir=${prefix}/include BIN = libeztrace-convert-@MODULE@.so libeztrace-@MODULE@.so libeztrace-autostart-@MODULE@.so ldflags=$(LDFLAGS) @CUSTOM_LDFLAGS@ -L${libdir} cflags=$(CFLAGS) @CUSTOM_CFLAGS@ -I${includedir} CONVERT_LDFLAGS=@CONVERT_LDFLAGS@ RECORD_LDFLAGS=@RECORD_LDFLAGS@ all: $(BIN) libeztrace-convert-@MODULE@.so: eztrace_convert_@MODULE@.c @MODULE@_ev_codes.h $(CC) --shared -o libeztrace-convert-@MODULE@.so eztrace_convert_@MODULE@.c -fPIC $(cflags) $(ldflags) $(CONVERT_LDFLAGS) -ldl libeztrace-@MODULE@.so: @MODULE@.c @MODULE@_ev_codes.h $(CC) --shared -o libeztrace-@MODULE@.so @MODULE@.c -fPIC $(cflags) $(ldflags) -Wl,-Bsymbolic $(RECORD_LDFLAGS) -ldl libeztrace-autostart-@MODULE@.so: @MODULE@.c @MODULE@_ev_codes.h $(CC) --shared -o libeztrace-autostart-@MODULE@.so @MODULE@.c -fPIC $(cflags) $(ldflags) -Wl,-Bsymbolic $(RECORD_LDFLAGS) -ldl -DEZTRACE_AUTOSTART clean: rm -f $(BIN) eztrace-1.1-2/src/core/input/Makefile.template.in000066400000000000000000000020731265506773700217300ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. prefix=@prefix@ exec_prefix=@exec_prefix@ libdir=@libdir@ includedir=@includedir@ BIN = libeztrace-convert-@MODULE@.so libeztrace-@MODULE@.so libeztrace-autostart-@MODULE@.so ldflags=$(LDFLAGS) @CUSTOM_LDFLAGS@ -L${libdir} cflags=$(CFLAGS) @CUSTOM_CFLAGS@ -I${includedir} CONVERT_LDFLAGS=@CONVERT_LDFLAGS@ RECORD_LDFLAGS=@RECORD_LDFLAGS@ all: $(BIN) libeztrace-convert-@MODULE@.so: eztrace_convert_@MODULE@.c @MODULE@_ev_codes.h $(CC) --shared -o libeztrace-convert-@MODULE@.so eztrace_convert_@MODULE@.c -fPIC $(cflags) $(ldflags) $(CONVERT_LDFLAGS) -ldl libeztrace-@MODULE@.so: @MODULE@.c @MODULE@_ev_codes.h $(CC) --shared -o libeztrace-@MODULE@.so @MODULE@.c -fPIC $(cflags) $(ldflags) -Wl,-Bsymbolic $(RECORD_LDFLAGS) -ldl libeztrace-autostart-@MODULE@.so: @MODULE@.c @MODULE@_ev_codes.h $(CC) --shared -o libeztrace-autostart-@MODULE@.so @MODULE@.c -fPIC $(cflags) $(ldflags) -Wl,-Bsymbolic $(RECORD_LDFLAGS) -ldl -DEZTRACE_AUTOSTART clean: rm -f $(BIN) eztrace-1.1-2/src/core/input/example.c.template000066400000000000000000000013631265506773700214630ustar00rootroot00000000000000/* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include "eztrace.h" #include "eztrace_sampling.h" @HEADER_USER@ #include "@HEADER_FILE@" @SAMPLING_FUNCTIONS@ @RECORD_CALLBACKS@ @RECORD_FUNCTIONS@ START_INTERCEPT @RECORD_INTERCEPTS@ END_INTERCEPT static void __@MODULE@_init (void) __attribute__ ((constructor)); /* Initialize the current library */ static void __@MODULE@_init (void) { DYNAMIC_INTERCEPT_ALL(); /* start event recording */ #ifdef EZTRACE_AUTOSTART eztrace_start (); #endif @POST_INIT@ } static void __@MODULE@_conclude (void) __attribute__ ((destructor)); static void __@MODULE@_conclude (void) { /* stop event recording */ eztrace_stop (); } eztrace-1.1-2/src/core/input/example_ev_codes.h.template000066400000000000000000000014641265506773700233410ustar00rootroot00000000000000/* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #ifndef __@MODULE@_EV_CODES_H__ #define __@MODULE@_EV_CODES_H__ /* This file defines the event codes that are used by the example * module. */ #include "ev_codes.h" /* 7-bits event codes prefix. This identifies the module and thus should be * unique. * The 0x0? prefix is reserved for eztrace internal use. Thus you can * use any prefix between 0x80 and 0xff. */ #define @MODULE@_EVENTS_ID USER_MODULE_ID(0x@MODULE_ID@) #define @MODULE@_PREFIX (@MODULE@_EVENTS_ID << NB_BITS_EVENTS) /* Define various event codes used by the example module * The 2 most significant bytes should correspond to the module id, * as below: */ @EVENT_DEFINITION@ #endif /* __@MODULE@_EV_CODES_H__ */ eztrace-1.1-2/src/core/input/eztrace_convert_example.c.template000066400000000000000000000107501265506773700247400ustar00rootroot00000000000000/* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include "eztrace_convert.h" @HEADER_USER@ #include "@HEADER_FILE@" int eztrace_convert_@MODULE@_init(); int handle_@MODULE@_events(eztrace_event_t *ev); int handle_@MODULE@_stats(eztrace_event_t *ev); void print_@MODULE@_stats(); @CONVERT_FUNCTIONS_PROTOTYPES@ /* thread-specific structure */ struct @MODULE@_thread_info_t { struct thread_info_t *p_thread; /* TO COMPLETE: You can add per-thread counters here */ }; static struct @MODULE@_thread_info_t *__register_thread_hook( struct thread_info_t *p_thread) { struct @MODULE@_thread_info_t *ptr = (struct @MODULE@_thread_info_t*) malloc( sizeof(struct @MODULE@_thread_info_t)); ptr->p_thread = p_thread; /* TO COMPLETE: If you added per-thread counters, initialize them here*/ /* add the hook in the thread info structure */ ezt_hook_list_add(&ptr->p_thread->hooks, ptr, (uint8_t) @MODULE@_EVENTS_ID); return ptr; } #define INIT_@MODULE@_THREAD_INFO(p_thread, var) \ struct @MODULE@_thread_info_t *var = (struct @MODULE@_thread_info_t*) \ ezt_hook_list_retrieve_data(&p_thread->hooks, (uint8_t)@MODULE@_EVENTS_ID); \ if(!(var)) { \ var = __register_thread_hook(p_thread); \ } /* Constructor of the plugin. * This function registers the current module to eztrace_convert */ struct eztrace_convert_module @MODULE@_module; void libinit(void) __attribute__ ((constructor)); void libinit(void) { @MODULE@_module.api_version = EZTRACE_API_VERSION; /* Specify the initialization function. * This function will be called once all the plugins are loaded * and the trace is started. * This function usually declared StateTypes, LinkTypes, etc. */ @MODULE@_module.init = eztrace_convert_@MODULE@_init; /* Specify the function to call for handling an event */ @MODULE@_module.handle = handle_@MODULE@_events; /* Specify the function to call for handling an event when * eztrace_stats is called */ @MODULE@_module.handle_stats = handle_@MODULE@_stats; /* Specify the function to call for printinf statistics */ @MODULE@_module.print_stats = print_@MODULE@_stats; /* Specify the module prefix */ @MODULE@_module.module_prefix = @MODULE@_EVENTS_ID; asprintf(&@MODULE@_module.name, "@MODULE@"); asprintf(&@MODULE@_module.description, @MODULE_DESC@); @MODULE@_module.token.data = &@MODULE@_module; /* Register the module to eztrace_convert */ eztrace_convert_register_module(&@MODULE@_module); //printf("module @MODULE@ loaded\n"); } void libfinalize(void) __attribute__ ((destructor)); void libfinalize(void) { //printf("unloading module @MODULE@\n"); } /* * This function will be called once all the plugins are loaded * and the trace is started. * This function usually declared StateTypes, LinkTypes, etc. */ int eztrace_convert_@MODULE@_init() { @CONVERT_INIT@ } /* This function is called by eztrace_convert for each event to * handle. * It shall return 1 if the event was handled successfully or * 0 otherwise. */ int handle_@MODULE@_events(eztrace_event_t *ev) { if(! CUR_TRACE->start) return 0; switch (LITL_READ_GET_CODE(ev)) { @CONVERT_CASE@ default: /* The event was not handled */ return 0; } return 1; } /* This function is called by eztrace_stats for each event to * handle. * It shall return 1 if the event was handled successfully or * 0 otherwise. */ int handle_@MODULE@_stats(eztrace_event_t *ev) { /* By default, use the same function as for eztrace_convert */ return handle_@MODULE@_events(ev); } void print_@MODULE@_stats() { printf("\n@MODULE@:\n"); printf("-------\n"); int i; /* Browse the list of processes */ for (i = 0; i < NB_TRACES; i++) { struct eztrace_container_t *p_process = GET_PROCESS_CONTAINER(i); int j; /* For each process, browse the list of threads */ for(j=0; jnb_children; j++) { struct eztrace_container_t *thread_container = p_process->children[j]; struct thread_info_t *p_thread = (struct thread_info_t*) thread_container->container_info; if(!p_thread) continue; INIT_@MODULE@_THREAD_INFO(p_thread, ptr); printf("\tThread %s\n", thread_container->name); /* TO COMPLETE: you can print per-thread counters here */ } } } @CONVERT_FUNCTIONS_BODY@ eztrace-1.1-2/src/core/pthread_core.c000066400000000000000000000063561265506773700175250ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 /* or _BSD_SOURCE or _SVID_SOURCE */ #define _REENTRANT #include #include #include #include "ev_codes.h" #include "eztrace.h" //#define VERBOSE 1 #ifdef VERBOSE #define FUNCTION_NAME fprintf(stderr, "Calling [%s]\n", __FUNCTION__) #else #define FUNCTION_NAME (void) 0 #endif static volatile int __pthread_core_initialized = 0; int (*libpthread_create) (pthread_t * thread, const pthread_attr_t * attr, void *(*start_routine) (void *), void *arg); int (*libpthread_join) (pthread_t th, void **thread_return); void (*libpthread_exit) (void *thread_return); /* this function shall e called by each new thread */ void eztrace_set_alarm(); /* Thread creation/destruction callbacks */ /* Internal structure used for transmitting the function and argument * during pthread_create. */ struct __pthread_create_info_t { void *(*func)(void *); void *arg; }; /* Invoked by pthread_create on the new thread */ static void * __pthread_new_thread(void *arg) { struct __pthread_create_info_t *p_arg = (struct __pthread_create_info_t*) arg; void *(*f)(void *) = p_arg->func; void *__arg = p_arg->arg; free(p_arg); EZTRACE_FORCE_RECORD_EVENT0(EZTRACE_NEW_THREAD); RECORD_HW_COUNTERS(); eztrace_set_alarm(); void *res = (*f)(__arg); EZTRACE_FORCE_RECORD_EVENT0(EZTRACE_END_THREAD); return res; } int pthread_create (pthread_t *__restrict thread, const pthread_attr_t *__restrict attr, void *(*start_routine) (void *), void *__restrict arg) { FUNCTION_NAME; struct __pthread_create_info_t * __args = (struct __pthread_create_info_t*) malloc( sizeof(struct __pthread_create_info_t)); __args->func = start_routine; __args->arg = arg; if (!libpthread_create) INTERCEPT("pthread_create", libpthread_create); /* We do not call directly start_routine since we could not get the actual creation timestamp of * the thread. Let's invoke __pthread_new_thread that will PROF_EVENT the thread and call * start_routine. */ EZTRACE_FORCE_RECORD_EVENT0(EZTRACE_START_THREAD_CREATE); int retval = libpthread_create(thread, attr, __pthread_new_thread, __args); EZTRACE_FORCE_RECORD_EVENT0(EZTRACE_STOP_THREAD_CREATE); return retval; } int pthread_join(pthread_t th, void **thread_return) { FUNCTION_NAME; EZTRACE_FORCE_RECORD_EVENT0(EZTRACE_START_THREAD_JOIN); int ret = libpthread_join(th, thread_return); EZTRACE_FORCE_RECORD_EVENT3(EZTRACE_STOP_THREAD_JOIN, th, thread_return, ret); return ret; } void pthread_exit(void *thread_return) { FUNCTION_NAME; libpthread_exit(thread_return); __builtin_unreachable(); } static void __pthread_core_init(void) __attribute__ ((constructor)); static void __pthread_core_init(void) { INTERCEPT("pthread_create", libpthread_create); INTERCEPT("pthread_join", libpthread_join); INTERCEPT("pthread_exit", libpthread_exit); #ifdef EZTRACE_AUTOSTART eztrace_start (); #endif __pthread_core_initialized = 1; } static void __pthread_core_conclude(void) __attribute__ ((destructor)); static void __pthread_core_conclude(void) { __pthread_core_initialized = 0; eztrace_stop(); } eztrace-1.1-2/src/core/submodules/000077500000000000000000000000001265506773700170725ustar00rootroot00000000000000eztrace-1.1-2/src/core/submodules/ezt_getcpu.c000066400000000000000000000024271265506773700214140ustar00rootroot00000000000000#define _GNU_SOURCE #include #include "ezt_submodule.h" #include "eztrace_sampling.h" static int __ezt_use_getcpu = 0; struct cpu_info { int last_cpu; }; int ezt_getcpu_callback(struct ezt_sampling_callback_instance *instance) { struct cpu_info* p = NULL; if(!instance->plugin_data) { /* first time this thread calls this callback. * Let's allocate data */ p = malloc(sizeof(struct cpu_info)); p->last_cpu = -1; instance->plugin_data = p; } p = instance->plugin_data; /* todo: use getcpu instead (getcpu also returns NUMA-related information) */ int cur_cpu = sched_getcpu(); if(cur_cpu != p->last_cpu) { EZTRACE_EVENT1(EZT_GETCPU, cur_cpu); } p->last_cpu = cur_cpu; return 0; } /* initialize the ezt_getcpu module */ void ezt_getcpu_init() { static int initialized = 0; if(initialized) return; initialized = 1; char* str = getenv("EZTRACE_USE_GETCPU"); if(str) { if(strcmp(str, "0")) { char* str2 = getenv("EZTRACE_GETCPU_INTERVAL"); int interval = 10000; if(str2) { interval = atoi(str2); } __ezt_use_getcpu = 1; printf("[EZTrace] module getcpu enabled (sampling every %d us)\n", interval); ezt_sampling_register_callback(ezt_getcpu_callback, interval); } } } eztrace-1.1-2/src/core/submodules/ezt_getcpu.h000066400000000000000000000002051265506773700214110ustar00rootroot00000000000000#ifndef EZT_GETCPU_H #define EZT_GETCPU_H /* initialize the ezt_getcpu module */ void ezt_getcpu_init(); #endif /* EZT_GETCPU_H */ eztrace-1.1-2/src/core/submodules/ezt_getcpu_convert.c000066400000000000000000000014241265506773700231500ustar00rootroot00000000000000#include #include "eztrace_convert.h" #include "ezt_submodule.h" #include "ezt_getcpu.h" /* These functions are called post mortem (by eztrace_convert/eztrace_stats) */ int ezt_getcpu_convert_init() { addVarType ("V_CURCPU", "Current CPU", "CT_Thread"); return 0; } int ezt_getcpu_convert_events(eztrace_event_t *ev) { DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); switch (LITL_READ_GET_CODE(ev)) { case EZT_GETCPU: { /* todo */ FUNC_NAME; int cpu = GET_PARAM(CUR_EV, 1); setVar(CURRENT, "V_CURCPU", thread_id, (double)cpu); break; } default: return 0; } return 1; } int ezt_getcpu_convert_stats(eztrace_event_t *ev __attribute__((unused))) { return 0; } void ezt_getcpu_convert_print_stats() { } eztrace-1.1-2/src/core/submodules/ezt_submodule.c000066400000000000000000000012501265506773700221150ustar00rootroot00000000000000#include "ezt_submodule.h" #include "ezt_getcpu.h" static int __ezt_nb_submodules = 1; static struct ezt_submodule __ezt_submodules[] = { { .exec_init = ezt_getcpu_init, .convert_init = NULL, .convert_handle = NULL, .convert_handle_stats = NULL, .convert_print_stats = NULL } }; void ezt_submodule_exec_init() { static int initialized = 0; if(initialized) return; initialized = 1; int i; for(i=0;i<__ezt_nb_submodules; i++) { __ezt_submodules[i].exec_init(); } } static void __ezt_submodule_init(void) __attribute__ ((constructor)); static void __ezt_submodule_init(void) { ezt_submodule_exec_init(); } eztrace-1.1-2/src/core/submodules/ezt_submodule.h000066400000000000000000000022701265506773700221250ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZT_SUBMODULE_H #define EZT_SUBMODULE_H #include "eztrace.h" #include "eztrace_convert_types.h" #include "ev_codes.h" #define EZT_SUBMODULE_EVENTS_ID SYSTEM_MODULE_ID(0x10) #define EZT_SUBMODULE_PREFIX GENERATE_SYSTEM_MODULE_PREFIX(EZT_SUBMODULE_EVENTS_ID) struct ezt_submodule { void (*exec_init)(); int (*convert_init)(); int (*convert_handle)(eztrace_event_t* ev); int (*convert_handle_stats)(eztrace_event_t* ev); void (*convert_print_stats)(); }; void ezt_submodule_exec_init(); void ezt_submodule_convert_init(); int ezt_submodule_convert_handle(eztrace_event_t *ev); int ezt_submodule_convert_handle_stats(eztrace_event_t *ev); void ezt_submodule_convert_print_stats(); /* GETCPU submodule */ extern void ezt_getcpu_init(); extern int ezt_getcpu_convert_init(); extern int ezt_getcpu_convert_events(eztrace_event_t *ev); extern int ezt_getcpu_convert_stats(eztrace_event_t *ev); extern void ezt_getcpu_convert_print_stats(); #define EZT_GETCPU (EZT_SUBMODULE_PREFIX | 0X0001) #endif /* EZT_SUBMODULE_H */ eztrace-1.1-2/src/core/submodules/ezt_submodule_convert.c000066400000000000000000000021661265506773700236640ustar00rootroot00000000000000#include "ezt_submodule.h" #include "ezt_getcpu.h" static int __ezt_nb_submodules = 1; static struct ezt_submodule __ezt_submodules[] = { { .exec_init = NULL, .convert_init = ezt_getcpu_convert_init, .convert_handle = ezt_getcpu_convert_events, .convert_handle_stats = ezt_getcpu_convert_stats, .convert_print_stats = ezt_getcpu_convert_print_stats } }; void ezt_submodule_convert_init() { int i; for(i=0;i<__ezt_nb_submodules; i++) { __ezt_submodules[i].convert_init(); } } int ezt_submodule_convert_handle(eztrace_event_t* ev) { int i; int ret = 0; for(i=0;i<__ezt_nb_submodules; i++) { ret = __ezt_submodules[i].convert_handle(ev); if(ret) return ret; } return ret; } int ezt_submodule_convert_handle_stats(eztrace_event_t* ev) { int i; int ret = 0; for(i=0;i<__ezt_nb_submodules; i++) { ret = __ezt_submodules[i].convert_handle_stats(ev); if(ret) return ret; } return ret; } void ezt_submodule_convert_print_stats() { int i; for(i=0;i<__ezt_nb_submodules; i++) { __ezt_submodules[i].convert_print_stats(); } } eztrace-1.1-2/src/modules/000077500000000000000000000000001265506773700154305ustar00rootroot00000000000000eztrace-1.1-2/src/modules/cuda/000077500000000000000000000000001265506773700163445ustar00rootroot00000000000000eztrace-1.1-2/src/modules/cuda/Makefile.am000066400000000000000000000037211265506773700204030ustar00rootroot00000000000000# Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 # See COPYING in top-level directory. if USE_CUDA TLCFLAGS=$(TL_CPPFLAGS) TLLDFLAGS=$(TL_LDFLAGS) TLLIBADD=$(TL_LIB) GTGCFLAGS=$(GTG_CPPFLAGS) GTGLDFLAGS=$(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD = $(GTG_LIB) LINK = $(LIBTOOL) --mode=link $(CC) -o $@ $(CUDA_LDFLAGS) $(CUDA_LIBS) lib_LTLIBRARIES = libeztrace-convert-cuda.la \ libeztrace-cuda.la \ libeztrace-autostart-cuda.la # todo: do not hard-code these dir names AM_CFLAGS = -W -Wall -Wextra -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ -I$(top_srcdir)/src/pptrace $(CUPTI_CFLAGS) NVCCFLAGS += $(TLCFLAGS) -I$(srcdir)/../../core/ $(CUPTI_CFLAGS) NVCC_LDFLAGS = $(CUPTI_LDFLAGS) $(CUPTI_LIBS) include cuda.mk libeztrace_convert_cuda_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) libeztrace_convert_cuda_la_LIBADD = $(GTGLIBADD) $(TLLIBADD) libeztrace_convert_cuda_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_cuda_la_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace_convert_cuda_la_SOURCES = eztrace_convert_cuda.c libeztrace_cuda_la_SOURCES = cuda.cu cuda_runtime.cu cuda_driver.cu ezt_cuda.h libeztrace_cuda_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_cuda_la_LIBADD = $(CUDA_LIBS) -lcupti $(TLLIBADD) libeztrace_cuda_la_LDFLAGS = --no-undefined $(TLLDFLAGS) \ $(CUDA_LDFLAGS) $(NVCC_LDFLAGS) -lcupti libeztrace_autostart_cuda_la_SOURCES = cuda.cu cuda_runtime.cu cuda_driver.cu \ ezt_cuda.h libeztrace_autostart_cuda_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_autostart_cuda_la_LIBADD = $(CUDA_LIBS) -lcupti $(TLLIBADD) libeztrace_autostart_cuda_la_LDFLAGS = --no-undefined $(TLLDFLAGS) \ $(CUDA_LDFLAGS) $(NVCC_LDFLAGS) -lcupti libeztrace_autostart_cuda_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra -DEZTRACE_AUTOSTART noinst_HEADERS = cuda_ev_codes.h \ cudalt.py endif #USE_CUDA eztrace-1.1-2/src/modules/cuda/Makefile.in000066400000000000000000000706621265506773700204240ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ @USE_CUDA_TRUE@am__append_1 = $(TLCFLAGS) -I$(srcdir)/../../core/ $(CUPTI_CFLAGS) subdir = src/modules/cuda ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__noinst_HEADERS_DIST) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(libdir)" LTLIBRARIES = $(lib_LTLIBRARIES) am__DEPENDENCIES_1 = @USE_CUDA_TRUE@am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) @USE_CUDA_TRUE@libeztrace_autostart_cuda_la_DEPENDENCIES = \ @USE_CUDA_TRUE@ $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_2) am__libeztrace_autostart_cuda_la_SOURCES_DIST = cuda.cu \ cuda_runtime.cu cuda_driver.cu ezt_cuda.h @USE_CUDA_TRUE@am_libeztrace_autostart_cuda_la_OBJECTS = cuda.lo \ @USE_CUDA_TRUE@ cuda_runtime.lo cuda_driver.lo libeztrace_autostart_cuda_la_OBJECTS = \ $(am_libeztrace_autostart_cuda_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libeztrace_autostart_cuda_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(libeztrace_autostart_cuda_la_CFLAGS) $(CFLAGS) \ $(libeztrace_autostart_cuda_la_LDFLAGS) $(LDFLAGS) -o $@ @USE_CUDA_TRUE@am_libeztrace_autostart_cuda_la_rpath = -rpath \ @USE_CUDA_TRUE@ $(libdir) am__libeztrace_convert_cuda_la_SOURCES_DIST = eztrace_convert_cuda.c @USE_CUDA_TRUE@am_libeztrace_convert_cuda_la_OBJECTS = libeztrace_convert_cuda_la-eztrace_convert_cuda.lo libeztrace_convert_cuda_la_OBJECTS = \ $(am_libeztrace_convert_cuda_la_OBJECTS) libeztrace_convert_cuda_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_convert_cuda_la_LDFLAGS) \ $(LDFLAGS) -o $@ @USE_CUDA_TRUE@am_libeztrace_convert_cuda_la_rpath = -rpath $(libdir) @USE_CUDA_TRUE@libeztrace_cuda_la_DEPENDENCIES = \ @USE_CUDA_TRUE@ $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_2) am__libeztrace_cuda_la_SOURCES_DIST = cuda.cu cuda_runtime.cu \ cuda_driver.cu ezt_cuda.h @USE_CUDA_TRUE@am_libeztrace_cuda_la_OBJECTS = cuda.lo cuda_runtime.lo \ @USE_CUDA_TRUE@ cuda_driver.lo libeztrace_cuda_la_OBJECTS = $(am_libeztrace_cuda_la_OBJECTS) libeztrace_cuda_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_cuda_la_LDFLAGS) \ $(LDFLAGS) -o $@ @USE_CUDA_TRUE@am_libeztrace_cuda_la_rpath = -rpath $(libdir) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libeztrace_autostart_cuda_la_SOURCES) \ $(libeztrace_convert_cuda_la_SOURCES) \ $(libeztrace_cuda_la_SOURCES) DIST_SOURCES = $(am__libeztrace_autostart_cuda_la_SOURCES_DIST) \ $(am__libeztrace_convert_cuda_la_SOURCES_DIST) \ $(am__libeztrace_cuda_la_SOURCES_DIST) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__noinst_HEADERS_DIST = cuda_ev_codes.h cudalt.py HEADERS = $(noinst_HEADERS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/cuda.mk \ $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ $(am__append_1) OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ @USE_CUDA_TRUE@TLCFLAGS = $(TL_CPPFLAGS) @USE_CUDA_TRUE@TLLDFLAGS = $(TL_LDFLAGS) @USE_CUDA_TRUE@TLLIBADD = $(TL_LIB) @USE_CUDA_TRUE@GTGCFLAGS = $(GTG_CPPFLAGS) @USE_CUDA_TRUE@GTGLDFLAGS = $(GTG_LDFLAGS) @USE_CUDA_TRUE@GTGDEPENDENCIES = $(GTG_DEPENDENCIES) @USE_CUDA_TRUE@GTGLIBADD = $(GTG_LIB) @USE_CUDA_TRUE@LINK = $(LIBTOOL) --mode=link $(CC) -o $@ $(CUDA_LDFLAGS) $(CUDA_LIBS) @USE_CUDA_TRUE@lib_LTLIBRARIES = libeztrace-convert-cuda.la \ @USE_CUDA_TRUE@ libeztrace-cuda.la \ @USE_CUDA_TRUE@ libeztrace-autostart-cuda.la # todo: do not hard-code these dir names @USE_CUDA_TRUE@AM_CFLAGS = -W -Wall -Wextra -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ @USE_CUDA_TRUE@ -I$(top_srcdir)/src/pptrace $(CUPTI_CFLAGS) @USE_CUDA_TRUE@NVCC_LDFLAGS = $(CUPTI_LDFLAGS) $(CUPTI_LIBS) @USE_CUDA_TRUE@libeztrace_convert_cuda_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) @USE_CUDA_TRUE@libeztrace_convert_cuda_la_LIBADD = $(GTGLIBADD) $(TLLIBADD) @USE_CUDA_TRUE@libeztrace_convert_cuda_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) @USE_CUDA_TRUE@libeztrace_convert_cuda_la_DEPENDENCIES = $(GTGDEPENDENCIES) @USE_CUDA_TRUE@libeztrace_convert_cuda_la_SOURCES = eztrace_convert_cuda.c @USE_CUDA_TRUE@libeztrace_cuda_la_SOURCES = cuda.cu cuda_runtime.cu cuda_driver.cu ezt_cuda.h @USE_CUDA_TRUE@libeztrace_cuda_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) @USE_CUDA_TRUE@libeztrace_cuda_la_LIBADD = $(CUDA_LIBS) -lcupti $(TLLIBADD) @USE_CUDA_TRUE@libeztrace_cuda_la_LDFLAGS = --no-undefined $(TLLDFLAGS) \ @USE_CUDA_TRUE@ $(CUDA_LDFLAGS) $(NVCC_LDFLAGS) -lcupti @USE_CUDA_TRUE@libeztrace_autostart_cuda_la_SOURCES = cuda.cu cuda_runtime.cu cuda_driver.cu \ @USE_CUDA_TRUE@ ezt_cuda.h @USE_CUDA_TRUE@libeztrace_autostart_cuda_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) @USE_CUDA_TRUE@libeztrace_autostart_cuda_la_LIBADD = $(CUDA_LIBS) -lcupti $(TLLIBADD) @USE_CUDA_TRUE@libeztrace_autostart_cuda_la_LDFLAGS = --no-undefined $(TLLDFLAGS) \ @USE_CUDA_TRUE@ $(CUDA_LDFLAGS) $(NVCC_LDFLAGS) -lcupti @USE_CUDA_TRUE@libeztrace_autostart_cuda_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra -DEZTRACE_AUTOSTART @USE_CUDA_TRUE@noinst_HEADERS = cuda_ev_codes.h \ @USE_CUDA_TRUE@ cudalt.py all: all-am .SUFFIXES: .SUFFIXES: .c .cu .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(srcdir)/cuda.mk $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/modules/cuda/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu src/modules/cuda/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(srcdir)/cuda.mk $(am__empty): $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ } uninstall-libLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ done clean-libLTLIBRARIES: -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) @list='$(lib_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libeztrace-autostart-cuda.la: $(libeztrace_autostart_cuda_la_OBJECTS) $(libeztrace_autostart_cuda_la_DEPENDENCIES) $(EXTRA_libeztrace_autostart_cuda_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_autostart_cuda_la_LINK) $(am_libeztrace_autostart_cuda_la_rpath) $(libeztrace_autostart_cuda_la_OBJECTS) $(libeztrace_autostart_cuda_la_LIBADD) $(LIBS) libeztrace-convert-cuda.la: $(libeztrace_convert_cuda_la_OBJECTS) $(libeztrace_convert_cuda_la_DEPENDENCIES) $(EXTRA_libeztrace_convert_cuda_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_convert_cuda_la_LINK) $(am_libeztrace_convert_cuda_la_rpath) $(libeztrace_convert_cuda_la_OBJECTS) $(libeztrace_convert_cuda_la_LIBADD) $(LIBS) libeztrace-cuda.la: $(libeztrace_cuda_la_OBJECTS) $(libeztrace_cuda_la_DEPENDENCIES) $(EXTRA_libeztrace_cuda_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_cuda_la_LINK) $(am_libeztrace_cuda_la_rpath) $(libeztrace_cuda_la_OBJECTS) $(libeztrace_cuda_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_cuda_la-eztrace_convert_cuda.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< libeztrace_convert_cuda_la-eztrace_convert_cuda.lo: eztrace_convert_cuda.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_cuda_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_cuda_la-eztrace_convert_cuda.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_cuda_la-eztrace_convert_cuda.Tpo -c -o libeztrace_convert_cuda_la-eztrace_convert_cuda.lo `test -f 'eztrace_convert_cuda.c' || echo '$(srcdir)/'`eztrace_convert_cuda.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_cuda_la-eztrace_convert_cuda.Tpo $(DEPDIR)/libeztrace_convert_cuda_la-eztrace_convert_cuda.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_cuda.c' object='libeztrace_convert_cuda_la-eztrace_convert_cuda.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_cuda_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_cuda_la-eztrace_convert_cuda.lo `test -f 'eztrace_convert_cuda.c' || echo '$(srcdir)/'`eztrace_convert_cuda.c mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) $(HEADERS) installdirs: for dir in "$(DESTDIR)$(libdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-libLTLIBRARIES install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-libLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libLTLIBRARIES clean-libtool cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-libLTLIBRARIES install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-libLTLIBRARIES .PRECIOUS: Makefile @USE_CUDA_TRUE@.cu.o: @USE_CUDA_TRUE@ $(NVCC) -o $@ -c $< $(AM_CPPFLAGS) $(AM_CFLAGS) $(TLCFLAGS) $(CUPTI_CFLAGS) @USE_CUDA_TRUE@.cu.lo: @USE_CUDA_TRUE@ python $(top_srcdir)/src/modules/cuda/cudalt.py $@ $(NVCC) --compiler-options=\" $(CFLAGS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(AM_CFLAGS) $(CPPFLAGS) \" $(TLCFLAGS) -c $< $(CUPTI_CFLAGS) # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/src/modules/cuda/cuda.cu000066400000000000000000000735251265506773700176250ustar00rootroot00000000000000#define _GNU_SOURCE 1 /* or _BSD_SOURCE or _SVID_SOURCE */ #define _REENTRANT #include #include #include #include #include #include #include "ezt_cuda.h" #include "cuda_ev_codes.h" #include "eztrace.h" extern "C" { // This CUDA module uses 2 different mechanisms for recording events: // - CPU events are recorded using wrappers (usual mechanism in EZTrace) // - GPU events are recording using the CUPTI activity mechanism. // // For the CUPTI mechanism, we ask CUDA to record events in a buffer. When we reach a synchronization point, // eztrace reads the buffer and record the corresponding events. #define DEFAULT_BUF_SIZE (2 * 1024 * 1024) static size_t __cuda_buf_size = DEFAULT_BUF_SIZE; static int __cupti_enabled = 0; #define ALIGN_SIZE (8) #define ALIGN_BUFFER(buffer, align) \ (((uintptr_t) (buffer) &((align)-1)) ? ((buffer)+(align) - ((uintptr_t)(buffer)&((align)-1))) : (buffer)) #define CUDA_CHECK_RETVAL(__func__, __expected_retval__) \ do { \ if(__func__ != __expected_retval__) { \ fprintf(stderr, "EZTrace: CUDA returned an error\n"); \ abort(); \ } \ } while(0) /**** * CUPTI-based functions ****/ /** * Allocate a new BUF_SIZE buffer for CUPTI */ static void bufferRequested(uint8_t **buffer, size_t *size, size_t *maxNumRecords) { uint8_t *bfr = (uint8_t *) malloc(__cuda_buf_size + ALIGN_SIZE); if (bfr == NULL) { fprintf(stderr, "Error: out of memory\n"); exit(-1); } *size = __cuda_buf_size; *buffer = ALIGN_BUFFER(bfr, ALIGN_SIZE); *maxNumRecords = 0; } // todo: create one timestamp per GPU static uint64_t startTimestamp = 0; int __ezt_cuda_initialized = 0; void __ezt_cuda_initialize() { if(!__ezt_cuda_initialized) { __ezt_cuda_initialized = 1; if(!__cupti_enabled) { fprintf(stderr, "[EZTrace-CUDA] Only CPU events will be recorded. To enable the recording of GPU-events, set the EZTRACE_CUDA_CUPTI_ENABLED environment variable\n"); } int num_gpus = 0; cudaGetDeviceCount(&num_gpus); CUDA_CHECK_RETVAL(cuptiGetTimestamp(&startTimestamp), CUPTI_SUCCESS); EZTRACE_EVENT_PACKED_0(EZTRACE_CUDA_CUINIT); EZTRACE_EVENT_PACKED_1(EZTRACE_CUDA_SETNBDEVICES, num_gpus); } } /* set to 1 when all the hooks are set.... * This is usefull in order to avoid recursive calls */ static int __cuda_initialized = 0; static const char * getMemcpyKindString(CUpti_ActivityMemcpyKind kind) { switch (kind) { case CUPTI_ACTIVITY_MEMCPY_KIND_HTOD: return "HtoD"; case CUPTI_ACTIVITY_MEMCPY_KIND_DTOH: return "DtoH"; case CUPTI_ACTIVITY_MEMCPY_KIND_HTOA: return "HtoA"; case CUPTI_ACTIVITY_MEMCPY_KIND_ATOH: return "AtoH"; case CUPTI_ACTIVITY_MEMCPY_KIND_ATOA: return "AtoA"; case CUPTI_ACTIVITY_MEMCPY_KIND_ATOD: return "AtoD"; case CUPTI_ACTIVITY_MEMCPY_KIND_DTOA: return "DtoA"; case CUPTI_ACTIVITY_MEMCPY_KIND_DTOD: return "DtoD"; case CUPTI_ACTIVITY_MEMCPY_KIND_HTOH: return "HtoH"; default: break; } return ""; } static void __process_memcpy_record(CUpti_ActivityMemcpy2 *memcpy_info) { float start_date = memcpy_info->start - startTimestamp; float stop_date = memcpy_info->end - startTimestamp; ezt_cuda_size_t cpy_size = memcpy_info->bytes; enum ezt_cudaMemcpyKind type = CUPTI_ACTIVITY_MEMCPY_KIND_TO_EZT((CUpti_ActivityMemcpyKind)memcpy_info->copyKind); int srcDeviceId = memcpy_info->deviceId; int destDeviceId = memcpy_info->dstDeviceId; EZTRACE_EVENT_PACKED_6(EZTRACE_CUDA_GPU_MEMCPY_TIMESTAMPS, start_date, stop_date, cpy_size, type, srcDeviceId, destDeviceId); } struct kernel_info_t{ const char* name; }; static uint32_t nb_kernels = 0; static uint32_t nb_allocated_kernels = 0; static struct kernel_info_t *kernels; static kernel_id_t __register_kernel(const char* kernel_name) { uint32_t i; for(i=0; i nb_allocated_kernels) { // not enough space in the array. expand the array nb_allocated_kernels *= 2; struct kernel_info_t *ptr = (struct kernel_info_t *)realloc(kernels, nb_allocated_kernels*sizeof(struct kernel_info_t)); if(!ptr) { fprintf(stderr, "[EZTrace] Cannot allocate memory. Aborting\n"); abort(); } kernels = ptr; } // register the kernel kernels[nb_kernels-1].name = kernel_name; EZTRACE_EVENT_PACKED_1(EZTRACE_CUDA_REGISTER_KERNEL, nb_kernels-1); litl_write_probe_raw(__ezt_trace.litl_trace, EZTRACE_CUDA_KERNEL_NAME, strlen(kernels[nb_kernels-1].name), (litl_data_t*)kernels[nb_kernels-1].name); return nb_kernels-1; } static void __process_kernel_record(CUpti_ActivityKernel2 *kernel) { static unsigned next_kernel_id = 0; // todo: use the correlationId or something similar to identify the kernels unsigned current_id = next_kernel_id++; kernel_id_t kernel_id = __register_kernel(kernel->name); EZTRACE_EVENT_PACKED_5(EZTRACE_CUDA_GPU_KERNEL_TIMESTAMPS, current_id, (float)(kernel->start - startTimestamp), (float)(kernel->end - startTimestamp), kernel_id, (uint32_t)kernel->deviceId); } static sem_t __flush_sem; void CUPTIAPI bufferCompleted(CUcontext ctx, uint32_t streamId, uint8_t *buffer, size_t size, size_t validSize) { CUptiResult status; CUpti_Activity *record = NULL; if (validSize > 0) { __ezt_cuda_initialize(); if(sem_wait(&__flush_sem) != 0) { abort(); } do { status = cuptiActivityGetNextRecord(buffer, validSize, &record); if(status == CUPTI_SUCCESS) { switch(record->kind) { case CUPTI_ACTIVITY_KIND_MEMCPY: { __process_memcpy_record((CUpti_ActivityMemcpy2 *)record); break; } case CUPTI_ACTIVITY_KIND_KERNEL: case CUPTI_ACTIVITY_KIND_CONCURRENT_KERNEL: { __process_kernel_record((CUpti_ActivityKernel2 *)record); break; } default: printf(" \n", record->kind); break; } } else if (status == CUPTI_ERROR_MAX_LIMIT_REACHED) { break; } else { CUDA_CHECK_RETVAL(status, CUPTI_SUCCESS); } } while (1); if(sem_post(&__flush_sem) != 0) { abort(); } // report any records dropped from the queue size_t dropped; CUDA_CHECK_RETVAL(cuptiActivityGetNumDroppedRecords(ctx, streamId, &dropped), CUPTI_SUCCESS); if (dropped != 0) { fprintf(stderr, "[EZTrace-CUDA] %u events were dropped because the buffer dedicated to CUDA events is too small (%u bytes)\n", (unsigned int)dropped, __cuda_buf_size); fprintf(stderr, "[EZTrace-CUDA]\tYou can change this buffer size by setting EZTRACE_CUDA_BUFFER_SIZE\n"); } } free(buffer); } /**** CUDA runtime interface ****/ cudaError_t (*libcudaDeviceSynchronize)(); cudaError_t (*libcudaThreadSynchronize)(); // note: deprecated /* Kernel management */ cudaError_t (*libcudaLaunch)(const void *func); cudaError_t (*libcudaConfigureCall) ( dim3 gridDim, dim3 blockDim, size_t sharedMem, cudaStream_t stream ); /* Memory management */ cudaError_t (*libcudaMalloc)(void **devPtr, size_t size); cudaError_t (*libcudaMallocHost)(void **ptr, size_t size); cudaError_t (*libcudaMallocPitch)(void **devPtr, size_t *pitch, size_t width, size_t height); cudaError_t (*libcudaMallocArray)(struct cudaArray **array, const struct cudaChannelFormatDesc *desc, size_t width, size_t height, unsigned int flags); cudaError_t (*libcudaMalloc3D)(struct cudaPitchedPtr* pitchedDevPtr, struct cudaExtent extent); cudaError_t (*libcudaMalloc3DArray)(cudaArray_t *array, const struct cudaChannelFormatDesc* desc, struct cudaExtent extent, unsigned int flags); cudaError_t (*libcudaMallocMipmappedArray)(cudaMipmappedArray_t *mipmappedArray, const struct cudaChannelFormatDesc* desc, struct cudaExtent extent, unsigned int numLevels, unsigned int flags); cudaError_t (*libcudaFree)(void *devPtr); cudaError_t (*libcudaFreeHost)(void *ptr); cudaError_t (*libcudaFreeArray)(cudaArray_t array); cudaError_t (*libcudaFreeMipmappedArray)(cudaMipmappedArray_t mipmappedArray); cudaError_t (*libcudaHostAlloc)(void **pHost, size_t size, unsigned int flags); cudaError_t (*libcudaHostRegister)(void *ptr, size_t size, unsigned int flags); cudaError_t (*libcudaHostUnregister)(void *ptr); /* Memory Transfers */ cudaError_t (*libcudaMemcpy3D)(const struct cudaMemcpy3DParms *p); cudaError_t (*libcudaMemcpy3DPeer)(const struct cudaMemcpy3DPeerParms *p); cudaError_t (*libcudaMemcpy3DAsync)(const struct cudaMemcpy3DParms *p, cudaStream_t stream ); cudaError_t (*libcudaMemcpy3DPeerAsync)(const struct cudaMemcpy3DPeerParms *p, cudaStream_t stream ); cudaError_t (*libcudaMemcpy)(void *dst, const void *src, size_t count, enum cudaMemcpyKind kind); cudaError_t (*libcudaMemcpyPeer)(void *dst, int dstDevice, const void *src, int srcDevice, size_t count); cudaError_t (*libcudaMemcpyToArray)(cudaArray_t dst, size_t wOffset, size_t hOffset, const void *src, size_t count, enum cudaMemcpyKind kind); cudaError_t (*libcudaMemcpyFromArray)(void *dst, cudaArray_const_t src, size_t wOffset, size_t hOffset, size_t count, enum cudaMemcpyKind kind); cudaError_t (*libcudaMemcpyArrayToArray)(cudaArray_t dst, size_t wOffsetDst, size_t hOffsetDst, cudaArray_const_t src, size_t wOffsetSrc, size_t hOffsetSrc, size_t count, enum cudaMemcpyKind kind); cudaError_t (*libcudaMemcpy2D)(void *dst, size_t dpitch, const void *src, size_t spitch, size_t width, size_t height, enum cudaMemcpyKind kind); cudaError_t (*libcudaMemcpy2DToArray)(cudaArray_t dst, size_t wOffset, size_t hOffset, const void *src, size_t spitch, size_t width, size_t height, enum cudaMemcpyKind kind); cudaError_t (*libcudaMemcpy2DFromArray)(void *dst, size_t dpitch, cudaArray_const_t src, size_t wOffset, size_t hOffset, size_t width, size_t height, enum cudaMemcpyKind kind); cudaError_t (*libcudaMemcpy2DArrayToArray)(cudaArray_t dst, size_t wOffsetDst, size_t hOffsetDst, cudaArray_const_t src, size_t wOffsetSrc, size_t hOffsetSrc, size_t width, size_t height, enum cudaMemcpyKind kind); cudaError_t (*libcudaMemcpyToSymbol)(const void *symbol, const void *src, size_t count, size_t offset , enum cudaMemcpyKind kind); cudaError_t (*libcudaMemcpyFromSymbol)(void *dst, const void *symbol, size_t count, size_t offset , enum cudaMemcpyKind kind); cudaError_t (*libcudaMemcpyAsync)(void *dst, const void *src, size_t count, enum cudaMemcpyKind kind, cudaStream_t stream ); cudaError_t (*libcudaMemcpyPeerAsync)(void *dst, int dstDevice, const void *src, int srcDevice, size_t count, cudaStream_t stream ); cudaError_t (*libcudaMemcpyToArrayAsync)(cudaArray_t dst, size_t wOffset, size_t hOffset, const void *src, size_t count, enum cudaMemcpyKind kind, cudaStream_t stream ); cudaError_t (*libcudaMemcpyFromArrayAsync)(void *dst, cudaArray_const_t src, size_t wOffset, size_t hOffset, size_t count, enum cudaMemcpyKind kind, cudaStream_t stream ); cudaError_t (*libcudaMemcpy2DAsync)(void *dst, size_t dpitch, const void *src, size_t spitch, size_t width, size_t height, enum cudaMemcpyKind kind, cudaStream_t stream ); cudaError_t (*libcudaMemcpy2DToArrayAsync)(cudaArray_t dst, size_t wOffset, size_t hOffset, const void *src, size_t spitch, size_t width, size_t height, enum cudaMemcpyKind kind, cudaStream_t stream ); cudaError_t (*libcudaMemcpy2DFromArrayAsync)(void *dst, size_t dpitch, cudaArray_const_t src, size_t wOffset, size_t hOffset, size_t width, size_t height, enum cudaMemcpyKind kind, cudaStream_t stream ); cudaError_t (*libcudaMemcpyToSymbolAsync)(const void *symbol, const void *src, size_t count, size_t offset, enum cudaMemcpyKind kind, cudaStream_t stream ); cudaError_t (*libcudaMemcpyFromSymbolAsync)(void *dst, const void *symbol, size_t count, size_t offset, enum cudaMemcpyKind kind, cudaStream_t stream ); cudaError_t (*libcudaMemset)(void *devPtr, int value, size_t count); cudaError_t (*libcudaMemset2D)(void *devPtr, size_t pitch, int value, size_t width, size_t height); cudaError_t (*libcudaMemset3D)(struct cudaPitchedPtr pitchedDevPtr, int value, struct cudaExtent extent); cudaError_t (*libcudaMemsetAsync)(void *devPtr, int value, size_t count, cudaStream_t stream ); cudaError_t (*libcudaMemset2DAsync)(void *devPtr, size_t pitch, int value, size_t width, size_t height, cudaStream_t stream ); cudaError_t (*libcudaMemset3DAsync)(struct cudaPitchedPtr pitchedDevPtr, int value, struct cudaExtent extent, cudaStream_t stream ); /**** CUDA driver interface ****/ #if 0 CUresult (*libcuMemcpyAtoA_v2)(CUarray dstArray, size_t dstOffset, CUarray srcArray, size_t srcOffset, size_t ByteCount); CUresult (*libcuMemcpyAtoD_v2)(CUdeviceptr dstDevice, CUarray srcArray, size_t srcOffset, size_t ByteCount); CUresult (*libcuMemcpyAtoH_v2)(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount); CUresult (*libcuMemcpyDtoA_v2)(CUarray dstArray, size_t dstOffset, CUdeviceptr srcDevice, size_t ByteCount); CUresult (*libcuMemcpyDtoD_v2)(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount); CUresult (*libcuMemcpyDtoH_v2)(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount); CUresult (*libcuMemcpyHtoA_v2)(CUarray dstArray, size_t dstOffset, const void* srcHost, size_t ByteCount); CUresult (*libcuMemcpyHtoD_v2)(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount); CUresult (*libcuMemFree_v2)(CUdeviceptr dptr); CUresult (*libcuMemAlloc_v2)(CUdeviceptr *dptr, size_t bytesize); CUresult (*libcuMemcpy) (CUdeviceptr dst, CUdeviceptr src, size_t ByteCount); CUresult (*libcuLaunchKernel)(CUfunction f, unsigned int gridDimX, unsigned int gridDimY, unsigned int gridDimZ, unsigned int blockDimX, unsigned int blockDimY, unsigned int blockDimZ, unsigned int sharedMemBytes, CUstream hStream, void ** kernelParams, void ** extra); #endif /* Kernel management */ CUresult (*libcuLaunchKernel)(CUfunction f, unsigned int gridDimX, unsigned int gridDimY, unsigned int gridDimZ, unsigned int blockDimX, unsigned int blockDimY, unsigned int blockDimZ, unsigned int sharedMemBytes, CUstream hStream, void **kernelParams, void **extra); CUresult (*libcuLaunch)(CUfunction f); CUresult (*libcuLaunchGrid)(CUfunction f, int grid_width, int grid_height); CUresult (*libcuLaunchGridAsync)(CUfunction f, int grid_width, int grid_height, CUstream hStream); /* Memory Management */ CUresult (*libcuMemGetInfo_v2)(size_t *free, size_t *total); CUresult (*libcuMemAlloc_v2)(CUdeviceptr *dptr, size_t bytesize); CUresult (*libcuMemAllocPitch_v2)(CUdeviceptr *dptr, size_t *pPitch, size_t WidthInBytes, size_t Height, unsigned int ElementSizeBytes); CUresult (*libcuMemFree_v2)(CUdeviceptr dptr); CUresult (*libcuMemAllocHost_v2)(void **pp, size_t bytesize); CUresult (*libcuMemFreeHost)(void *p); CUresult (*libcuMemHostAlloc)(void **pp, size_t bytesize, unsigned int Flags); CUresult (*libcuMemHostRegister)(void *p, size_t bytesize, unsigned int Flags); CUresult (*libcuMemHostUnregister)(void *p); /* Memory Transfers */ CUresult (*libcuMemcpy)(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount); CUresult (*libcuMemcpyPeer)(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount); CUresult (*libcuMemcpyHtoD_v2)(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount); CUresult (*libcuMemcpyDtoH_v2)(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount); CUresult (*libcuMemcpyDtoD_v2)(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount); CUresult (*libcuMemcpyDtoA_v2)(CUarray dstArray, size_t dstOffset, CUdeviceptr srcDevice, size_t ByteCount); CUresult (*libcuMemcpyAtoD_v2)(CUdeviceptr dstDevice, CUarray srcArray, size_t srcOffset, size_t ByteCount); CUresult (*libcuMemcpyHtoA_v2)(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount); CUresult (*libcuMemcpyAtoH_v2)(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount); CUresult (*libcuMemcpyAtoA_v2)(CUarray dstArray, size_t dstOffset, CUarray srcArray, size_t srcOffset, size_t ByteCount); CUresult (*libcuMemcpy2D_v2)(const CUDA_MEMCPY2D *pCopy); CUresult (*libcuMemcpy2DUnaligned_v2)(const CUDA_MEMCPY2D *pCopy); CUresult (*libcuMemcpy3D_v2)(const CUDA_MEMCPY3D *pCopy); CUresult (*libcuMemcpy3DPeer)(const CUDA_MEMCPY3D_PEER *pCopy); CUresult (*libcuMemcpyAsync)(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount, CUstream hStream); CUresult (*libcuMemcpyPeerAsync)(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount, CUstream hStream); CUresult (*libcuMemcpyHtoDAsync_v2)(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount, CUstream hStream); CUresult (*libcuMemcpyDtoHAsync_v2)(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream); CUresult (*libcuMemcpyDtoDAsync_v2)(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream); CUresult (*libcuMemcpyHtoAAsync_v2)(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount, CUstream hStream); CUresult (*libcuMemcpyAtoHAsync_v2)(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount, CUstream hStream); CUresult (*libcuMemcpy2DAsync_v2)(const CUDA_MEMCPY2D *pCopy, CUstream hStream); CUresult (*libcuMemcpy3DAsync_v2)(const CUDA_MEMCPY3D *pCopy, CUstream hStream); CUresult (*libcuMemcpy3DPeerAsync)(const CUDA_MEMCPY3D_PEER *pCopy, CUstream hStream); CUresult (*libcuMemsetD8_v2)(CUdeviceptr dstDevice, unsigned char uc, size_t N); CUresult (*libcuMemsetD16_v2)(CUdeviceptr dstDevice, unsigned short us, size_t N); CUresult (*libcuMemsetD32_v2)(CUdeviceptr dstDevice, unsigned int ui, size_t N); CUresult (*libcuMemsetD2D8_v2)(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height); CUresult (*libcuMemsetD2D16_v2)(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height); CUresult (*libcuMemsetD2D32_v2)(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height); CUresult (*libcuMemsetD8Async)(CUdeviceptr dstDevice, unsigned char uc, size_t N, CUstream hStream); CUresult (*libcuMemsetD16Async)(CUdeviceptr dstDevice, unsigned short us, size_t N, CUstream hStream); CUresult (*libcuMemsetD32Async)(CUdeviceptr dstDevice, unsigned int ui, size_t N, CUstream hStream); CUresult (*libcuMemsetD2D8Async)(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height, CUstream hStream); CUresult (*libcuMemsetD2D16Async)(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height, CUstream hStream); CUresult (*libcuMemsetD2D32Async)(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height, CUstream hStream); #if 0 /* is it useful ? */ CUresult (*libcuArrayCreate)(CUarray *pHandle, const CUDA_ARRAY_DESCRIPTOR *pAllocateArray); CUresult (*libcuArrayGetDescriptor)(CUDA_ARRAY_DESCRIPTOR *pArrayDescriptor, CUarray hArray); CUresult (*libcuArrayDestroy)(CUarray hArray); CUresult (*libcuArray3DCreate)(CUarray *pHandle, const CUDA_ARRAY3D_DESCRIPTOR *pAllocateArray); CUresult (*libcuArray3DGetDescriptor)(CUDA_ARRAY3D_DESCRIPTOR *pArrayDescriptor, CUarray hArray); CUresult (*libcuMipmappedArrayCreate)(CUmipmappedArray *pHandle, const CUDA_ARRAY3D_DESCRIPTOR *pMipmappedArrayDesc, unsigned int numMipmapLevels); CUresult (*libcuMipmappedArrayGetLevel)(CUarray *pLevelArray, CUmipmappedArray hMipmappedArray, unsigned int level); CUresult (*libcuMipmappedArrayDestroy)(CUmipmappedArray hMipmappedArray); #endif // CUresult (*libcuCtxSynchronize)(void); // CUresult (*libcuDeviceTotalMem)(unsigned int *bytes, CUdevice dev); #if 0 START_INTERCEPT INTERCEPT2("cudaLaunch", libcudaLaunch) INTERCEPT2("cudaMalloc", libcudaMalloc) INTERCEPT2("cudaFree", libcudaFree) INTERCEPT2("cudaConfigureCall", libcudaConfigureCall) INTERCEPT2("cudaMemcpy", libcudaMemcpy) INTERCEPT2("cudaMemcpyAsync", libcudaMemcpyAsync) INTERCEPT2("cudaDeviceSynchronize", libcudaDeviceSynchronize) INTERCEPT2("cudaThreadSynchronize", libcudaThreadSynchronize) INTERCEPT2("cuLaunchKernel", libcuLaunchKernel) INTERCEPT2("cuMemcpy", libcuMemcpy) INTERCEPT2("cuMemcpyAtoA_v2", libcuMemcpyAtoA_v2) INTERCEPT2("cuMemcpyAtoD_v2", libcuMemcpyAtoD_v2) INTERCEPT2("cuMemcpyAtoH_v2", libcuMemcpyAtoH_v2) INTERCEPT2("cuMemcpyDtoA_v2", libcuMemcpyDtoA_v2) INTERCEPT2("cuMemcpyDtoD_v2", libcuMemcpyDtoD_v2) INTERCEPT2("cuMemcpyDtoH_v2", libcuMemcpyDtoH_v2) INTERCEPT2("cuMemcpyHtoA_v2", libcuMemcpyHtoA_v2) INTERCEPT2("cuMemcpyHtoD_v2", libcuMemcpyHtoD_v2) INTERCEPT2("cuMemFree_v2",libcuMemFree_v2) INTERCEPT2("cuMemAlloc_v2", libcuMemAlloc_v2) END_INTERCEPT; #endif START_INTERCEPT_MODULE(cuda) INTERCEPT2("cudaDeviceSynchronize", libcudaDeviceSynchronize) INTERCEPT2("cudaThreadSynchronize", libcudaThreadSynchronize) INTERCEPT2("cudaLaunch", libcudaLaunch) INTERCEPT2("cudaConfigureCall", libcudaConfigureCall) INTERCEPT2("cudaMalloc", libcudaMalloc) INTERCEPT2("cudaMallocHost", libcudaMallocHost) INTERCEPT2("cudaMallocPitch", libcudaMallocPitch) INTERCEPT2("cudaMallocArray", libcudaMallocArray) INTERCEPT2("cudaMalloc3D", libcudaMalloc3D) INTERCEPT2("cudaMalloc3DArray", libcudaMalloc3DArray) INTERCEPT2("cudaMallocMipmappedArray", libcudaMallocMipmappedArray) INTERCEPT2("cudaFree", libcudaFree) INTERCEPT2("cudaFreeHost", libcudaFreeHost) INTERCEPT2("cudaFreeArray", libcudaFreeArray) INTERCEPT2("cudaFreeMipmappedArray", libcudaFreeMipmappedArray) INTERCEPT2("cudaHostAlloc", libcudaHostAlloc) INTERCEPT2("cudaHostRegister", libcudaHostRegister) INTERCEPT2("cudaHostUnregister", libcudaHostUnregister) INTERCEPT2("cudaMemcpy3D", libcudaMemcpy3D) INTERCEPT2("cudaMemcpy3DPeer", libcudaMemcpy3DPeer) INTERCEPT2("cudaMemcpy3DAsync", libcudaMemcpy3DAsync) INTERCEPT2("cudaMemcpy3DPeerAsync", libcudaMemcpy3DPeerAsync) INTERCEPT2("cudaMemcpy", libcudaMemcpy) INTERCEPT2("cudaMemcpyPeer", libcudaMemcpyPeer) INTERCEPT2("cudaMemcpyToArray", libcudaMemcpyToArray) INTERCEPT2("cudaMemcpyFromArray", libcudaMemcpyFromArray) INTERCEPT2("cudaMemcpyArrayToArray", libcudaMemcpyArrayToArray) INTERCEPT2("cudaMemcpy2D", libcudaMemcpy2D) INTERCEPT2("cudaMemcpy2DToArray", libcudaMemcpy2DToArray) INTERCEPT2("cudaMemcpy2DFromArray", libcudaMemcpy2DFromArray) INTERCEPT2("cudaMemcpy2DArrayToArray", libcudaMemcpy2DArrayToArray) INTERCEPT2("cudaMemcpyToSymbol", libcudaMemcpyToSymbol) INTERCEPT2("cudaMemcpyFromSymbol", libcudaMemcpyFromSymbol) INTERCEPT2("cudaMemcpyAsync", libcudaMemcpyAsync) INTERCEPT2("cudaMemcpyPeerAsync", libcudaMemcpyPeerAsync) INTERCEPT2("cudaMemcpyToArrayAsync", libcudaMemcpyToArrayAsync) INTERCEPT2("cudaMemcpyFromArrayAsync", libcudaMemcpyFromArrayAsync) INTERCEPT2("cudaMemcpy2DAsync", libcudaMemcpy2DAsync) INTERCEPT2("cudaMemcpy2DToArrayAsync", libcudaMemcpy2DToArrayAsync) INTERCEPT2("cudaMemcpy2DFromArrayAsync", libcudaMemcpy2DFromArrayAsync) INTERCEPT2("cudaMemcpyToSymbolAsync", libcudaMemcpyToSymbolAsync) INTERCEPT2("cudaMemcpyFromSymbolAsync", libcudaMemcpyFromSymbolAsync) INTERCEPT2("cudaMemset", libcudaMemset) INTERCEPT2("cudaMemset2D", libcudaMemset2D) INTERCEPT2("cudaMemset3D", libcudaMemset3D) INTERCEPT2("cudaMemsetAsync", libcudaMemsetAsync) INTERCEPT2("cudaMemset2DAsync", libcudaMemset2DAsync) INTERCEPT2("cudaMemset3DAsync", libcudaMemset3DAsync) INTERCEPT2("cuMemcpyAtoA_v2", libcuMemcpyAtoA_v2) INTERCEPT2("cuMemcpyAtoD_v2", libcuMemcpyAtoD_v2) INTERCEPT2("cuMemcpyAtoH_v2", libcuMemcpyAtoH_v2) INTERCEPT2("cuMemcpyDtoA_v2", libcuMemcpyDtoA_v2) INTERCEPT2("cuMemcpyDtoD_v2", libcuMemcpyDtoD_v2) INTERCEPT2("cuMemcpyDtoH_v2", libcuMemcpyDtoH_v2) INTERCEPT2("cuMemcpyHtoA_v2", libcuMemcpyHtoA_v2) INTERCEPT2("cuMemcpyHtoD_v2", libcuMemcpyHtoD_v2) INTERCEPT2("cuMemFree_v2", libcuMemFree_v2) INTERCEPT2("cuMemAlloc_v2", libcuMemAlloc_v2) INTERCEPT2("cuMemcpy", libcuMemcpy) INTERCEPT2("cuLaunchKernel", libcuLaunchKernel) INTERCEPT2("cuLaunchKernel", libcuLaunchKernel) INTERCEPT2("cuLaunch", libcuLaunch) INTERCEPT2("cuLaunchGrid", libcuLaunchGrid) INTERCEPT2("cuLaunchGridAsync", libcuLaunchGridAsync) INTERCEPT2("cuMemGetInfo_v2", libcuMemGetInfo_v2) INTERCEPT2("cuMemAlloc_v2", libcuMemAlloc_v2) INTERCEPT2("cuMemAllocPitch_v2", libcuMemAllocPitch_v2) INTERCEPT2("cuMemFree_v2", libcuMemFree_v2) INTERCEPT2("cuMemAllocHost_v2", libcuMemAllocHost_v2) INTERCEPT2("cuMemFreeHost", libcuMemFreeHost) INTERCEPT2("cuMemHostAlloc", libcuMemHostAlloc) INTERCEPT2("cuMemHostRegister", libcuMemHostRegister) INTERCEPT2("cuMemHostUnregister", libcuMemHostUnregister) INTERCEPT2("cuMemcpy", libcuMemcpy) INTERCEPT2("cuMemcpyPeer", libcuMemcpyPeer) INTERCEPT2("cuMemcpyHtoD_v2", libcuMemcpyHtoD_v2) INTERCEPT2("cuMemcpyDtoH_v2", libcuMemcpyDtoH_v2) INTERCEPT2("cuMemcpyDtoD_v2", libcuMemcpyDtoD_v2) INTERCEPT2("cuMemcpyDtoA_v2", libcuMemcpyDtoA_v2) INTERCEPT2("cuMemcpyAtoD_v2", libcuMemcpyAtoD_v2) INTERCEPT2("cuMemcpyHtoA_v2", libcuMemcpyHtoA_v2) INTERCEPT2("cuMemcpyAtoH_v2", libcuMemcpyAtoH_v2) INTERCEPT2("cuMemcpyAtoA_v2", libcuMemcpyAtoA_v2) INTERCEPT2("cuMemcpy2D_v2", libcuMemcpy2D_v2) INTERCEPT2("cuMemcpy2DUnaligned_v2", libcuMemcpy2DUnaligned_v2) INTERCEPT2("cuMemcpy3D_v2", libcuMemcpy3D_v2) INTERCEPT2("cuMemcpy3DPeer", libcuMemcpy3DPeer) INTERCEPT2("cuMemcpyAsync", libcuMemcpyAsync) INTERCEPT2("cuMemcpyPeerAsync", libcuMemcpyPeerAsync) INTERCEPT2("cuMemcpyHtoDAsync_v2", libcuMemcpyHtoDAsync_v2) INTERCEPT2("cuMemcpyDtoHAsync_v2", libcuMemcpyDtoHAsync_v2) INTERCEPT2("cuMemcpyDtoDAsync_v2", libcuMemcpyDtoDAsync_v2) INTERCEPT2("cuMemcpyHtoAAsync_v2", libcuMemcpyHtoAAsync_v2) INTERCEPT2("cuMemcpyAtoHAsync_v2", libcuMemcpyAtoHAsync_v2) INTERCEPT2("cuMemcpy2DAsync_v2", libcuMemcpy2DAsync_v2) INTERCEPT2("cuMemcpy3DAsync_v2", libcuMemcpy3DAsync_v2) INTERCEPT2("cuMemcpy3DPeerAsync", libcuMemcpy3DPeerAsync) INTERCEPT2("cuMemsetD8_v2", libcuMemsetD8_v2) INTERCEPT2("cuMemsetD16_v2", libcuMemsetD16_v2) INTERCEPT2("cuMemsetD32_v2", libcuMemsetD32_v2) INTERCEPT2("cuMemsetD2D8_v2", libcuMemsetD2D8_v2) INTERCEPT2("cuMemsetD2D16_v2", libcuMemsetD2D16_v2) INTERCEPT2("cuMemsetD2D32_v2", libcuMemsetD2D32_v2) INTERCEPT2("cuMemsetD8Async", libcuMemsetD8Async) INTERCEPT2("cuMemsetD16Async", libcuMemsetD16Async) INTERCEPT2("cuMemsetD32Async", libcuMemsetD32Async) INTERCEPT2("cuMemsetD2D8Async", libcuMemsetD2D8Async) INTERCEPT2("cuMemsetD2D16Async", libcuMemsetD2D16Async) INTERCEPT2("cuMemsetD2D32Async", libcuMemsetD2D32Async) END_INTERCEPT_MODULE(cuda); #if 0 INTERCEPT2("cuArrayCreate", libcuArrayCreate) INTERCEPT2("cuArrayGetDescriptor", libcuArrayGetDescriptor) INTERCEPT2("cuArrayDestroy", libcuArrayDestroy) INTERCEPT2("cuArray3DCreate", libcuArray3DCreate) INTERCEPT2("cuArray3DGetDescriptor", libcuArray3DGetDescriptor) INTERCEPT2("cuMipmappedArrayCreate", libcuMipmappedArrayCreate) INTERCEPT2("cuMipmappedArrayGetLevel", libcuMipmappedArrayGetLevel) INTERCEPT2("cuMipmappedArrayDestroy", libcuMipmappedArrayDestroy) INTERCEPT2("libcuCtxSynchronize", libcuCtxSynchronize) INTERCEPT2("libcuDeviceTotalMem", libcuDeviceTotalMem) #endif CUpti_SubscriberHandle subscriber; static void __init_buffer_size() { char* str = getenv("EZTRACE_CUDA_BUFFER_SIZE"); if(str) { __cuda_buf_size = atoi(str); fprintf(stderr, "Setting CUDA buffer size to %d bytes\n", __cuda_buf_size); } } static void __init_cupti() { char* str = getenv("EZTRACE_CUDA_CUPTI_DISABLED"); if(str) { __cupti_enabled = 0; } else { __cupti_enabled = 1; } if(__cupti_enabled) { fprintf(stderr, "[EZTrace][CUDA] CUPTI is enabled\n"); __cupti_enabled = 1; kernels = (struct kernel_info_t*) malloc(sizeof(struct kernel_info_t)*1024); nb_allocated_kernels = 1024; // device activity record is created when CUDA initializes, so we // want to enable it before cuInit() or any CUDA runtime call CUDA_CHECK_RETVAL(cuptiActivityEnable(CUPTI_ACTIVITY_KIND_KERNEL), CUPTI_SUCCESS); CUDA_CHECK_RETVAL(cuptiActivityEnable(CUPTI_ACTIVITY_KIND_MEMCPY), CUPTI_SUCCESS); CUDA_CHECK_RETVAL(cuptiActivityEnable(CUPTI_ACTIVITY_KIND_MEMSET), CUPTI_SUCCESS); // Register callbacks for buffer requests and for buffers completed by CUPTI. CUDA_CHECK_RETVAL(cuptiActivityRegisterCallbacks(bufferRequested, bufferCompleted), CUPTI_SUCCESS); if(sem_init(&__flush_sem, 0, 1) != 0 ){ abort(); } } } // flush all pending buffers static void __ezt_cuda_flush(void*param) { if(__cupti_enabled) { CUDA_CHECK_RETVAL(cuptiActivityFlushAll(CUPTI_ACTIVITY_FLAG_FORCE_INT), CUPTI_SUCCESS); // make sure there isn't another thread that is flushing the cuda buffer if(sem_wait(&__flush_sem) != 0) { abort(); } } } static void __cuda_init (void) __attribute__ ((constructor)); static void __cuda_init (void) { DYNAMIC_INTERCEPT_ALL_MODULE(cuda); __init_buffer_size(); __init_cupti(); // we need to flush all the pending buffers before closing the trace so that we don't lose // any event from the GPU eztrace_atexit(__ezt_cuda_flush, NULL); #ifdef EZTRACE_AUTOSTART eztrace_start(); #endif __cuda_initialized = 1; } static void __cuda_conclude (void) __attribute__ ((destructor)); static void __cuda_conclude (void) { __cuda_initialized = 0; if(__cupti_enabled) { cuptiUnsubscribe(subscriber); } eztrace_stop(); } } eztrace-1.1-2/src/modules/cuda/cuda.mk000066400000000000000000000004471265506773700176160ustar00rootroot00000000000000.cu.o: $(NVCC) -o $@ -c $< $(AM_CPPFLAGS) $(AM_CFLAGS) $(TLCFLAGS) $(CUPTI_CFLAGS) .cu.lo: python $(top_srcdir)/src/modules/cuda/cudalt.py $@ $(NVCC) --compiler-options=\" $(CFLAGS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(AM_CFLAGS) $(CPPFLAGS) \" $(TLCFLAGS) -c $< $(CUPTI_CFLAGS) eztrace-1.1-2/src/modules/cuda/cuda_driver.cu000066400000000000000000000507741265506773700212010ustar00rootroot00000000000000#define _GNU_SOURCE 1 /* or _BSD_SOURCE or _SVID_SOURCE */ #define _REENTRANT #include #include #include #include #include "ezt_cuda.h" #include "cuda_ev_codes.h" #include "eztrace.h" extern "C" { static unsigned kernel_id = 0; /* Kernel management */ CUresult cuLaunchKernel(CUfunction f, unsigned int gridDimX, unsigned int gridDimY, unsigned int gridDimZ, unsigned int blockDimX, unsigned int blockDimY, unsigned int blockDimZ, unsigned int sharedMemBytes, CUstream hStream, void **kernelParams, void **extra) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; unsigned current_id = kernel_id++; // TODO: distinguish between runtime and driver API CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CULAUNCHKERNEL_START, deviceId, current_id); res = libcuLaunchKernel(f, gridDimX, gridDimY, gridDimZ, blockDimX, blockDimY, blockDimZ, sharedMemBytes, hStream, kernelParams, extra); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CULAUNCHKERNEL_STOP, deviceId, current_id); return res; } CUresult cuLaunch(CUfunction f) { // deprecated FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; unsigned current_id = kernel_id++; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CULAUNCHKERNEL_START, deviceId, current_id); res = libcuLaunch(f); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CULAUNCHKERNEL_STOP, deviceId, current_id); return res; } CUresult cuLaunchGrid(CUfunction f, int grid_width, int grid_height) { // deprecated FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; unsigned current_id = kernel_id++; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CULAUNCHKERNEL_START, deviceId, current_id); res = libcuLaunchGrid(f, grid_width, grid_height); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CULAUNCHKERNEL_STOP, deviceId, current_id); return res; } CUresult cuLaunchGridAsync(CUfunction f, int grid_width, int grid_height, CUstream hStream) { // deprecated FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; unsigned current_id = kernel_id++; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CULAUNCHKERNEL_START, deviceId, current_id); res = libcuLaunchGridAsync(f, grid_width, grid_height, hStream); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CULAUNCHKERNEL_STOP, deviceId, current_id); return res; } /* Memory Management */ CUresult cuMemAlloc_v2(CUdeviceptr *dptr, size_t bytesize) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = bytesize; EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUMEMALLOC_START, deviceId, size); res = libcuMemAlloc_v2(dptr, bytesize); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMALLOC_STOP, deviceId, size, (app_ptr)*dptr); return res; } CUresult cuMemAllocPitch_v2(CUdeviceptr *dptr, size_t *pPitch, size_t WidthInBytes, size_t Height, unsigned int ElementSizeBytes) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; ezt_cuda_size_t size = Height * WidthInBytes; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUMEMALLOC_START, deviceId, size); res = libcuMemAllocPitch_v2(dptr, pPitch, WidthInBytes, Height, ElementSizeBytes); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMALLOC_STOP, deviceId, size, *dptr); return res; } CUresult cuMemFree_v2(CUdeviceptr dptr) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUDAFREE_START, deviceId, dptr); res = libcuMemFree_v2(dptr); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUDAFREE_STOP, deviceId, dptr); return res; } /* Memory Transfers */ CUresult cuMemcpy(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, 0); res = libcuMemcpy(dst, src, ByteCount); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, 0); return res; } CUresult cuMemcpyAsync(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount, CUstream hStream) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, 0); res = libcuMemcpyAsync(dst, src, ByteCount, hStream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, 0); return res; } CUresult cuMemcpyAtoA_v2(CUarray dstArray, size_t dstOffset, CUarray srcArray, size_t srcOffset, size_t ByteCount) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_ATOA; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyAtoA_v2(dstArray, dstOffset, srcArray, srcOffset, ByteCount); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpyAtoD_v2(CUdeviceptr dstDevice, CUarray srcArray, size_t srcOffset, size_t ByteCount) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_ATOD; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyAtoD_v2(dstDevice, srcArray, srcOffset, ByteCount); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpyAtoH_v2(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_ATOH; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyAtoH_v2(dstHost, srcArray, srcOffset, ByteCount); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpyAtoHAsync_v2(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount, CUstream hStream) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_ATOH; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyAtoHAsync_v2(dstHost, srcArray, srcOffset, ByteCount, hStream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpyDtoA_v2(CUarray dstArray, size_t dstOffset, CUdeviceptr srcDevice, size_t ByteCount) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_DTOA; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyDtoA_v2(dstArray, dstOffset, srcDevice, ByteCount); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpyDtoD_v2(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_DTOD; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyDtoD_v2( dstDevice, srcDevice, ByteCount); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpyDtoDAsync_v2(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_DTOD; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyDtoDAsync_v2( dstDevice, srcDevice, ByteCount, hStream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpyDtoH_v2(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_DTOH; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyDtoH_v2(dstHost, srcDevice, ByteCount); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpyDtoHAsync_v2(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_DTOH; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyDtoHAsync_v2(dstHost, srcDevice, ByteCount, hStream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpyHtoA_v2(CUarray dstArray, size_t dstOffset, const void* srcHost, size_t ByteCount) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_HTOA; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyHtoA_v2( dstArray, dstOffset, srcHost, ByteCount); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpyHtoAAsync_v2(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount, CUstream hStream) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_HTOA; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyHtoAAsync_v2( dstArray, dstOffset, srcHost, ByteCount, hStream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpyHtoD_v2(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_HTOD; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyHtoD_v2( dstDevice, srcHost, ByteCount); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpyHtoDAsync_v2(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount, CUstream hStream) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = CUDA_MEMCPY_KIND_HTOD; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); ezt_cuda_size_t size = ByteCount; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpyHtoDAsync_v2( dstDevice, srcHost, ByteCount, hStream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpy2D_v2(const CUDA_MEMCPY2D *pCopy) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = memoryTypesToCpyKind(pCopy->srcMemoryType, pCopy->dstMemoryType); ezt_cuda_size_t size = pCopy->WidthInBytes * pCopy->Height; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpy2D_v2(pCopy); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpy2DUnaligned_v2(const CUDA_MEMCPY2D *pCopy) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = memoryTypesToCpyKind(pCopy->srcMemoryType, pCopy->dstMemoryType); ezt_cuda_size_t size = pCopy->WidthInBytes * pCopy->Height; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpy2DUnaligned_v2(pCopy); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpy2DAsync_v2(const CUDA_MEMCPY2D *pCopy, CUstream hStream) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = memoryTypesToCpyKind(pCopy->srcMemoryType, pCopy->dstMemoryType); ezt_cuda_size_t size = pCopy->WidthInBytes * pCopy->Height; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpy2DAsync_v2(pCopy, hStream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpy3D_v2(const CUDA_MEMCPY3D *pCopy) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = memoryTypesToCpyKind(pCopy->srcMemoryType, pCopy->dstMemoryType); ezt_cuda_size_t size = pCopy->WidthInBytes * pCopy->Height * pCopy->Depth; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpy3D_v2(pCopy); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } CUresult cuMemcpy3DAsync_v2(const CUDA_MEMCPY3D *pCopy, CUstream hStream) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; enum ezt_cudaMemcpyKind kind = memoryTypesToCpyKind(pCopy->srcMemoryType, pCopy->dstMemoryType); ezt_cuda_size_t size = pCopy->WidthInBytes * pCopy->Height * pCopy->Depth; CUdevice deviceId; CUresult res = cuCtxGetDevice(&deviceId); assert(res == CUDA_SUCCESS); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, kind); res = libcuMemcpy3DAsync_v2(pCopy, hStream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, kind); return res; } // to be implemented CUresult cuMemGetInfo_v2(size_t *free, size_t *total) { return libcuMemGetInfo_v2(free, total); } CUresult cuMemAllocHost_v2(void **pp, size_t bytesize) { return libcuMemAllocHost_v2(pp, bytesize); } CUresult cuMemFreeHost(void *p) { return libcuMemFreeHost(p); } CUresult cuMemHostAlloc(void **pp, size_t bytesize, unsigned int Flags) { return libcuMemHostAlloc(pp, bytesize, Flags); } CUresult cuMemHostRegister(void *p, size_t bytesize, unsigned int Flags) { return libcuMemHostRegister(p, bytesize, Flags); } CUresult cuMemHostUnregister(void *p) { return libcuMemHostUnregister(p); } CUresult cuMemcpyPeer(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount) { return libcuMemcpyPeer(dstDevice, dstContext, srcDevice, srcContext, ByteCount); } CUresult cuMemcpyPeerAsync(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount, CUstream hStream) { return libcuMemcpyPeerAsync(dstDevice, dstContext, srcDevice, srcContext, ByteCount, hStream); } CUresult cuMemcpy3DPeer(const CUDA_MEMCPY3D_PEER *pCopy) { return libcuMemcpy3DPeer(pCopy); } CUresult cuMemcpy3DPeerAsync(const CUDA_MEMCPY3D_PEER *pCopy, CUstream hStream) { return libcuMemcpy3DPeerAsync(pCopy, hStream); } CUresult cuMemsetD8_v2(CUdeviceptr dstDevice, unsigned char uc, size_t N) { return libcuMemsetD8_v2(dstDevice, uc, N); } CUresult cuMemsetD16_v2(CUdeviceptr dstDevice, unsigned short us, size_t N) { return libcuMemsetD16_v2(dstDevice, us, N); } CUresult cuMemsetD32_v2(CUdeviceptr dstDevice, unsigned int ui, size_t N) { return libcuMemsetD32_v2(dstDevice, ui, N); } CUresult cuMemsetD2D8_v2(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height) { return libcuMemsetD2D8_v2(dstDevice, dstPitch, uc, Width, Height); } CUresult cuMemsetD2D16_v2(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height) { return libcuMemsetD2D16_v2(dstDevice, dstPitch, us, Width, Height); } CUresult cuMemsetD2D32_v2(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height) { return libcuMemsetD2D32_v2(dstDevice, dstPitch, ui, Width, Height); } CUresult cuMemsetD8Async(CUdeviceptr dstDevice, unsigned char uc, size_t N, CUstream hStream) { return libcuMemsetD8Async(dstDevice, uc, N, hStream); } CUresult cuMemsetD16Async(CUdeviceptr dstDevice, unsigned short us, size_t N, CUstream hStream) { return libcuMemsetD16Async(dstDevice, us, N, hStream); } CUresult cuMemsetD32Async(CUdeviceptr dstDevice, unsigned int ui, size_t N, CUstream hStream) { return libcuMemsetD32Async(dstDevice, ui, N, hStream); } CUresult cuMemsetD2D8Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height, CUstream hStream) { return libcuMemsetD2D8Async(dstDevice, dstPitch, uc, Width, Height, hStream); } CUresult cuMemsetD2D16Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height, CUstream hStream) { return libcuMemsetD2D16Async(dstDevice, dstPitch, us, Width, Height, hStream); } CUresult cuMemsetD2D32Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height, CUstream hStream) { return libcuMemsetD2D32Async(dstDevice, dstPitch, ui, Width, Height, hStream); } #if 0 /* is it useful ? */ CUresult cuArrayCreate(CUarray *pHandle, const CUDA_ARRAY_DESCRIPTOR *pAllocateArray) { return libcuArrayCreate(pHandle, pAllocateArray); } CUresult cuArrayGetDescriptor(CUDA_ARRAY_DESCRIPTOR *pArrayDescriptor, CUarray hArray) { return libcuArrayGetDescriptor(pArrayDescriptor, hArray); } CUresult cuArrayDestroy(CUarray hArray) { return libcuArrayDestroy(hArray); } CUresult cuArray3DCreate(CUarray *pHandle, const CUDA_ARRAY3D_DESCRIPTOR *pAllocateArray) { return libcuArray3DCreate(pHandle, pAllocateArray); } CUresult cuArray3DGetDescriptor(CUDA_ARRAY3D_DESCRIPTOR *pArrayDescriptor, CUarray hArray) { return libcuArray3DGetDescriptor(pArrayDescriptor, hArray); } CUresult cuMipmappedArrayCreate(CUmipmappedArray *pHandle, const CUDA_ARRAY3D_DESCRIPTOR *pMipmappedArrayDesc, unsigned int numMipmapLevels) { return libcuMipmappedArrayCreate(pHandle, pMipmappedArrayDesc, numMipmapLevels); } CUresult cuMipmappedArrayGetLevel(CUarray *pLevelArray, CUmipmappedArray hMipmappedArray, unsigned int level) { return libcuMipmappedArrayGetLevel(pLevelArray, hMipmappedArray, level); } CUresult cuMipmappedArrayDestroy(CUmipmappedArray hMipmappedArray) { return libcuMipmappedArrayDestroy(hMipmappedArray); } #endif } eztrace-1.1-2/src/modules/cuda/cuda_ev_codes.h000066400000000000000000000130361265506773700213030ustar00rootroot00000000000000#ifndef __CUDA_EV_CODES_H__ #define __CUDA_EV_CODES_H__ #include #include "ev_codes.h" #define EZTRACE_CUDA_EVENTS_ID 0x07 #define EZTRACE_CUDA_PREFIX (EZTRACE_CUDA_EVENTS_ID << NB_BITS_EVENTS) #define EZTRACE_CUDA_CUMEMALLOC_START (EZTRACE_CUDA_PREFIX | 0X0110) #define EZTRACE_CUDA_CUMEMALLOC_STOP (EZTRACE_CUDA_PREFIX | 0X0111) #define EZTRACE_CUDA_CUDAFREE_START (EZTRACE_CUDA_PREFIX | 0X0112) #define EZTRACE_CUDA_CUDAFREE_STOP (EZTRACE_CUDA_PREFIX | 0X0113) #define EZTRACE_CUDA_CULAUNCHKERNEL_START (EZTRACE_CUDA_PREFIX | 0X0120) #define EZTRACE_CUDA_CULAUNCHKERNEL_STOP (EZTRACE_CUDA_PREFIX | 0X0121) #define EZTRACE_CUDA_CUDATHREADSYNCHRONIZE_START (EZTRACE_CUDA_PREFIX | 0X0130) #define EZTRACE_CUDA_CUDATHREADSYNCHRONIZE_STOP (EZTRACE_CUDA_PREFIX | 0X0131) #define EZTRACE_CUDA_CUINIT (EZTRACE_CUDA_PREFIX | 0X0140) #define EZTRACE_CUDA_SETNBDEVICES (EZTRACE_CUDA_PREFIX | 0X0141) #define EZTRACE_CUDA_CUMEMCPY_START (EZTRACE_CUDA_PREFIX | 0X0150) #define EZTRACE_CUDA_CUMEMCPY_STOP (EZTRACE_CUDA_PREFIX | 0X0151) #define EZTRACE_CUDA_CUDADEVICESYNCHRONIZE_START (EZTRACE_CUDA_PREFIX | 0X0160) #define EZTRACE_CUDA_CUDADEVICESYNCHRONIZE_STOP (EZTRACE_CUDA_PREFIX | 0X0161) #define EZTRACE_CUDA_GPU_KERNEL_TIMESTAMPS (EZTRACE_CUDA_PREFIX | 0X0210) #define EZTRACE_CUDA_GPU_MEMCPY_TIMESTAMPS (EZTRACE_CUDA_PREFIX | 0X0211) #define EZTRACE_CUDA_REGISTER_KERNEL (EZTRACE_CUDA_PREFIX | 0X1001) #define EZTRACE_CUDA_KERNEL_NAME (EZTRACE_CUDA_PREFIX | 0X1002) typedef uint32_t kernel_id_t; typedef uint64_t ezt_cuda_size_t; enum ezt_cudaMemcpyKind { CUDA_MEMCPY_KIND_HTOD = 1, CUDA_MEMCPY_KIND_DTOH = 2, CUDA_MEMCPY_KIND_HTOA = 3, CUDA_MEMCPY_KIND_ATOH = 4, CUDA_MEMCPY_KIND_ATOA = 5, CUDA_MEMCPY_KIND_ATOD = 6, CUDA_MEMCPY_KIND_DTOA = 7, CUDA_MEMCPY_KIND_DTOD = 8, CUDA_MEMCPY_KIND_HTOH = 9, CUDA_MEMCPY_KIND_UNKNOWN = -1 }; #define memoryTypesToCpyKind(srcType, destType) \ (((srcType)== CU_MEMORYTYPE_HOST && (destType)== CU_MEMORYTYPE_HOST)? CUDA_MEMCPY_KIND_HTOH : \ ((srcType)== CU_MEMORYTYPE_HOST && (destType)== CU_MEMORYTYPE_DEVICE)? CUDA_MEMCPY_KIND_HTOD : \ ((srcType)== CU_MEMORYTYPE_HOST && (destType)== CU_MEMORYTYPE_ARRAY)? CUDA_MEMCPY_KIND_HTOA : \ ((srcType)== CU_MEMORYTYPE_DEVICE && (destType)== CU_MEMORYTYPE_HOST)? CUDA_MEMCPY_KIND_DTOH : \ ((srcType)== CU_MEMORYTYPE_DEVICE && (destType)== CU_MEMORYTYPE_DEVICE)? CUDA_MEMCPY_KIND_DTOD : \ ((srcType)== CU_MEMORYTYPE_DEVICE && (destType)== CU_MEMORYTYPE_ARRAY)? CUDA_MEMCPY_KIND_DTOA : \ ((srcType)== CU_MEMORYTYPE_ARRAY && (destType)== CU_MEMORYTYPE_HOST)? CUDA_MEMCPY_KIND_ATOH : \ ((srcType)== CU_MEMORYTYPE_ARRAY && (destType)== CU_MEMORYTYPE_DEVICE)? CUDA_MEMCPY_KIND_ATOD : \ ((srcType)== CU_MEMORYTYPE_ARRAY && (destType)== CU_MEMORYTYPE_ARRAY)? CUDA_MEMCPY_KIND_ATOA : \ CUDA_MEMCPY_KIND_UNKNOWN) #define CUDA_MEMCPY_KIND_TO_EZT(kind) \ ((kind)==cudaMemcpyHostToHost?CUDA_MEMCPY_KIND_HTOH: \ ((kind)==cudaMemcpyHostToDevice?CUDA_MEMCPY_KIND_HTOD: \ ((kind)==cudaMemcpyDeviceToDevice?CUDA_MEMCPY_KIND_DTOD: \ ((kind)==cudaMemcpyDeviceToHost?CUDA_MEMCPY_KIND_DTOH: \ CUDA_MEMCPY_KIND_UNKNOWN)))) #define CUPTI_ACTIVITY_MEMCPY_KIND_TO_EZT(kind) \ ((kind) == CUPTI_ACTIVITY_MEMCPY_KIND_HTOD ? CUDA_MEMCPY_KIND_HTOD: \ ((kind) == CUPTI_ACTIVITY_MEMCPY_KIND_DTOH ? CUDA_MEMCPY_KIND_DTOH: \ ((kind) == CUPTI_ACTIVITY_MEMCPY_KIND_HTOA ? CUDA_MEMCPY_KIND_HTOA: \ ((kind) == CUPTI_ACTIVITY_MEMCPY_KIND_ATOH ? CUDA_MEMCPY_KIND_ATOH: \ ((kind) == CUPTI_ACTIVITY_MEMCPY_KIND_ATOA ? CUDA_MEMCPY_KIND_ATOA: \ ((kind) == CUPTI_ACTIVITY_MEMCPY_KIND_ATOD ? CUDA_MEMCPY_KIND_ATOD: \ ((kind) == CUPTI_ACTIVITY_MEMCPY_KIND_DTOA ? CUDA_MEMCPY_KIND_DTOA: \ ((kind) == CUPTI_ACTIVITY_MEMCPY_KIND_DTOD ? CUDA_MEMCPY_KIND_DTOD: \ ((kind) == CUPTI_ACTIVITY_MEMCPY_KIND_HTOH ? CUDA_MEMCPY_KIND_HTOH: \ CUDA_MEMCPY_KIND_UNKNOWN))))))))) /* return true if the transfer starts from the CPU */ #define IS_FROM_CPU(kind) \ (((kind) == CUDA_MEMCPY_KIND_HTOD) || \ ((kind) == CUDA_MEMCPY_KIND_HTOA) || \ ((kind) == CUDA_MEMCPY_KIND_HTOH)) /* return true if the transfer starts from the GPU */ #define IS_FROM_GPU(kind) \ (((kind) == CUDA_MEMCPY_KIND_DTOH) || \ ((kind) == CUDA_MEMCPY_KIND_ATOH) || \ ((kind) == CUDA_MEMCPY_KIND_ATOA) || \ ((kind) == CUDA_MEMCPY_KIND_ATOD) || \ ((kind) == CUDA_MEMCPY_KIND_DTOA) || \ ((kind) == CUDA_MEMCPY_KIND_DTOD)) /* return true if the transfer ends to the CPU */ #define IS_TO_CPU(kind) \ (((kind) == CUDA_MEMCPY_KIND_DTOH) || \ ((kind) == CUDA_MEMCPY_KIND_ATOH) || \ ((kind) == CUDA_MEMCPY_KIND_HTOH)) /* return true if the transfer ends to the GPU */ #define IS_TO_GPU(kind) \ (((kind) == CUDA_MEMCPY_KIND_HTOD) || \ ((kind) == CUDA_MEMCPY_KIND_HTOA) || \ ((kind) == CUDA_MEMCPY_KIND_ATOD) || \ ((kind) == CUDA_MEMCPY_KIND_ATOA) || \ ((kind) == CUDA_MEMCPY_KIND_DTOA) || \ ((kind) == CUDA_MEMCPY_KIND_DTOD)) #define MEMCPY_TYPE_STR(kind) \ ((IS_FROM_CPU(kind) && IS_TO_CPU(kind))? "HToH_memcpy": \ (IS_FROM_CPU(kind) && IS_TO_GPU(kind))? "HToD_memcpy": \ (IS_FROM_GPU(kind) && IS_TO_CPU(kind))? "DToH_memcpy": \ (IS_FROM_GPU(kind) && IS_TO_GPU(kind))? "DToD_memcpy": "Unknown") extern int __ezt_cuda_initialized; void __ezt_cuda_initialize(); #define EZT_CUDA_INITIALIZE do { if(!__ezt_cuda_initialized) { __ezt_cuda_initialize(); } } while(0) #endif eztrace-1.1-2/src/modules/cuda/cuda_runtime.cu000066400000000000000000000562201265506773700213610ustar00rootroot00000000000000#define _GNU_SOURCE 1 /* or _BSD_SOURCE or _SVID_SOURCE */ #define _REENTRANT #include #include #include #include #include "ezt_cuda.h" #include "cuda_ev_codes.h" #include "eztrace.h" extern "C" { /**** CUDA runtime interface ****/ cudaError_t cudaThreadSynchronize(){ // note: deprecated FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_1(EZTRACE_CUDA_CUDATHREADSYNCHRONIZE_START, deviceId); ret = libcudaThreadSynchronize(); EZTRACE_EVENT_PACKED_1(EZTRACE_CUDA_CUDATHREADSYNCHRONIZE_STOP, deviceId); return ret; } cudaError_t cudaDeviceSynchronize(){ FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_1(EZTRACE_CUDA_CUDADEVICESYNCHRONIZE_START, deviceId); ret = libcudaDeviceSynchronize(); EZTRACE_EVENT_PACKED_1(EZTRACE_CUDA_CUDADEVICESYNCHRONIZE_STOP, deviceId); return ret; } /* Kernel management */ #if 0 // todo: just before cudaLaunch, nvcc puts a call to cudaConfigureCall . We could intercept this function and // record the gridDim, blockDim, etc. cudaError_t cudaConfigureCall ( dim3 gridDim, dim3 blockDim, size_t sharedMem, cudaStream_t stream) { fprintf(stderr, "cudaConfigureCall(gridDim(%d, %d, %d), blockDim(%d, %d, %d), sharedMem=%d, stream=%p)\n", gridDim.x, gridDim.y, gridDim.z, blockDim.x, blockDim.y, blockDim.z, sharedMem, stream); cudaError_t ret; ret = libcudaConfigureCall(gridDim, blockDim, sharedMem, stream); return ret; } #else cudaError_t cudaConfigureCall ( dim3 gridDim, dim3 blockDim, size_t sharedMem, cudaStream_t stream) { return libcudaConfigureCall(gridDim, blockDim, sharedMem, stream); } #endif cudaError_t cudaLaunch(const void *entry) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; static unsigned kernel_id = 0; unsigned current_id = kernel_id++; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CULAUNCHKERNEL_START, deviceId, current_id); ret = libcudaLaunch(entry); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CULAUNCHKERNEL_STOP, deviceId, current_id); return ret; } /* Memory management */ cudaError_t cudaMalloc(void ** devPtr, size_t size) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); ezt_cuda_size_t ezt_size = size; // todo: use devptr ? EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUMEMALLOC_START, deviceId, ezt_size); ret = libcudaMalloc(devPtr, size); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMALLOC_STOP, deviceId, ezt_size, *devPtr); return ret; } cudaError_t cudaMallocPitch(void **devPtr, size_t *pitch, size_t width, size_t height) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); ezt_cuda_size_t ezt_size = width*height; EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUMEMALLOC_START, deviceId, ezt_size); ret = libcudaMallocPitch(devPtr, pitch, width, height); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMALLOC_STOP, deviceId, ezt_size, *devPtr); return ret; } cudaError_t cudaMallocArray(struct cudaArray **array, const struct cudaChannelFormatDesc *desc, size_t width, size_t height, unsigned int flags) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; ezt_cuda_size_t size = width*height; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUMEMALLOC_START, deviceId, size); ret = libcudaMallocArray(array, desc, width, height, flags); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMALLOC_STOP, deviceId, size, *array); return ret; } cudaError_t cudaMalloc3D(struct cudaPitchedPtr* pitchedDevPtr, struct cudaExtent extent) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); ezt_cuda_size_t size = extent.width * extent.height * extent.depth; EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUMEMALLOC_START, deviceId, size); ret = libcudaMalloc3D(pitchedDevPtr, extent); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMALLOC_STOP, deviceId, size, pitchedDevPtr); return ret; } cudaError_t cudaMalloc3DArray(cudaArray_t *array, const struct cudaChannelFormatDesc* desc, struct cudaExtent extent, unsigned int flags) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); ezt_cuda_size_t size = extent.width * extent.height * extent.depth; EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUMEMALLOC_START, deviceId, size); ret = libcudaMalloc3DArray(array, desc, extent, flags); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMALLOC_STOP, deviceId, size, *array); return ret; } cudaError_t cudaMallocMipmappedArray(cudaMipmappedArray_t *mipmappedArray, const struct cudaChannelFormatDesc* desc, struct cudaExtent extent, unsigned int numLevels, unsigned int flags) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); ezt_cuda_size_t size = extent.width * extent.height * extent.depth; EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUMEMALLOC_START, deviceId, size); ret = libcudaMallocMipmappedArray(mipmappedArray, desc, extent, numLevels, flags); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMALLOC_STOP, deviceId, size, mipmappedArray); return ret; } cudaError_t cudaFree(void *devPtr) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); if(devPtr) EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUDAFREE_START, deviceId, devPtr); ret = libcudaFree(devPtr); if(devPtr) EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUDAFREE_STOP, deviceId, devPtr); return ret; } cudaError_t cudaFreeArray(cudaArray_t array) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); if(array) EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUDAFREE_START, deviceId, array); ret = libcudaFreeArray(array); if(array) EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUDAFREE_STOP, deviceId, array); return ret; } cudaError_t cudaFreeMipmappedArray(cudaMipmappedArray_t mipmappedArray) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); if(mipmappedArray) EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUDAFREE_START, deviceId, mipmappedArray); ret = libcudaFreeMipmappedArray(mipmappedArray); if(mipmappedArray) EZTRACE_EVENT_PACKED_2(EZTRACE_CUDA_CUDAFREE_STOP, deviceId, mipmappedArray); return ret; } /* Memory Transfers */ cudaError_t cudaMemcpy(void *dst, const void *src, size_t count, enum cudaMemcpyKind kind) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; // todo: use devptr ? enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); ezt_cuda_size_t ezt_size = count; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, ezt_size, ezt_kind); ret = libcudaMemcpy(dst, src, count, kind); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, ezt_size, ezt_kind); return ret; } cudaError_t cudaMemcpy3D(const struct cudaMemcpy3DParms *p) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(p->kind); ezt_cuda_size_t size = p->extent.width * p->extent.height *p->extent.depth; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpy3D(p); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpy3DAsync(const struct cudaMemcpy3DParms *p, cudaStream_t stream ) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(p->kind); ezt_cuda_size_t size = p->extent.width * p->extent.height *p->extent.depth; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpy3DAsync(p, stream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpyToArray(cudaArray_t dst, size_t wOffset, size_t hOffset, const void *src, size_t count, enum cudaMemcpyKind kind) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = count; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpyToArray(dst, wOffset, hOffset, src, count, kind); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpyFromArray(void *dst, cudaArray_const_t src, size_t wOffset, size_t hOffset, size_t count, enum cudaMemcpyKind kind) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = count; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpyFromArray(dst, src, wOffset, hOffset, count, kind); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpyArrayToArray(cudaArray_t dst, size_t wOffsetDst, size_t hOffsetDst, cudaArray_const_t src, size_t wOffsetSrc, size_t hOffsetSrc, size_t count, enum cudaMemcpyKind kind) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = count; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpyArrayToArray(dst, wOffsetDst, hOffsetDst, src, wOffsetSrc, hOffsetSrc, count, kind); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpy2D(void *dst, size_t dpitch, const void *src, size_t spitch, size_t width, size_t height, enum cudaMemcpyKind kind) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = width*height; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpy2D(dst, dpitch, src, spitch, width, height, kind); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpy2DToArray(cudaArray_t dst, size_t wOffset, size_t hOffset, const void *src, size_t spitch, size_t width, size_t height, enum cudaMemcpyKind kind) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = width*height; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpy2DToArray(dst, wOffset, hOffset, src, spitch, width, height, kind); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpy2DFromArray(void *dst, size_t dpitch, cudaArray_const_t src, size_t wOffset, size_t hOffset, size_t width, size_t height, enum cudaMemcpyKind kind) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = width*height; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpy2DFromArray(dst, dpitch, src, wOffset, hOffset, width, height, kind) ; EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpy2DArrayToArray(cudaArray_t dst, size_t wOffsetDst, size_t hOffsetDst, cudaArray_const_t src, size_t wOffsetSrc, size_t hOffsetSrc, size_t width, size_t height, enum cudaMemcpyKind kind) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = width*height; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpy2DArrayToArray(dst, wOffsetDst, hOffsetDst, src, wOffsetSrc, hOffsetSrc, width, height, kind); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpyToSymbol(const void *symbol, const void *src, size_t count, size_t offset , enum cudaMemcpyKind kind) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = count; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpyToSymbol(symbol, src, count, offset , kind); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpyFromSymbol(void *dst, const void *symbol, size_t count, size_t offset , enum cudaMemcpyKind kind) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = count; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpyFromSymbol(dst, symbol, count, offset , kind); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpyAsync(void *dst, const void *src, size_t count, enum cudaMemcpyKind kind, cudaStream_t stream ) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = count; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpyAsync(dst, src, count, kind, stream ); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpyToArrayAsync(cudaArray_t dst, size_t wOffset, size_t hOffset, const void *src, size_t count, enum cudaMemcpyKind kind, cudaStream_t stream ) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = count; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpyToArrayAsync(dst, wOffset, hOffset, src, count, kind, stream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpyFromArrayAsync(void *dst, cudaArray_const_t src, size_t wOffset, size_t hOffset, size_t count, enum cudaMemcpyKind kind, cudaStream_t stream ) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = count; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpyFromArrayAsync(dst, src, wOffset, hOffset, count, kind, stream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpy2DAsync(void *dst, size_t dpitch, const void *src, size_t spitch, size_t width, size_t height, enum cudaMemcpyKind kind, cudaStream_t stream ) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = width * height; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpy2DAsync(dst, dpitch, src, spitch, width, height, kind, stream ); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpy2DToArrayAsync(cudaArray_t dst, size_t wOffset, size_t hOffset, const void *src, size_t spitch, size_t width, size_t height, enum cudaMemcpyKind kind, cudaStream_t stream) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = width * height; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpy2DToArrayAsync(dst, wOffset, hOffset, src, spitch, width, height, kind, stream ); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpy2DFromArrayAsync(void *dst, size_t dpitch, cudaArray_const_t src, size_t wOffset, size_t hOffset, size_t width, size_t height, enum cudaMemcpyKind kind, cudaStream_t stream ) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = width * height; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpy2DFromArrayAsync(dst, dpitch, src, wOffset, hOffset, width, height, kind, stream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpyToSymbolAsync(const void *symbol, const void *src, size_t count, size_t offset, enum cudaMemcpyKind kind, cudaStream_t stream ) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = count; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpyToSymbolAsync(symbol, src, count, offset, kind, stream ); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } cudaError_t cudaMemcpyFromSymbolAsync(void *dst, const void *symbol, size_t count, size_t offset, enum cudaMemcpyKind kind, cudaStream_t stream ) { FUNCTION_ENTRY; EZT_CUDA_INITIALIZE; cudaError_t ret; enum ezt_cudaMemcpyKind ezt_kind = CUDA_MEMCPY_KIND_TO_EZT(kind); ezt_cuda_size_t size = count; int deviceId; ret = cudaGetDevice(&deviceId); assert(ret == cudaSuccess); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_START, deviceId, size, ezt_kind); ret = libcudaMemcpyFromSymbolAsync(dst, symbol, count, offset, kind, stream); EZTRACE_EVENT_PACKED_3(EZTRACE_CUDA_CUMEMCPY_STOP, deviceId, size, ezt_kind); return ret; } /**** functions to implement ****/ cudaError_t cudaMemset(void *devPtr, int value, size_t count) { return libcudaMemset(devPtr, value, count); } cudaError_t cudaMemset2D(void *devPtr, size_t pitch, int value, size_t width, size_t height) { return libcudaMemset2D(devPtr, pitch, value, width, height); } cudaError_t cudaMemset3D(struct cudaPitchedPtr pitchedDevPtr, int value, struct cudaExtent extent) { return libcudaMemset3D(pitchedDevPtr, value, extent); } cudaError_t cudaMemsetAsync(void *devPtr, int value, size_t count, cudaStream_t stream ) { return libcudaMemsetAsync(devPtr, value, count, stream ); } cudaError_t cudaMemset2DAsync(void *devPtr, size_t pitch, int value, size_t width, size_t height, cudaStream_t stream ) { return libcudaMemset2DAsync(devPtr, pitch, value, width, height, stream ); } cudaError_t cudaMemset3DAsync(struct cudaPitchedPtr pitchedDevPtr, int value, struct cudaExtent extent, cudaStream_t stream ) { return libcudaMemset3DAsync(pitchedDevPtr, value, extent, stream ); } cudaError_t cudaMemcpy3DPeer(const struct cudaMemcpy3DPeerParms *p) { fprintf(stderr, "[EZTRACE] Warning: the instrumentation of function %s is not implemented!\n", __FUNCTION__); return libcudaMemcpy3DPeer(p); } cudaError_t cudaMemcpy3DPeerAsync(const struct cudaMemcpy3DPeerParms *p, cudaStream_t stream ) { fprintf(stderr, "[EZTRACE] Warning: the instrumentation of function %s is not implemented!\n", __FUNCTION__); return libcudaMemcpy3DPeerAsync(p, stream); } cudaError_t cudaMemcpyPeer(void *dst, int dstDevice, const void *src, int srcDevice, size_t count) { fprintf(stderr, "[EZTRACE] Warning: the instrumentation of function %s is not implemented!\n", __FUNCTION__); return libcudaMemcpyPeer(dst, dstDevice, src, srcDevice, count); } cudaError_t cudaMemcpyPeerAsync(void *dst, int dstDevice, const void *src, int srcDevice, size_t count, cudaStream_t stream ) { fprintf(stderr, "[EZTRACE] Warning: the instrumentation of function %s is not implemented!\n", __FUNCTION__); return libcudaMemcpyPeerAsync(dst, dstDevice, src, srcDevice, count, stream ); } } cudaError_t cudaMallocHost(void **ptr, size_t size) { // todo: record something or remove this function return libcudaMallocHost(ptr, size); } cudaError_t cudaFreeHost(void *ptr) { return libcudaFreeHost(ptr); } #if 0 cudaError_t cudaHostAlloc(void **pHost, size_t size, unsigned int flags); cudaError_t cudaHostRegister(void *ptr, size_t size, unsigned int flags); cudaError_t cudaHostUnregister(void *ptr); #endif eztrace-1.1-2/src/modules/cuda/cudalt.py000077500000000000000000000036401265506773700202000ustar00rootroot00000000000000#!/usr/bin/python # libtoolish hack: compile a .cu file like libtool does import sys import os lo_filepath = sys.argv[1] o_filepath = lo_filepath.replace(".lo", ".o") try: i = o_filepath.rindex("/") lo_dir = o_filepath[0:i+1] o_filename = o_filepath[i+1:] except ValueError: lo_dir = "" o_filename = o_filepath local_pic_dir = ".libs/" local_npic_dir = "" pic_dir = lo_dir + local_pic_dir npic_dir = lo_dir + local_npic_dir pic_filepath = pic_dir + o_filename npic_filepath = npic_dir + o_filename local_pic_filepath = local_pic_dir + o_filename local_npic_filepath = local_npic_dir + o_filename # Make lib dir try: os.mkdir(pic_dir) except OSError: pass # generate the command to compile the .cu for shared library args = sys.argv[2:] args.extend(["-Xcompiler","-fPIC"]) # position indep code args.append("-o") args.append(pic_filepath) command = " ".join(args) print command # compile the .cu rv = os.system(command) if rv != 0: sys.exit(1) # generate the command to compile the .cu for static library args = sys.argv[2:] args.append("-o") args.append(npic_filepath) command = " ".join(args) print command # compile the .cu rv = os.system(command) if rv != 0: sys.exit(1) # get libtool version fd = os.popen("../../../libtool --version") libtool_version = fd.readline() # this loop supresses the broken pipe errors # you get by not reading all the data for dog in fd.readlines(): noop = 1; fd.close() # generate the .lo file f = open(lo_filepath, "w") f.write("# " + lo_filepath + " - a libtool object file\n") f.write("# Generated by " + libtool_version + "\n") f.write("#\n") f.write("# Please DO NOT delete this file!\n") f.write("# It is necessary for linking the library.\n\n") f.write("# Name of the PIC object.\n") f.write("pic_object='" + local_pic_filepath + "'\n\n") f.write("# Name of the non-PIC object.\n") f.write("non_pic_object='" + local_npic_filepath + "'\n") f.close() sys.exit(0) eztrace-1.1-2/src/modules/cuda/ezt_cuda.h000066400000000000000000000345061265506773700203230ustar00rootroot00000000000000#ifndef EZT_CUDA_H #define EZT_CUDA_H extern "C" { #include #include "cuda_ev_codes.h" #include "eztrace.h" /**** CUDA runtime interface ****/ extern cudaError_t (*libcudaDeviceSynchronize)(); extern cudaError_t (*libcudaThreadSynchronize)(); // note: deprecated /* Kernel management */ extern cudaError_t (*libcudaLaunch)(const void *func); extern cudaError_t (*libcudaConfigureCall) ( dim3 gridDim, dim3 blockDim, size_t sharedMem, cudaStream_t stream ); /* Memory management */ extern cudaError_t (*libcudaMalloc)(void **devPtr, size_t size); extern cudaError_t (*libcudaMallocHost)(void **ptr, size_t size); extern cudaError_t (*libcudaMallocPitch)(void **devPtr, size_t *pitch, size_t width, size_t height); extern cudaError_t (*libcudaMallocArray)(struct cudaArray **array, const struct cudaChannelFormatDesc *desc, size_t width, size_t height, unsigned int flags); extern cudaError_t (*libcudaMalloc3D)(struct cudaPitchedPtr* pitchedDevPtr, struct cudaExtent extent); extern cudaError_t (*libcudaMalloc3DArray)(cudaArray_t *array, const struct cudaChannelFormatDesc* desc, struct cudaExtent extent, unsigned int flags); extern cudaError_t (*libcudaMallocMipmappedArray)(cudaMipmappedArray_t *mipmappedArray, const struct cudaChannelFormatDesc* desc, struct cudaExtent extent, unsigned int numLevels, unsigned int flags); extern cudaError_t (*libcudaFree)(void *devPtr); extern cudaError_t (*libcudaFreeHost)(void *ptr); extern cudaError_t (*libcudaFreeArray)(cudaArray_t array); extern cudaError_t (*libcudaFreeMipmappedArray)(cudaMipmappedArray_t mipmappedArray); extern cudaError_t (*libcudaHostAlloc)(void **pHost, size_t size, unsigned int flags); extern cudaError_t (*libcudaHostRegister)(void *ptr, size_t size, unsigned int flags); extern cudaError_t (*libcudaHostUnregister)(void *ptr); /* Memory Transfers */ extern cudaError_t (*libcudaMemcpy3D)(const struct cudaMemcpy3DParms *p); extern cudaError_t (*libcudaMemcpy3DPeer)(const struct cudaMemcpy3DPeerParms *p); extern cudaError_t (*libcudaMemcpy3DAsync)(const struct cudaMemcpy3DParms *p, cudaStream_t stream ); extern cudaError_t (*libcudaMemcpy3DPeerAsync)(const struct cudaMemcpy3DPeerParms *p, cudaStream_t stream ); extern cudaError_t (*libcudaMemcpy)(void *dst, const void *src, size_t count, enum cudaMemcpyKind kind); extern cudaError_t (*libcudaMemcpyPeer)(void *dst, int dstDevice, const void *src, int srcDevice, size_t count); extern cudaError_t (*libcudaMemcpyToArray)(cudaArray_t dst, size_t wOffset, size_t hOffset, const void *src, size_t count, enum cudaMemcpyKind kind); extern cudaError_t (*libcudaMemcpyFromArray)(void *dst, cudaArray_const_t src, size_t wOffset, size_t hOffset, size_t count, enum cudaMemcpyKind kind); extern cudaError_t (*libcudaMemcpyArrayToArray)(cudaArray_t dst, size_t wOffsetDst, size_t hOffsetDst, cudaArray_const_t src, size_t wOffsetSrc, size_t hOffsetSrc, size_t count, enum cudaMemcpyKind kind); extern cudaError_t (*libcudaMemcpy2D)(void *dst, size_t dpitch, const void *src, size_t spitch, size_t width, size_t height, enum cudaMemcpyKind kind); extern cudaError_t (*libcudaMemcpy2DToArray)(cudaArray_t dst, size_t wOffset, size_t hOffset, const void *src, size_t spitch, size_t width, size_t height, enum cudaMemcpyKind kind); extern cudaError_t (*libcudaMemcpy2DFromArray)(void *dst, size_t dpitch, cudaArray_const_t src, size_t wOffset, size_t hOffset, size_t width, size_t height, enum cudaMemcpyKind kind); extern cudaError_t (*libcudaMemcpy2DArrayToArray)(cudaArray_t dst, size_t wOffsetDst, size_t hOffsetDst, cudaArray_const_t src, size_t wOffsetSrc, size_t hOffsetSrc, size_t width, size_t height, enum cudaMemcpyKind kind); extern cudaError_t (*libcudaMemcpyToSymbol)(const void *symbol, const void *src, size_t count, size_t offset , enum cudaMemcpyKind kind); extern cudaError_t (*libcudaMemcpyFromSymbol)(void *dst, const void *symbol, size_t count, size_t offset , enum cudaMemcpyKind kind); extern cudaError_t (*libcudaMemcpyAsync)(void *dst, const void *src, size_t count, enum cudaMemcpyKind kind, cudaStream_t stream ); extern cudaError_t (*libcudaMemcpyPeerAsync)(void *dst, int dstDevice, const void *src, int srcDevice, size_t count, cudaStream_t stream ); extern cudaError_t (*libcudaMemcpyToArrayAsync)(cudaArray_t dst, size_t wOffset, size_t hOffset, const void *src, size_t count, enum cudaMemcpyKind kind, cudaStream_t stream ); extern cudaError_t (*libcudaMemcpyFromArrayAsync)(void *dst, cudaArray_const_t src, size_t wOffset, size_t hOffset, size_t count, enum cudaMemcpyKind kind, cudaStream_t stream ); extern cudaError_t (*libcudaMemcpy2DAsync)(void *dst, size_t dpitch, const void *src, size_t spitch, size_t width, size_t height, enum cudaMemcpyKind kind, cudaStream_t stream ); extern cudaError_t (*libcudaMemcpy2DToArrayAsync)(cudaArray_t dst, size_t wOffset, size_t hOffset, const void *src, size_t spitch, size_t width, size_t height, enum cudaMemcpyKind kind, cudaStream_t stream ); extern cudaError_t (*libcudaMemcpy2DFromArrayAsync)(void *dst, size_t dpitch, cudaArray_const_t src, size_t wOffset, size_t hOffset, size_t width, size_t height, enum cudaMemcpyKind kind, cudaStream_t stream ); extern cudaError_t (*libcudaMemcpyToSymbolAsync)(const void *symbol, const void *src, size_t count, size_t offset, enum cudaMemcpyKind kind, cudaStream_t stream ); extern cudaError_t (*libcudaMemcpyFromSymbolAsync)(void *dst, const void *symbol, size_t count, size_t offset, enum cudaMemcpyKind kind, cudaStream_t stream ); extern cudaError_t (*libcudaMemset)(void *devPtr, int value, size_t count); extern cudaError_t (*libcudaMemset2D)(void *devPtr, size_t pitch, int value, size_t width, size_t height); extern cudaError_t (*libcudaMemset3D)(struct cudaPitchedPtr pitchedDevPtr, int value, struct cudaExtent extent); extern cudaError_t (*libcudaMemsetAsync)(void *devPtr, int value, size_t count, cudaStream_t stream ); extern cudaError_t (*libcudaMemset2DAsync)(void *devPtr, size_t pitch, int value, size_t width, size_t height, cudaStream_t stream ); extern cudaError_t (*libcudaMemset3DAsync)(struct cudaPitchedPtr pitchedDevPtr, int value, struct cudaExtent extent, cudaStream_t stream ); /**** CUDA driver interface ****/ #if 0 extern CUresult (*libcuMemcpyAtoA_v2)(CUarray dstArray, size_t dstOffset, CUarray srcArray, size_t srcOffset, size_t ByteCount); extern CUresult (*libcuMemcpyAtoD_v2)(CUdeviceptr dstDevice, CUarray srcArray, size_t srcOffset, size_t ByteCount); extern CUresult (*libcuMemcpyAtoH_v2)(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount); extern CUresult (*libcuMemcpyDtoA_v2)(CUarray dstArray, size_t dstOffset, CUdeviceptr srcDevice, size_t ByteCount); extern CUresult (*libcuMemcpyDtoD_v2)(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount); extern CUresult (*libcuMemcpyDtoH_v2)(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount); extern CUresult (*libcuMemcpyHtoA_v2)(CUarray dstArray, size_t dstOffset, const void* srcHost, size_t ByteCount); extern CUresult (*libcuMemcpyHtoD_v2)(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount); extern CUresult (*libcuMemFree_v2)(CUdeviceptr dptr); extern CUresult (*libcuMemAlloc_v2)(CUdeviceptr *dptr, size_t bytesize); extern CUresult (*libcuMemcpy) (CUdeviceptr dst, CUdeviceptr src, size_t ByteCount); extern CUresult (*libcuLaunchKernel)(CUfunction f, unsigned int gridDimX, unsigned int gridDimY, unsigned int gridDimZ, unsigned int blockDimX, unsigned int blockDimY, unsigned int blockDimZ, unsigned int sharedMemBytes, CUstream hStream, void ** kernelParams, void ** extra); #endif /* Kernel management */ extern CUresult (*libcuLaunchKernel)(CUfunction f, unsigned int gridDimX, unsigned int gridDimY, unsigned int gridDimZ, unsigned int blockDimX, unsigned int blockDimY, unsigned int blockDimZ, unsigned int sharedMemBytes, CUstream hStream, void **kernelParams, void **extra); extern CUresult (*libcuLaunch)(CUfunction f); extern CUresult (*libcuLaunchGrid)(CUfunction f, int grid_width, int grid_height); extern CUresult (*libcuLaunchGridAsync)(CUfunction f, int grid_width, int grid_height, CUstream hStream); /* Memory Management */ extern CUresult (*libcuMemGetInfo_v2)(size_t *free, size_t *total); extern CUresult (*libcuMemAlloc_v2)(CUdeviceptr *dptr, size_t bytesize); extern CUresult (*libcuMemAllocPitch_v2)(CUdeviceptr *dptr, size_t *pPitch, size_t WidthInBytes, size_t Height, unsigned int ElementSizeBytes); extern CUresult (*libcuMemFree_v2)(CUdeviceptr dptr); extern CUresult (*libcuMemAllocHost_v2)(void **pp, size_t bytesize); extern CUresult (*libcuMemFreeHost)(void *p); extern CUresult (*libcuMemHostAlloc)(void **pp, size_t bytesize, unsigned int Flags); extern CUresult (*libcuMemHostRegister)(void *p, size_t bytesize, unsigned int Flags); extern CUresult (*libcuMemHostUnregister)(void *p); /* Memory Transfers */ extern CUresult (*libcuMemcpy)(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount); extern CUresult (*libcuMemcpyPeer)(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount); extern CUresult (*libcuMemcpyHtoD_v2)(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount); extern CUresult (*libcuMemcpyDtoH_v2)(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount); extern CUresult (*libcuMemcpyDtoD_v2)(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount); extern CUresult (*libcuMemcpyDtoA_v2)(CUarray dstArray, size_t dstOffset, CUdeviceptr srcDevice, size_t ByteCount); extern CUresult (*libcuMemcpyAtoD_v2)(CUdeviceptr dstDevice, CUarray srcArray, size_t srcOffset, size_t ByteCount); extern CUresult (*libcuMemcpyHtoA_v2)(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount); extern CUresult (*libcuMemcpyAtoH_v2)(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount); extern CUresult (*libcuMemcpyAtoA_v2)(CUarray dstArray, size_t dstOffset, CUarray srcArray, size_t srcOffset, size_t ByteCount); extern CUresult (*libcuMemcpy2D_v2)(const CUDA_MEMCPY2D *pCopy); extern CUresult (*libcuMemcpy2DUnaligned_v2)(const CUDA_MEMCPY2D *pCopy); extern CUresult (*libcuMemcpy3D_v2)(const CUDA_MEMCPY3D *pCopy); extern CUresult (*libcuMemcpy3DPeer)(const CUDA_MEMCPY3D_PEER *pCopy); extern CUresult (*libcuMemcpyAsync)(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount, CUstream hStream); extern CUresult (*libcuMemcpyPeerAsync)(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount, CUstream hStream); extern CUresult (*libcuMemcpyHtoDAsync_v2)(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount, CUstream hStream); extern CUresult (*libcuMemcpyDtoHAsync_v2)(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream); extern CUresult (*libcuMemcpyDtoDAsync_v2)(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream); extern CUresult (*libcuMemcpyHtoAAsync_v2)(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount, CUstream hStream); extern CUresult (*libcuMemcpyAtoHAsync_v2)(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount, CUstream hStream); extern CUresult (*libcuMemcpy2DAsync_v2)(const CUDA_MEMCPY2D *pCopy, CUstream hStream); extern CUresult (*libcuMemcpy3DAsync_v2)(const CUDA_MEMCPY3D *pCopy, CUstream hStream); extern CUresult (*libcuMemcpy3DPeerAsync)(const CUDA_MEMCPY3D_PEER *pCopy, CUstream hStream); extern CUresult (*libcuMemsetD8_v2)(CUdeviceptr dstDevice, unsigned char uc, size_t N); extern CUresult (*libcuMemsetD16_v2)(CUdeviceptr dstDevice, unsigned short us, size_t N); extern CUresult (*libcuMemsetD32_v2)(CUdeviceptr dstDevice, unsigned int ui, size_t N); extern CUresult (*libcuMemsetD2D8_v2)(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height); extern CUresult (*libcuMemsetD2D16_v2)(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height); extern CUresult (*libcuMemsetD2D32_v2)(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height); extern CUresult (*libcuMemsetD8Async)(CUdeviceptr dstDevice, unsigned char uc, size_t N, CUstream hStream); extern CUresult (*libcuMemsetD16Async)(CUdeviceptr dstDevice, unsigned short us, size_t N, CUstream hStream); extern CUresult (*libcuMemsetD32Async)(CUdeviceptr dstDevice, unsigned int ui, size_t N, CUstream hStream); extern CUresult (*libcuMemsetD2D8Async)(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height, CUstream hStream); extern CUresult (*libcuMemsetD2D16Async)(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height, CUstream hStream); extern CUresult (*libcuMemsetD2D32Async)(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height, CUstream hStream); #if 0 /* is it useful ? */ extern CUresult (*libcuArrayCreate)(CUarray *pHandle, const CUDA_ARRAY_DESCRIPTOR *pAllocateArray); extern CUresult (*libcuArrayGetDescriptor)(CUDA_ARRAY_DESCRIPTOR *pArrayDescriptor, CUarray hArray); extern CUresult (*libcuArrayDestroy)(CUarray hArray); extern CUresult (*libcuArray3DCreate)(CUarray *pHandle, const CUDA_ARRAY3D_DESCRIPTOR *pAllocateArray); extern CUresult (*libcuArray3DGetDescriptor)(CUDA_ARRAY3D_DESCRIPTOR *pArrayDescriptor, CUarray hArray); extern CUresult (*libcuMipmappedArrayCreate)(CUmipmappedArray *pHandle, const CUDA_ARRAY3D_DESCRIPTOR *pMipmappedArrayDesc, unsigned int numMipmapLevels); extern CUresult (*libcuMipmappedArrayGetLevel)(CUarray *pLevelArray, CUmipmappedArray hMipmappedArray, unsigned int level); extern CUresult (*libcuMipmappedArrayDestroy)(CUmipmappedArray hMipmappedArray); #endif //extern CUresult (*libcuCtxSynchronize)(void); //extern CUresult (*libcuDeviceTotalMem)(unsigned int *bytes, CUdevice dev); } #endif /* EZT_CUDA_H */ eztrace-1.1-2/src/modules/cuda/eztrace_convert_cuda.c000066400000000000000000000717151265506773700227140ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include #include #include "ezt_demangle.h" #include "eztrace_convert.h" #include "cuda_ev_codes.h" #include "eztrace_list.h" static int recording_stats = 0; struct cuda_memcpy_stat_t { unsigned nb_memcpy; ezt_cuda_size_t total_size; /* total size memcpied */ ezt_cuda_size_t min_size; /* minimum size of memcpy */ ezt_cuda_size_t max_size; /* maximum size of memcpy */ }; struct cuda_malloc_stat_t { unsigned nb_malloc; ezt_cuda_size_t total_size; /* total size allocated */ ezt_cuda_size_t peak_mem; /* peak memory consumption */ ezt_cuda_size_t cur_mem; /* current memory consumption */ }; struct cuda_device_info_t { struct ezt_list_token_t token; struct cuda_process_info_t *p_process; uint32_t device_id; char* gpu_id; char* gpu_name; int link_start, link_end; float start_time; int added; /* set to 1 once the container is created in GTG */ struct ezt_list_t pending_kernels; struct ezt_list_t finished_kernels; struct ezt_list_t pending_memcpy; struct ezt_list_t finished_memcpy; struct ezt_list_t pending_malloc; /* buffers that are currently in use (ie. not freed) */ struct ezt_list_t finished_malloc; /* buffers that have been freed */ struct ezt_list_t kernel_stats; struct cuda_memcpy_stat_t memcpy_stats; struct cuda_malloc_stat_t malloc_stats; }; struct cuda_process_info_t { struct process_info_t *p_process; float start_time; struct ezt_list_t kernel_names; struct ezt_list_t device_list; }; struct cuda_kernel_name_t { kernel_id_t id; struct ezt_list_token_t token; char state_id[80]; char state_desc[80]; char name[80]; }; struct cuda_kernel_stat_t { struct cuda_kernel_name_t *p_kernel; struct cuda_device_info_t *p_device; unsigned nb_calls; double min_duration; double max_duration; double kernel_duration; /* total duration of the kernel */ struct ezt_list_token_t token; }; struct cuda_kernel_info_t { /* time in seconds */ float gpu_start_time; float gpu_stop_time; float cpu_start_time; float cpu_stop_time; unsigned kernel_id; struct cuda_kernel_name_t *name; char link_str[80]; /* todo: store the parameters, etc. */ struct ezt_list_token_t token; }; struct cuda_memcpy_info_t { /* time in seconds */ float gpu_start_time; float gpu_stop_time; float cpu_start_time; float cpu_stop_time; unsigned id; char link_str[80]; char* src; char* dest; ezt_cuda_size_t size; enum ezt_cudaMemcpyKind kind; struct ezt_list_token_t token; }; struct cuda_malloc_info_t { float cpu_start_time; /* timestamp when cudaMalloc started */ float cpu_stop_time; /* timestamp when cudaMalloc stoped */ ezt_cuda_size_t size; /* size of the allocated buffer */ app_ptr devPtr; /* address of the buffer */ struct ezt_list_token_t token; }; static struct cuda_process_info_t *__register_process_hook(struct process_info_t *p_process) { struct cuda_process_info_t *p_cuda = (struct cuda_process_info_t*) malloc(sizeof(struct cuda_process_info_t)); p_cuda->p_process = p_process; ezt_hook_list_add(&p_cuda->p_process->hooks, p_cuda, (uint8_t)EZTRACE_CUDA_EVENTS_ID); p_cuda->start_time = 0; ezt_list_new(&p_cuda->kernel_names); ezt_list_new(&p_cuda->device_list); return p_cuda; } #define INIT_CUDA_PROCESS_INFO(p_process, var) \ struct cuda_process_info_t *var = (struct cuda_process_info_t*) \ ezt_hook_list_retrieve_data(&p_process->hooks, (uint8_t)EZTRACE_CUDA_EVENTS_ID); \ if(!(var)) { \ var = __register_process_hook(p_process); \ } #define CUDA_CHANGE() if(!recording_stats) CHANGE() #define TOSTRING(x) #x #define GENERATE_HANDLER(fname) \ void handle_cuda_##fname (int start) \ { \ FUNC_NAME; \ DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); \ if(start) { \ CUDA_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, TOSTRING(cuda_##fname)); \ }else{ \ CUDA_CHANGE() popState(CURRENT, "ST_Thread", thread_id); \ } \ } /* creates the GPU in the output GTG trace */ static void __create_device_container(struct cuda_device_info_t* p_cuda); GENERATE_HANDLER(cudaThreadSynchronize) /* a GPU timestamp is expressed in nanoseconds */ #define GPU_TIMESTAMP_TO_CPU(timestamp) ((timestamp)/1e6) /* find the cuda_kernel_info_t that matches kernel_id * return NULL if not found */ struct cuda_kernel_stat_t* __cuda_find_kernel_stats(struct cuda_device_info_t *p_device, struct cuda_kernel_name_t *p_kernel) { struct ezt_list_token_t *t = NULL; struct cuda_kernel_stat_t *p_stat; ezt_list_foreach(&p_device->kernel_stats, t){ p_stat = (struct cuda_kernel_stat_t *) t->data; if(p_stat->p_kernel == p_kernel) return p_stat; } /* stat not found. Probably because it's the first time this kernel is called */ p_stat = malloc(sizeof(struct cuda_kernel_stat_t)); p_stat->p_kernel = p_kernel; p_stat->p_device = p_device; p_stat->nb_calls = 0; p_stat->min_duration = DBL_MAX; p_stat->max_duration = 0; p_stat->kernel_duration = 0; p_stat->token.data = p_stat; ezt_list_add(&p_device->kernel_stats, &p_stat->token); return p_stat; } /* find the cuda_kernel_info_t that matches kernel_id * return NULL if not found */ struct cuda_kernel_name_t* __cuda_find_kernel_name(struct ezt_list_t*list, kernel_id_t kernel_id) { struct ezt_list_token_t *t = NULL; struct cuda_kernel_name_t *p_name; ezt_list_foreach(list, t){ p_name = (struct cuda_kernel_name_t *) t->data; if(p_name->id == kernel_id) return p_name; } return NULL; } /* create a struct cuda_kernel_info_t for kernel #kernel_id and add it to the list of pending kernels */ struct cuda_kernel_info_t* __cuda_new_kernel(unsigned kernel_id, struct cuda_device_info_t*p_device) { struct cuda_kernel_info_t* p_kernel = malloc(sizeof(struct cuda_kernel_info_t)); p_kernel->kernel_id = kernel_id; p_kernel->gpu_start_time = -1; p_kernel->gpu_stop_time = -1; p_kernel->cpu_start_time = -1; p_kernel->cpu_stop_time = -1; p_kernel->name = NULL; snprintf(p_kernel->link_str, 80, "%s_cuda_%x", p_device->p_process->p_process->container->id, kernel_id); p_kernel->token.data = p_kernel; ezt_list_add(&p_device->pending_kernels, &p_kernel->token); return p_kernel; } /* find the cuda_kernel_info_t that matches kernel_id * return NULL if not found */ struct cuda_kernel_info_t* __cuda_find_kernel(struct ezt_list_t*list, unsigned kernel_id) { struct ezt_list_token_t *t = NULL; struct cuda_kernel_info_t *p_kernel; ezt_list_foreach(list, t){ p_kernel = (struct cuda_kernel_info_t *) t->data; if(p_kernel->kernel_id == kernel_id) return p_kernel; } return NULL; } static struct cuda_device_info_t* __get_device_info(struct cuda_process_info_t *p_cuda, uint32_t device_id) { struct ezt_list_token_t *t = NULL; struct cuda_device_info_t* p_device = NULL; ezt_list_foreach(&p_cuda->device_list, t){ p_device = (struct cuda_device_info_t *) t->data; if(p_device->device_id == device_id) return p_device; } return NULL; } static void __ezt_cuda_init_memcpy_stats(struct cuda_memcpy_stat_t*p_stats) { p_stats->nb_memcpy = 0; p_stats->total_size = 0; p_stats->min_size = 0; p_stats->max_size = 0; } static void __ezt_cuda_init_malloc_stats(struct cuda_malloc_stat_t*p_malloc) { p_malloc->nb_malloc = 0; p_malloc->total_size = 0; p_malloc->peak_mem = 0; p_malloc->cur_mem = 0; } static struct cuda_device_info_t * __new_device(struct cuda_process_info_t* p_process, uint32_t device_id) { struct cuda_device_info_t *p_device = malloc(sizeof(struct cuda_device_info_t)); p_device->p_process = p_process; p_device->start_time = 0; p_device->device_id = device_id; if(p_process->start_time > 0) p_device->start_time = p_process->start_time; asprintf(&p_device->gpu_id, "%s_GPU_%d", p_process->p_process->container->id, device_id); asprintf(&p_device->gpu_name, "%s_GPU_%d", p_process->p_process->container->name, device_id); p_device->added = 0; p_device->link_start = -1; p_device->link_end = -1; /* add the hook in the thread info structure */ ezt_list_new(&p_device->pending_kernels); ezt_list_new(&p_device->finished_kernels); ezt_list_new(&p_device->pending_memcpy); ezt_list_new(&p_device->finished_memcpy); ezt_list_new(&p_device->pending_malloc); ezt_list_new(&p_device->finished_malloc); ezt_list_new(&p_device->kernel_stats); __ezt_cuda_init_memcpy_stats(&p_device->memcpy_stats); __ezt_cuda_init_malloc_stats(&p_device->malloc_stats); p_device->token.data = p_device; ezt_list_add(&p_process->device_list, &p_device->token); return p_device; } /* create a struct cuda_memcpy_info_t and add it to the list of pending memcpy */ struct cuda_memcpy_info_t* __cuda_new_memcpy(enum ezt_cudaMemcpyKind kind, ezt_cuda_size_t size, struct cuda_device_info_t*p_device) { static unsigned memcpy_id = 0; struct cuda_memcpy_info_t* p_memcpy = malloc(sizeof(struct cuda_memcpy_info_t)); p_memcpy->gpu_start_time = -1; p_memcpy->gpu_stop_time = -1; p_memcpy->cpu_start_time = -1; p_memcpy->cpu_stop_time = -1; p_memcpy->id = memcpy_id++; p_memcpy->size = size; p_memcpy->kind = kind; p_memcpy->src = NULL; p_memcpy->dest = NULL; snprintf(p_memcpy->link_str, 80, "%s_memcpy_%x", p_device->p_process->p_process->container->id, p_memcpy->id); p_memcpy->token.data = p_memcpy; ezt_list_add(&p_device->pending_memcpy, &p_memcpy->token); return p_memcpy; } /* find the cuda_memcpy_info_t * return NULL if not found */ struct cuda_memcpy_info_t* __cuda_find_memcpy(struct ezt_list_t*list, enum ezt_cudaMemcpyKind kind, ezt_cuda_size_t size) { struct ezt_list_token_t *t = NULL; struct cuda_memcpy_info_t *p_memcpy; ezt_list_foreach(list, t){ p_memcpy = (struct cuda_memcpy_info_t *) t->data; if((p_memcpy->kind == kind) && (p_memcpy->size == size)) return p_memcpy; } return NULL; } /* create a struct cuda_malloc_info_t for buffer #devPtr_id and add it to the list of pending buffers */ struct cuda_malloc_info_t* __cuda_new_malloc(app_ptr devPtr, struct cuda_device_info_t*p_device) { struct cuda_malloc_info_t* p_malloc = malloc(sizeof(struct cuda_malloc_info_t)); p_malloc->cpu_start_time = -1; p_malloc->cpu_stop_time = -1; p_malloc->token.data = p_malloc; p_malloc->devPtr = devPtr; ezt_list_add(&p_device->pending_malloc, &p_malloc->token); return p_malloc; } /* find the cuda_malloc_info_t that matches devPtr * return NULL if not found */ struct cuda_malloc_info_t* __cuda_find_malloc(struct ezt_list_t*list, app_ptr devPtr) { struct ezt_list_token_t *t = NULL; struct cuda_malloc_info_t *p_malloc; ezt_list_foreach(list, t){ p_malloc = (struct cuda_malloc_info_t *) t->data; if(p_malloc->devPtr == devPtr) return p_malloc; } return NULL; } void handle_cuda_cuLaunchKernel (int start) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); INIT_CUDA_PROCESS_INFO(p_process, p_cuda); uint32_t device_id; kernel_id_t kernel_id; GET_PARAM_PACKED_2(CUR_EV, device_id, kernel_id); struct cuda_device_info_t* p_device = __get_device_info(p_cuda, device_id); if(start) { struct cuda_kernel_info_t *p_kernel = __cuda_new_kernel(kernel_id, p_device); p_kernel->cpu_start_time = CURRENT; CUDA_CHANGE() { __create_device_container(p_device); pushState(CURRENT, "ST_Thread", thread_id, "cuda_cuLaunchKernel"); if(p_device->start_time) { startLink (CURRENT, "hToD_kernel", CUR_ID, thread_id, p_device->gpu_id, p_kernel->link_str, p_kernel->link_str); } } }else{ struct cuda_kernel_info_t *p_kernel = __cuda_find_kernel(&p_device->pending_kernels, kernel_id); p_kernel->cpu_stop_time = CURRENT; CUDA_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } } static void __ezt_cuda_update_memcpy_stats(struct cuda_device_info_t *p_device, ezt_cuda_size_t size) { p_device->memcpy_stats.nb_memcpy ++; p_device->memcpy_stats.total_size += size; if(size < p_device->memcpy_stats.min_size || p_device->memcpy_stats.nb_memcpy == 1) { p_device->memcpy_stats.min_size = size; } if(size > p_device->memcpy_stats.max_size || p_device->memcpy_stats.nb_memcpy == 1) { p_device->memcpy_stats.max_size = size; } } void handle_cuda_cuMemcpy (int start) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); INIT_CUDA_PROCESS_INFO(p_process, p_cuda); int device_id; ezt_cuda_size_t size; enum ezt_cudaMemcpyKind kind; GET_PARAM_PACKED_3(CUR_EV, device_id, size, kind); /* TODO: for now the memcpy record is stored in the list of device #0 * in order to support multi-GPU, we should store it in the srcDevice list (since it is where * handle_cuda_gpu_memcpy_timestamps() searches for it) */ struct cuda_device_info_t* p_device = __get_device_info(p_cuda, device_id); /* todo: add an event that displays the size of the data transfer */ if(start) { struct cuda_memcpy_info_t *p_memcpy = __cuda_new_memcpy(kind, size, p_device); p_memcpy->cpu_start_time = CURRENT; __create_device_container(p_device); CUDA_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, TOSTRING(cuda_cuMemcpy)); if(IS_FROM_CPU(p_memcpy->kind)) p_memcpy->src = thread_id; else p_memcpy->src = p_device->gpu_id; if(IS_TO_CPU(p_memcpy->kind)) p_memcpy->dest = thread_id; else p_memcpy->dest = p_device->gpu_id; CUDA_CHANGE() { if(p_device->start_time && (IS_FROM_CPU(p_memcpy->kind))) { startLink (CURRENT, MEMCPY_TYPE_STR(p_memcpy->kind), CUR_ID, p_memcpy->src, p_memcpy->dest, p_memcpy->link_str, p_memcpy->link_str); } } }else{ struct cuda_memcpy_info_t *p_memcpy = __cuda_find_memcpy(&p_device->pending_memcpy, kind, size); p_memcpy->cpu_stop_time = CURRENT; __ezt_cuda_update_memcpy_stats(p_device, size); CUDA_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } } void handle_cuda_cuMemAlloc (int start) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); INIT_CUDA_PROCESS_INFO(p_process, p_cuda); int device_id; ezt_cuda_size_t size; app_ptr devPtr; if(start) { GET_PARAM_PACKED_2(CUR_EV, device_id, size); } else { GET_PARAM_PACKED_3(CUR_EV, device_id, size, devPtr); } struct cuda_device_info_t* p_device = __get_device_info(p_cuda, device_id); assert(p_device); if(start) { __create_device_container(p_device); /* create a new malloc_info for this buffer. * For now, we don't know the address of the buffer, so let's say NULL */ struct cuda_malloc_info_t * p_malloc = __cuda_new_malloc((app_ptr)NULL, p_device); p_malloc->size = size; CUDA_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "cuda_cuMemAlloc"); CUDA_CHANGE() addVar(CURRENT, "V_GPU_Mem", p_device->gpu_id, size); }else{ /* Get the malloc_info that was created at the entry of cudaMalloc. * We can now assign devPtr. * WARNING: This is not reentrant, so we may have a problem if several threads call cudaMalloc simultaneously */ struct cuda_malloc_info_t * p_malloc = __cuda_find_malloc(&p_device->pending_malloc, (app_ptr)NULL); assert(p_malloc->size == size); p_malloc->devPtr = devPtr; /* update statistics */ p_device->malloc_stats.nb_malloc ++; p_device->malloc_stats.total_size += size; p_device->malloc_stats.cur_mem += size; if(p_device->malloc_stats.cur_mem > p_device->malloc_stats.peak_mem) { p_device->malloc_stats.peak_mem = p_device->malloc_stats.cur_mem; } CUDA_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } } void handle_cuda_cudaFree(int start) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); INIT_CUDA_PROCESS_INFO(p_process, p_cuda); uint32_t device_id; app_ptr devPtr; GET_PARAM_PACKED_2(CUR_EV, device_id, devPtr); struct cuda_device_info_t* p_device = __get_device_info(p_cuda, device_id); assert(p_device); /* Get the malloc_info that was created in cudaMalloc. * This permits to know the buffer size. */ struct cuda_malloc_info_t * p_malloc = __cuda_find_malloc(&p_device->pending_malloc, devPtr); if(start) { __create_device_container(p_device); CUDA_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "cuda_cudaFree"); CUDA_CHANGE() subVar(CURRENT, "V_GPU_Mem", p_device->gpu_id, p_malloc->size); }else{ CUDA_CHANGE() popState(CURRENT, "ST_Thread", thread_id); ezt_list_remove(&p_malloc->token); ezt_list_add(&p_device->finished_malloc, &p_malloc->token); } } void handle_cuda_gpu_kernel_timestamps() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); INIT_CUDA_PROCESS_INFO(p_process, p_cuda); unsigned kernel_type; float start_time; float stop_time; kernel_id_t kernel_id; uint32_t device_id; GET_PARAM_PACKED_5(CUR_EV, kernel_type, start_time, stop_time, kernel_id, device_id); struct cuda_device_info_t* p_device = __get_device_info(p_cuda, device_id); struct cuda_kernel_info_t *p_kernel = __cuda_find_kernel(&p_device->pending_kernels, kernel_type); p_kernel->name = __cuda_find_kernel_name(&p_cuda->kernel_names, kernel_id); p_kernel->gpu_start_time = p_device->start_time + GPU_TIMESTAMP_TO_CPU(start_time); p_kernel->gpu_stop_time = p_device->start_time + GPU_TIMESTAMP_TO_CPU(stop_time); CUDA_CHANGE() pushState(p_kernel->gpu_start_time, "ST_GPU", p_device->gpu_id, p_kernel->name->state_id); /* todo: use the kernel id to identify the link */ CUDA_CHANGE() { if(p_device->start_time) { endLink(p_kernel->gpu_start_time, "hToD_kernel", CUR_ID, thread_id, p_device->gpu_id, p_kernel->link_str, p_kernel->link_str); } popState(p_kernel->gpu_stop_time, "ST_GPU", p_device->gpu_id); } /* update the kernel statistics */ struct cuda_kernel_stat_t*p_stats = __cuda_find_kernel_stats(p_device, p_kernel->name); p_stats->nb_calls++; double kernel_runtime = p_kernel->gpu_stop_time-p_kernel->gpu_start_time; p_stats->kernel_duration += kernel_runtime; if(kernel_runtime < p_stats->min_duration) { p_stats->min_duration = kernel_runtime; } if(kernel_runtime > p_stats->max_duration) { p_stats->max_duration = kernel_runtime; } /* remove the kernel from the list of pending kernels and add it to the list of finished kernels */ ezt_list_remove(&p_kernel->token); ezt_list_add(&p_device->finished_kernels, &p_kernel->token); } void handle_cuda_gpu_memcpy_timestamps() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); INIT_CUDA_PROCESS_INFO(p_process, p_cuda); float start_time; float stop_time; ezt_cuda_size_t size; enum ezt_cudaMemcpyKind kind; int srcDeviceId; int destDeviceId; GET_PARAM_PACKED_6(CUR_EV, start_time, stop_time, size, kind, srcDeviceId, destDeviceId); struct cuda_device_info_t* p_srcDevice = __get_device_info(p_cuda, srcDeviceId); assert(p_srcDevice); struct cuda_device_info_t* p_destDevice = __get_device_info(p_cuda, destDeviceId); assert(p_destDevice); struct cuda_memcpy_info_t *p_memcpy = __cuda_find_memcpy(&p_srcDevice->pending_memcpy, kind, size); assert(p_memcpy); p_memcpy->gpu_start_time = p_srcDevice->start_time + GPU_TIMESTAMP_TO_CPU(start_time); p_memcpy->gpu_stop_time = p_srcDevice->start_time + GPU_TIMESTAMP_TO_CPU(stop_time); CUDA_CHANGE() { pushState(p_memcpy->gpu_start_time, "ST_GPU", p_srcDevice->gpu_id, "cuda_gpu_memcpy"); if(p_srcDevice->start_time) { if(IS_FROM_GPU(p_memcpy->kind)) { startLink (p_memcpy->gpu_start_time, MEMCPY_TYPE_STR(p_memcpy->kind), CUR_ID, p_memcpy->src, p_memcpy->dest, p_memcpy->link_str, p_memcpy->link_str); } endLink(p_memcpy->gpu_stop_time, MEMCPY_TYPE_STR(p_memcpy->kind), CUR_ID, p_memcpy->src, p_memcpy->dest, p_memcpy->link_str, p_memcpy->link_str); } popState(p_memcpy->gpu_stop_time, "ST_GPU", p_srcDevice->gpu_id); } /* remove the memcpy from the list of pending memcpy and add it to the list of finished memcpy */ ezt_list_remove(&p_memcpy->token); ezt_list_add(&p_srcDevice->finished_memcpy, &p_memcpy->token); } int eztrace_convert_cuda_init() { if(get_mode() == EZTRACE_CONVERT) { addContType("CT_GPU", "0", "GPU"); addStateType("ST_GPU", "CT_GPU", "GPU"); addLinkType("hToD_kernel", "kernel", "CT_Process", "CT_Thread", "CT_GPU"); addLinkType("HToD_memcpy", "memcpy", "CT_Process", "CT_Thread", "CT_GPU"); addLinkType("DToH_memcpy", "memcpy", "CT_Process", "CT_GPU", "CT_Thread"); addLinkType("HToH_memcpy", "memcpy", "CT_Process", "CT_Thread", "CT_Thread"); addLinkType("DToD_memcpy", "memcpy", "CT_Process", "CT_GPU", "CT_GPU"); addEntityValue("cuda_cuMemAlloc", "ST_Thread", "cuda_cuMemAlloc", GTG_YELLOW); addEntityValue("cuda_cuLaunchKernel", "ST_Thread", "cuda_cuLaunchKernel", GTG_GREEN); addEntityValue("cuda_cudaThreadSynchronize", "ST_Thread", "cuda_cudaThreadSynchronize", GTG_RED); addEntityValue("cuda_cuMemcpy", "ST_Thread", "cuda_cuMemcpy", GTG_BLACK); addEntityValue("cuda_gpu_kernel", "ST_GPU", "cuda_gpu_kernel", GTG_GREEN); addEntityValue("cuda_gpu_memcpy", "ST_GPU", "cuda_gpu_memcpy", GTG_BLACK); addEntityValue("cuda_gpu_idle", "ST_GPU", "cuda_gpu_idle", GTG_RED); addVarType ("V_GPU_Mem", "Memory used", "CT_GPU"); } return 0; } static void __create_device_container(struct cuda_device_info_t* p_device) { CUDA_CHANGE() { if(! p_device->added) { addContainer(CURRENT, p_device->gpu_id, "CT_GPU", p_device->p_process->p_process->container->id, p_device->gpu_name, "0"); pushState(CURRENT, "ST_GPU", p_device->gpu_id, "cuda_gpu_idle"); setVar(CURRENT, "V_GPU_Mem", p_device->gpu_id, 0); p_device->added = 1; } } } void handle_cuda_register_kernel() { FUNC_NAME; DECLARE_CUR_PROCESS(p_process); INIT_CUDA_PROCESS_INFO(p_process, p_cuda); kernel_id_t kernel_id; GET_PARAM_PACKED_1(CUR_EV, kernel_id); wait_for_an_event(CUR_INDEX, EZTRACE_CUDA_KERNEL_NAME); struct cuda_kernel_name_t* p_kernel = malloc(sizeof(struct cuda_kernel_name_t)); p_kernel->id = kernel_id; assert(LITL_READ_GET_TYPE(CUR_EV) == LITL_TYPE_RAW); const char* mangled_name = (char*)LITL_READ_RAW(CUR_EV)->data; const char* demangled_name = ezt_demangle(mangled_name); strncpy(p_kernel->name, demangled_name, 80); p_kernel->token.data = p_kernel; sprintf(p_kernel->state_id, "cuda_kernel_%x", p_kernel->id); sprintf(p_kernel->state_desc, "kernel %s", p_kernel->name); CUDA_CHANGE() addEntityValue(p_kernel->state_id, "ST_GPU", p_kernel->state_desc, GTG_GREEN); ezt_list_add(&p_cuda->kernel_names, &p_kernel->token); } void handle_cuda_cuInit() { DECLARE_CUR_PROCESS(p_process); INIT_CUDA_PROCESS_INFO(p_process, p_cuda); FUNC_NAME; p_cuda->start_time = (CURRENT); } void handle_cuda_setnbdevices() { FUNC_NAME; DECLARE_CUR_PROCESS(p_process); INIT_CUDA_PROCESS_INFO(p_process, p_cuda); int num_gpus; GET_PARAM_PACKED_1(CUR_EV, num_gpus); int i; for(i=0; istart_time = (CURRENT); __create_device_container(p_device); } } /* return 1 if the event was handled */ int handle_cuda_events(eztrace_event_t *ev) { if(!STARTED) return 0; switch (LITL_READ_GET_CODE(ev)) { case EZTRACE_CUDA_CUMEMALLOC_START: handle_cuda_cuMemAlloc(1); break; case EZTRACE_CUDA_CUMEMALLOC_STOP: handle_cuda_cuMemAlloc(0); break; case EZTRACE_CUDA_CUDAFREE_START: handle_cuda_cudaFree(1); break; case EZTRACE_CUDA_CUDAFREE_STOP: handle_cuda_cudaFree(0); break; case EZTRACE_CUDA_CULAUNCHKERNEL_START: handle_cuda_cuLaunchKernel(1); break; case EZTRACE_CUDA_CULAUNCHKERNEL_STOP: handle_cuda_cuLaunchKernel(0); break; case EZTRACE_CUDA_CUMEMCPY_START: handle_cuda_cuMemcpy(1); break; case EZTRACE_CUDA_CUMEMCPY_STOP: handle_cuda_cuMemcpy(0); break; case EZTRACE_CUDA_CUDATHREADSYNCHRONIZE_START: handle_cuda_cudaThreadSynchronize(1); break; case EZTRACE_CUDA_CUDATHREADSYNCHRONIZE_STOP: handle_cuda_cudaThreadSynchronize(0); break; case EZTRACE_CUDA_CUDADEVICESYNCHRONIZE_START: handle_cuda_cudaThreadSynchronize(1); break; case EZTRACE_CUDA_CUDADEVICESYNCHRONIZE_STOP: handle_cuda_cudaThreadSynchronize(0); break; case EZTRACE_CUDA_CUINIT: handle_cuda_cuInit(); break; case EZTRACE_CUDA_SETNBDEVICES: handle_cuda_setnbdevices(); break; case EZTRACE_CUDA_REGISTER_KERNEL: handle_cuda_register_kernel(); break; case EZTRACE_CUDA_GPU_KERNEL_TIMESTAMPS: handle_cuda_gpu_kernel_timestamps(); break; case EZTRACE_CUDA_GPU_MEMCPY_TIMESTAMPS: handle_cuda_gpu_memcpy_timestamps(); break; default: return 1; } return 1; } int handle_cuda_stats(eztrace_event_t *ev) { recording_stats = 1; return handle_cuda_events(ev); } #define FORMAT_BYTES(nb_bytes) \ ((uint64_t)nb_bytes<1024?"B": \ ((uint64_t)nb_bytes<1024*1024?"KB": \ ((uint64_t)nb_bytes<1024*1024*1024?"MB": \ ((uint64_t)nb_bytes<(uint64_t)1024*1024*1024*1024?"GB": \ ((uint64_t)nb_bytes<(uint64_t)1024*1024*1024*1024*1024?"TB": \ "PB"))))) static float VALUE_BYTES(uint64_t nb_bytes) { int i; uint64_t div=1; for(i=0; i<6; i++) { if((nb_bytes/div)<1024) return (nb_bytes/(double)div); div*=1024; } return (float)nb_bytes; } void __ezt_print_device_stats(struct cuda_device_info_t *p_device) { /* For each device: total allocated memory */ printf("%s\n", p_device->gpu_name); struct cuda_kernel_stat_t *p_stat; struct ezt_list_token_t *t = NULL; /* print the list of executed kernels */ ezt_list_foreach(&p_device->kernel_stats, t) { p_stat = (struct cuda_kernel_stat_t *) t->data; if(p_stat->nb_calls) { double avg_runtime = p_stat->kernel_duration/p_stat->nb_calls; printf("\tkernel %s was called %d times. Total run time: %lf ns, min: %lf ns, max: %lf ns, avg: %lf ns\n", p_stat->p_kernel->name, p_stat->nb_calls, p_stat->kernel_duration, p_stat->min_duration, p_stat->max_duration, avg_runtime); } } /* print the list of executed memcpy */ struct cuda_memcpy_stat_t *p_memcpy = &p_device->memcpy_stats; if(p_memcpy->nb_memcpy>0) { printf("\tNumber of calls to cudaMemcpy: %d. Total size copied: %f %s (min: %f %s, max: %f %s, avg: %f %s)\n", p_memcpy->nb_memcpy, VALUE_BYTES(p_memcpy->total_size), FORMAT_BYTES(p_memcpy->total_size), VALUE_BYTES(p_memcpy->min_size), FORMAT_BYTES(p_memcpy->min_size), VALUE_BYTES(p_memcpy->max_size), FORMAT_BYTES(p_memcpy->max_size), VALUE_BYTES(p_memcpy->total_size/p_memcpy->nb_memcpy), FORMAT_BYTES(p_memcpy->total_size/p_memcpy->nb_memcpy)); } /* print the memory information */ struct cuda_malloc_stat_t *p_malloc = &p_device->malloc_stats; if(p_malloc->nb_malloc>0) { printf("\tNumber of calls to cudaMalloc: %d. Total size allocated: %f %s (peak: %f %s)\n", p_malloc->nb_malloc, VALUE_BYTES(p_malloc->total_size), FORMAT_BYTES(p_malloc->total_size), VALUE_BYTES(p_malloc->peak_mem), FORMAT_BYTES(p_malloc->peak_mem)); } } void print_cuda_stats() { printf("\nCUDA:\n"); printf("----------\n"); /* browse the processes finished_section_list and extract statistics */ int i; for (i = 0; i < NB_TRACES; i++) { struct process_info_t *p_process = GET_PROCESS_INFO(i); struct cuda_process_info_t *p_info = (struct cuda_process_info_t*) ezt_hook_list_retrieve_data( &p_process->hooks, (uint8_t) EZTRACE_CUDA_EVENTS_ID); if (!p_info) continue; /* No cuda process info attached, skip this process */ struct ezt_list_token_t *token; ezt_list_foreach(&p_info->device_list, token) { struct cuda_device_info_t * p_device = (struct cuda_device_info_t *) token->data; assert(p_device); __ezt_print_device_stats(p_device); } } } struct eztrace_convert_module cuda_module; void libinit(void) __attribute__ ((constructor)); void libinit(void) { cuda_module.api_version = EZTRACE_API_VERSION; cuda_module.init = eztrace_convert_cuda_init; cuda_module.handle = handle_cuda_events; cuda_module.handle_stats = handle_cuda_stats; cuda_module.print_stats = print_cuda_stats; cuda_module.module_prefix = EZTRACE_CUDA_EVENTS_ID; asprintf(&cuda_module.name, "cuda"); asprintf(&cuda_module.description, "Module for cuda functions (cuMemAlloc, cuMemcopy, etc.)"); cuda_module.token.data = &cuda_module; eztrace_convert_register_module(&cuda_module); } void libfinalize(void) __attribute__ ((destructor)); void libfinalize(void) { } eztrace-1.1-2/src/modules/memory/000077500000000000000000000000001265506773700167405ustar00rootroot00000000000000eztrace-1.1-2/src/modules/memory/Makefile.am000066400000000000000000000026771265506773700210100ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. TLCFLAGS=$(TL_CPPFLAGS) TLLDFLAGS=$(TL_LDFLAGS) TLLIBADD=$(TL_LIB) GTGCFLAGS=$(GTG_CPPFLAGS) GTGLDFLAGS=$(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD=$(GTG_LIB) lib_LTLIBRARIES = libeztrace-convert-memory.la \ libeztrace-memory.la \ libeztrace-autostart-memory.la AM_CFLAGS = -W -Wall -Wextra -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ -I$(top_srcdir)/src/pptrace libeztrace_convert_memory_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) libeztrace_convert_memory_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) libeztrace_convert_memory_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_memory_la_SOURCES = eztrace_convert_memory.c libeztrace_convert_memory_la_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace_memory_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_memory_la_LIBADD = $(TLLIBADD) libeztrace_memory_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_memory_la_SOURCES = memory.c libeztrace_autostart_memory_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_autostart_memory_la_LIBADD = $(TLLIBADD) libeztrace_autostart_memory_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_autostart_memory_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra \ -DEZTRACE_AUTOSTART libeztrace_autostart_memory_la_SOURCES = memory.c noinst_HEADERS = memory_ev_codes.h eztrace-1.1-2/src/modules/memory/Makefile.in000066400000000000000000000715771265506773700210260ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = src/modules/memory ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(noinst_HEADERS) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(libdir)" LTLIBRARIES = $(lib_LTLIBRARIES) am__DEPENDENCIES_1 = am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) libeztrace_autostart_memory_la_DEPENDENCIES = $(am__DEPENDENCIES_2) am_libeztrace_autostart_memory_la_OBJECTS = \ libeztrace_autostart_memory_la-memory.lo libeztrace_autostart_memory_la_OBJECTS = \ $(am_libeztrace_autostart_memory_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libeztrace_autostart_memory_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(libeztrace_autostart_memory_la_CFLAGS) $(CFLAGS) \ $(libeztrace_autostart_memory_la_LDFLAGS) $(LDFLAGS) -o $@ am_libeztrace_convert_memory_la_OBJECTS = \ libeztrace_convert_memory_la-eztrace_convert_memory.lo libeztrace_convert_memory_la_OBJECTS = \ $(am_libeztrace_convert_memory_la_OBJECTS) libeztrace_convert_memory_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_convert_memory_la_LDFLAGS) \ $(LDFLAGS) -o $@ libeztrace_memory_la_DEPENDENCIES = $(am__DEPENDENCIES_2) am_libeztrace_memory_la_OBJECTS = libeztrace_memory_la-memory.lo libeztrace_memory_la_OBJECTS = $(am_libeztrace_memory_la_OBJECTS) libeztrace_memory_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_memory_la_LDFLAGS) \ $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libeztrace_autostart_memory_la_SOURCES) \ $(libeztrace_convert_memory_la_SOURCES) \ $(libeztrace_memory_la_SOURCES) DIST_SOURCES = $(libeztrace_autostart_memory_la_SOURCES) \ $(libeztrace_convert_memory_la_SOURCES) \ $(libeztrace_memory_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac HEADERS = $(noinst_HEADERS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ TLCFLAGS = $(TL_CPPFLAGS) TLLDFLAGS = $(TL_LDFLAGS) TLLIBADD = $(TL_LIB) GTGCFLAGS = $(GTG_CPPFLAGS) GTGLDFLAGS = $(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD = $(GTG_LIB) lib_LTLIBRARIES = libeztrace-convert-memory.la \ libeztrace-memory.la \ libeztrace-autostart-memory.la AM_CFLAGS = -W -Wall -Wextra -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ -I$(top_srcdir)/src/pptrace libeztrace_convert_memory_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) libeztrace_convert_memory_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) libeztrace_convert_memory_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_memory_la_SOURCES = eztrace_convert_memory.c libeztrace_convert_memory_la_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace_memory_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_memory_la_LIBADD = $(TLLIBADD) libeztrace_memory_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_memory_la_SOURCES = memory.c libeztrace_autostart_memory_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_autostart_memory_la_LIBADD = $(TLLIBADD) libeztrace_autostart_memory_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_autostart_memory_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra \ -DEZTRACE_AUTOSTART libeztrace_autostart_memory_la_SOURCES = memory.c noinst_HEADERS = memory_ev_codes.h all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/modules/memory/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu src/modules/memory/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ } uninstall-libLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ done clean-libLTLIBRARIES: -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) @list='$(lib_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libeztrace-autostart-memory.la: $(libeztrace_autostart_memory_la_OBJECTS) $(libeztrace_autostart_memory_la_DEPENDENCIES) $(EXTRA_libeztrace_autostart_memory_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_autostart_memory_la_LINK) -rpath $(libdir) $(libeztrace_autostart_memory_la_OBJECTS) $(libeztrace_autostart_memory_la_LIBADD) $(LIBS) libeztrace-convert-memory.la: $(libeztrace_convert_memory_la_OBJECTS) $(libeztrace_convert_memory_la_DEPENDENCIES) $(EXTRA_libeztrace_convert_memory_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_convert_memory_la_LINK) -rpath $(libdir) $(libeztrace_convert_memory_la_OBJECTS) $(libeztrace_convert_memory_la_LIBADD) $(LIBS) libeztrace-memory.la: $(libeztrace_memory_la_OBJECTS) $(libeztrace_memory_la_DEPENDENCIES) $(EXTRA_libeztrace_memory_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_memory_la_LINK) -rpath $(libdir) $(libeztrace_memory_la_OBJECTS) $(libeztrace_memory_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_autostart_memory_la-memory.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_memory_la-eztrace_convert_memory.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_memory_la-memory.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< libeztrace_autostart_memory_la-memory.lo: memory.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_memory_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_memory_la_CFLAGS) $(CFLAGS) -MT libeztrace_autostart_memory_la-memory.lo -MD -MP -MF $(DEPDIR)/libeztrace_autostart_memory_la-memory.Tpo -c -o libeztrace_autostart_memory_la-memory.lo `test -f 'memory.c' || echo '$(srcdir)/'`memory.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_autostart_memory_la-memory.Tpo $(DEPDIR)/libeztrace_autostart_memory_la-memory.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='memory.c' object='libeztrace_autostart_memory_la-memory.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_memory_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_memory_la_CFLAGS) $(CFLAGS) -c -o libeztrace_autostart_memory_la-memory.lo `test -f 'memory.c' || echo '$(srcdir)/'`memory.c libeztrace_convert_memory_la-eztrace_convert_memory.lo: eztrace_convert_memory.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_memory_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_memory_la-eztrace_convert_memory.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_memory_la-eztrace_convert_memory.Tpo -c -o libeztrace_convert_memory_la-eztrace_convert_memory.lo `test -f 'eztrace_convert_memory.c' || echo '$(srcdir)/'`eztrace_convert_memory.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_memory_la-eztrace_convert_memory.Tpo $(DEPDIR)/libeztrace_convert_memory_la-eztrace_convert_memory.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_memory.c' object='libeztrace_convert_memory_la-eztrace_convert_memory.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_memory_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_memory_la-eztrace_convert_memory.lo `test -f 'eztrace_convert_memory.c' || echo '$(srcdir)/'`eztrace_convert_memory.c libeztrace_memory_la-memory.lo: memory.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_memory_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_memory_la-memory.lo -MD -MP -MF $(DEPDIR)/libeztrace_memory_la-memory.Tpo -c -o libeztrace_memory_la-memory.lo `test -f 'memory.c' || echo '$(srcdir)/'`memory.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_memory_la-memory.Tpo $(DEPDIR)/libeztrace_memory_la-memory.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='memory.c' object='libeztrace_memory_la-memory.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_memory_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_memory_la-memory.lo `test -f 'memory.c' || echo '$(srcdir)/'`memory.c mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) $(HEADERS) installdirs: for dir in "$(DESTDIR)$(libdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-libLTLIBRARIES install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-libLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libLTLIBRARIES clean-libtool cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-libLTLIBRARIES install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-libLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/src/modules/memory/eztrace_convert_memory.c000066400000000000000000000152611265506773700236760ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include #include "eztrace_convert.h" #include "eztrace_convert_macros.h" #include "memory_ev_codes.h" #include "eztrace_list.h" static int recording_stats = 0; #define MEMORY_CHANGE() if(!recording_stats) CHANGE() struct memory_process_info_t { struct process_info_t *p_process; uint64_t memory_use; uint32_t nb_malloc; uint32_t nb_free; uint64_t total_malloced; uint64_t total_freed; uint64_t max_mem_used; }; static struct memory_process_info_t *__register_process_hook( struct process_info_t *p_process) { struct memory_process_info_t *p_mem = (struct memory_process_info_t*) malloc( sizeof(struct memory_process_info_t)); p_mem->p_process = p_process; p_mem->memory_use = 0; p_mem->nb_malloc = 0; p_mem->nb_free = 0; p_mem->total_malloced = 0; p_mem->total_freed = 0; p_mem->max_mem_used = 0; /* add the hook in the thread info structure */ ezt_hook_list_add(&p_mem->p_process->hooks, p_mem, (uint8_t) EZTRACE_MEMORY_EVENTS_ID); return p_mem; } #define INIT_MEMORY_PROCESS_INFO(p_process, var) \ struct memory_process_info_t *var = (struct memory_process_info_t*) \ ezt_hook_list_retrieve_data(&p_process->hooks, (uint8_t)EZTRACE_MEMORY_EVENTS_ID); \ if(!(var)) { \ var = __register_process_hook(p_process); \ } void handle_memory_malloc() { FUNC_NAME; /* warning: this function may be called before the trace is started (eg. before MPI_Init is detected) * so proc_id may be undefined. * In this case, proc_id is used only after MPI_Init, so there's no real problem. */ DECLARE_PROCESS_ID_STR(proc_id, CUR_INDEX); size_t block_size; app_ptr ptr; GET_PARAM_PACKED_2(CUR_EV, block_size, ptr); DECLARE_CUR_PROCESS(p_process); INIT_MEMORY_PROCESS_INFO(p_process, p_mem); p_mem->nb_malloc++; p_mem->memory_use += block_size; p_mem->total_malloced += block_size; if (p_mem->memory_use > p_mem->max_mem_used) p_mem->max_mem_used = p_mem->memory_use; MEMORY_CHANGE() setVar(CURRENT, "V_Mem", proc_id, p_mem->memory_use); } void handle_memory_realloc() { FUNC_NAME; /* warning: this function may be called before the trace is started (eg. before MPI_Init is detected) * so proc_id may be undefined. * In this case, proc_id is used only after MPI_Init, so there's no real problem. */ DECLARE_PROCESS_ID_STR(proc_id, CUR_INDEX); size_t old_size; size_t new_size; app_ptr ptr; GET_PARAM_PACKED_3(CUR_EV, old_size, new_size, ptr); DECLARE_CUR_PROCESS(p_process); INIT_MEMORY_PROCESS_INFO(p_process, p_mem); p_mem->nb_malloc++; p_mem->nb_free++; p_mem->memory_use += new_size - old_size; p_mem->total_malloced += new_size - old_size; if (p_mem->memory_use > p_mem->max_mem_used) p_mem->max_mem_used = p_mem->memory_use; MEMORY_CHANGE() setVar(CURRENT, "V_Mem", proc_id, p_mem->memory_use); } void handle_memory_free() { FUNC_NAME; /* warning: this function may be called before the trace is started (eg. before MPI_Init is detected) * so proc_id may be undefined. * In this case, proc_id is used only after MPI_Init, so there's no real problem. */ DECLARE_PROCESS_ID_STR(proc_id, CUR_INDEX); size_t block_size; app_ptr ptr; GET_PARAM_PACKED_2(CUR_EV, block_size, ptr); DECLARE_CUR_PROCESS(p_process); INIT_MEMORY_PROCESS_INFO(p_process, p_mem); p_mem->nb_free++; if (p_mem->memory_use >= block_size) p_mem->memory_use -= block_size; else { fprintf( stderr, "t=%lf\tWarning: %s frees %ld bytes, but only %ld are currently allocated\n", CURRENT, CUR_ID, block_size, p_mem->memory_use); p_mem->memory_use = 0; } p_mem->total_freed += block_size; MEMORY_CHANGE() setVar(CURRENT, "V_Mem", proc_id, p_mem->memory_use); } int eztrace_convert_memory_init() { if (get_mode() == EZTRACE_CONVERT) { addVarType("V_Mem", "Memory used", "CT_Process"); } return 0; } /* return 1 if the event was handled */ int handle_memory_events(eztrace_event_t *ev) { switch (LITL_READ_GET_CODE(ev)) { case EZTRACE_MEMORY_MALLOC: handle_memory_malloc(); break; case EZTRACE_MEMORY_FREE: handle_memory_free(); break; case EZTRACE_MEMORY_REALLOC: handle_memory_realloc(); break; default: return 0; } return 1; } int handle_memory_stats(eztrace_event_t *ev) { recording_stats = 1; return handle_memory_events(ev); } void print_memory_stats() { printf("\nMEMORY:\n"); printf("-------\n"); int i; uint32_t nb_malloc = 0; uint32_t nb_free = 0; uint64_t total_malloced = 0; uint64_t total_freed = 0; uint64_t max_mem_used = 0; for (i = 0; i < NB_TRACES; i++) { struct process_info_t *p_process = GET_PROCESS_INFO(i); struct memory_process_info_t *p_info = (struct memory_process_info_t*) ezt_hook_list_retrieve_data( &p_process->hooks, (uint8_t) EZTRACE_MEMORY_EVENTS_ID); if (!p_info) { printf("No p_info for %s\n", p_process->container->name); continue; /* No memory process info attached, skip this process */ } nb_malloc += p_info->nb_malloc; nb_free += p_info->nb_free; total_malloced += p_info->total_malloced; total_freed += p_info->total_freed; if (p_info->max_mem_used > max_mem_used) max_mem_used = p_info->max_mem_used; printf("\t%s:\t", p_process->container->name); printf("%u malloc (total: %lu bytes)\t", p_info->nb_malloc, p_info->total_malloced); printf("%u free (total: %lu bytes)\t", p_info->nb_free, p_info->total_freed); printf("maximum memory used: %"PRTIu64" bytes\n", p_info->max_mem_used); } printf("Total:\t"); printf("%u malloc (total: %"PRTIu64" bytes)\t", nb_malloc, total_malloced); printf("%u free (total: %"PRTIu64" bytes)\t", nb_free, total_freed); printf("maximum memory used: %"PRTIu64" bytes\n", max_mem_used); } struct eztrace_convert_module memory_module; void libinit(void) __attribute__ ((constructor)); void libinit(void) { memory_module.api_version = EZTRACE_API_VERSION; memory_module.init = eztrace_convert_memory_init; memory_module.handle = handle_memory_events; memory_module.handle_stats = handle_memory_stats; memory_module.print_stats = print_memory_stats; memory_module.module_prefix = EZTRACE_MEMORY_EVENTS_ID; int res __attribute__ ((__unused__)); res = asprintf(&memory_module.name, "memory"); res = asprintf(&memory_module.description, "Module for memory functions (malloc, free, etc.)"); memory_module.token.data = &memory_module; eztrace_convert_register_module(&memory_module); } void libfinalize(void) __attribute__ ((destructor)); void libfinalize(void) { } eztrace-1.1-2/src/modules/memory/memory.c000066400000000000000000000225321265506773700204200ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 /* or _BSD_SOURCE or _SVID_SOURCE */ #define _REENTRANT #include #include #include #include #include #include "memory_ev_codes.h" #include "eztrace.h" #include "eztrace_litl_packed.h" #include "pptrace.h" /* set to 1 when all the hooks are set. * This is useful in order to avoid recursive calls */ static int __memory_initialized = 0; #define MAGIC_PATTERN 0xdeadbeef /* when a buffer is allocated with eztrace, it has the following pattern: * PADDING BLOCK_INFO USER_BLOCK * block_info has to be right-aligned because of calloc. * the address should be a multiple of 8 bytes in order to avoid bugs * (if not aligned, some weird bugs may happen when using -O3) */ enum __memory_type { MEM_TYPE_MALLOC, MEM_TYPE_CUSTOM_MALLOC }; /* todo: we could add information like: * - date of malloc * - thread id that allocated the block * - NUMA node ? */ struct mem_block_info { void* u_ptr; /* address of the user block */ void* p_ptr; /* address of the padding */ enum __memory_type mem_type; size_t total_size; /* size allocated (including this structure) */ size_t size; /* size of the buffer (not including this structure) */ /* WARNING: this must be the last field of the structure */ uint32_t canary; /* this is used for checking that we malloc'ed the buffer */ }__attribute__((__packed__)); /* size of the padding + mem_info structure */ #define GET_HEADER_SIZE() (sizeof(struct mem_block_info)) #define CANARY_OK(u_ptr) ((*(uint32_t*)((u_ptr) - sizeof(uint32_t))) == MAGIC_PATTERN) /* converts a pointer to a user_block into a pointer to the block info */ #define USER_PTR_TO_BLOCK_INFO(u_ptr, b_ptr) \ do { \ if(! CANARY_OK(u_ptr)) { \ /* we didn't malloc this buffer */ \ (b_ptr) = NULL; \ break; \ } \ b_ptr = (void*)(ptr - (void*)sizeof(struct mem_block_info)); \ }while(0) /* converts a pointer to a user_block into a pointer to the padding */ #define USER_PTR_TO_PADDING(u_ptr, p_ptr) \ do { \ struct mem_block_info *b_ptr; \ USER_PTR_TO_BLOCK_INFO(u_ptr, b_ptr); \ if(!b_ptr) { \ (p_ptr) = NULL; \ break; \ } \ (p_ptr) = b_ptr->p_ptr; \ } while(0) /* fill a mem_info structure * @param p_mem the mem_info* structure to fill * @param ptr the address returned by (m,c,re)alloc * @param nmemb the number of elements * @param block_size the size of 1 element */ #define INIT_MEM_INFO(p_mem, ptr, nmemb, block_size) \ do { \ unsigned int nb_memb_header = GET_HEADER_SIZE() / block_size; \ if(block_size*nb_memb_header < GET_HEADER_SIZE()) \ nb_memb_header++; \ void* u_ptr = ptr + (block_size*nb_memb_header); \ p_mem = u_ptr - sizeof(struct mem_block_info); \ p_mem->p_ptr = ptr; \ p_mem->total_size = (nmemb + nb_memb_header) * block_size; \ p_mem->size = nmemb * block_size; \ p_mem->u_ptr = u_ptr; \ p_mem->canary = MAGIC_PATTERN; \ } while(0) /* todo: also implement mmap and munmap ? */ void* (*libcalloc)(size_t nmemb, size_t size) = NULL; void* (*libmalloc)(size_t size) = NULL; void (*libfree)(void *ptr) = NULL; void* (*librealloc)(void *ptr, size_t size) = NULL; static int malloc_protect_on = 0; /* Custom malloc function. It is used when libmalloc=NULL (e.g. during startup) * This function is not thread-safe and is very likely to be bogus, so use with * caution */ static void* hand_made_malloc(size_t size) { /* allocate a 1MB buffer */ #define POOL_SIZE (1024 * 1024) static char mem[POOL_SIZE] = {'\0'}; /* since this function is only used before we found libmalloc, there's no * fancy memory management mechanism (block reuse, etc.) */ static char* next_slot = &mem[0]; static int total_alloc = 0; if (libmalloc) /* let's use the real malloc */ return malloc(size); struct mem_block_info *p_block = NULL; INIT_MEM_INFO(p_block, next_slot, size, 1); p_block->mem_type = MEM_TYPE_CUSTOM_MALLOC; total_alloc += size; next_slot = next_slot + p_block->total_size; return p_block->u_ptr; } void* malloc(size_t size) { /* if memory_init hasn't been called yet, we need to get libc's malloc * address */ if (!libmalloc) { if (malloc_protect_on) /* protection flag says that malloc is already trying to retrieve the * address of malloc. * If we call dlsym now, there will be an infinite recursion, so let's * allocate memory 'by hand' */ return hand_made_malloc(size); /* set the protection flag and retrieve the address of malloc. * If dlsym calls malloc, memory will be allocated 'by hand' */ malloc_protect_on = 1; libmalloc = dlsym(RTLD_NEXT, "malloc"); char* error; if ((error = dlerror()) != NULL) { fputs(error, stderr); exit(1); } /* it is now safe to call libmalloc */ malloc_protect_on = 0; } FUNCTION_ENTRY; EZTRACE_PROTECT { void* pptr = libmalloc(size + GET_HEADER_SIZE()); struct mem_block_info *p_block = NULL; INIT_MEM_INFO(p_block, pptr, size, 1); p_block->mem_type = MEM_TYPE_MALLOC; EZTRACE_EVENT_PACKED_2(EZTRACE_MEMORY_MALLOC, p_block->size, (app_ptr)p_block->u_ptr); #if 0 /* for debugging purpose only */ uint32_t* canary = p_block->u_ptr-sizeof(uint32_t); if(*canary != MAGIC_PATTERN) { fprintf(stderr, "warning: canary = %x instead of %x\n", *canary, MAGIC_PATTERN); } #endif return p_block->u_ptr; } return libmalloc(size); } void* realloc(void *ptr, size_t size) { /* if ptr is NULL, realloc behaves like malloc */ if (!ptr) return malloc(size); /* if size=0 and ptr isn't NULL, realloc behaves like free */ if (!size && ptr) { free(ptr); return NULL; } FUNCTION_ENTRY; if (!librealloc) { librealloc = dlsym(RTLD_NEXT, "realloc"); char* error; if ((error = dlerror()) != NULL) { fputs(error, stderr); exit(1); } } if (!CANARY_OK(ptr)) { /* we didn't malloc'ed this buffer */ return librealloc(ptr, size); } EZTRACE_PROTECT { struct mem_block_info *p_block; USER_PTR_TO_BLOCK_INFO(ptr, p_block); size_t old_size = p_block->size; size_t header_size = p_block->total_size - p_block->size; if (p_block->mem_type != MEM_TYPE_MALLOC) { fprintf( stderr, "Warning: realloc a ptr that was allocated by hand_made_malloc\n"); } void *pptr = librealloc(p_block->p_ptr, size + header_size); if (!p_block) { return NULL; } INIT_MEM_INFO(p_block, pptr, size + header_size, 1); p_block->mem_type = MEM_TYPE_MALLOC; EZTRACE_EVENT_PACKED_3(EZTRACE_MEMORY_REALLOC, old_size, p_block->size, (app_ptr)p_block->u_ptr); return p_block->u_ptr; } return librealloc(ptr, size); } void* calloc(size_t nmemb, size_t size) { if (!libcalloc) { void* ret = hand_made_malloc(nmemb * size); if (ret) { memset(ret, 0, nmemb * size); } return ret; } FUNCTION_ENTRY; EZTRACE_PROTECT { /* compute the number of blocks for header */ int nb_memb_header = sizeof(struct mem_block_info) / size; if (size * nb_memb_header < sizeof(struct mem_block_info)) nb_memb_header++; /* allocate buffer + header */ void* p_ptr = libcalloc(nmemb + nb_memb_header, size); struct mem_block_info *p_block = NULL; INIT_MEM_INFO(p_block, p_ptr, nmemb, size); p_block->mem_type = MEM_TYPE_MALLOC; EZTRACE_EVENT_PACKED_2(EZTRACE_MEMORY_MALLOC, p_block->size, (app_ptr)p_block->u_ptr); #if 0 /* for debugging purpose only */ uint32_t* canary = p_block->u_ptr-sizeof(uint32_t); if(*canary != MAGIC_PATTERN) { fprintf(stderr, "warning: canary = %x instead of %x\n", *canary, MAGIC_PATTERN); } #endif return p_block->u_ptr; } return libcalloc(nmemb, size); } void free(void* ptr) { if (!libfree) { libfree = dlsym(RTLD_NEXT, "free"); char* error; if ((error = dlerror()) != NULL) { fputs(error, stderr); exit(1); } } FUNCTION_ENTRY; if (!ptr) { libfree(ptr); return; } /* first, check wether we malloc'ed the buffer */ if (!CANARY_OK(ptr)) { /* we didn't malloc this buffer */ libfree(ptr); return; } /* retrieve the block information and free it */ EZTRACE_PROTECT { struct mem_block_info *p_block; USER_PTR_TO_BLOCK_INFO(ptr, p_block); if (p_block->mem_type == MEM_TYPE_MALLOC) { EZTRACE_EVENT_PACKED_2(EZTRACE_MEMORY_FREE, p_block->size, (app_ptr)p_block->u_ptr); libfree(p_block->p_ptr); } else { /* the buffer was allocated by hand_made_malloc, there's nothing to free */ } } } START_INTERCEPT_MODULE(memory) INTERCEPT2("malloc", libmalloc) INTERCEPT2("calloc", libcalloc) INTERCEPT2("realloc", librealloc) INTERCEPT2("free", libfree) END_INTERCEPT_MODULE(memory) static void __memory_init(void) __attribute__ ((constructor)); static void __memory_init(void) { malloc_protect_on = 1; DYNAMIC_INTERCEPT_ALL_MODULE(memory); #ifdef EZTRACE_AUTOSTART eztrace_start (); #endif malloc_protect_on = 0; __memory_initialized = 1; } static void __memory_conclude(void) __attribute__ ((destructor)); static void __memory_conclude(void) { __memory_initialized = 0; eztrace_stop(); } eztrace-1.1-2/src/modules/memory/memory_ev_codes.h000066400000000000000000000012511265506773700222670ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef __MEMORY_EV_CODES_H__ #define __MEMORY_EV_CODES_H__ #include "ev_codes.h" #define EZTRACE_MEMORY_EVENTS_ID SYSTEM_MODULE_ID(0x05) #define EZTRACE_MEMORY_PREFIX GENERATE_SYSTEM_MODULE_PREFIX(EZTRACE_MEMORY_EVENTS_ID) #define EZTRACE_MEMORY_MALLOC (EZTRACE_MEMORY_PREFIX | 0X0001) #define EZTRACE_MEMORY_CALLOC (EZTRACE_MEMORY_PREFIX | 0X0002) #define EZTRACE_MEMORY_REALLOC (EZTRACE_MEMORY_PREFIX | 0X0003) #define EZTRACE_MEMORY_FREE (EZTRACE_MEMORY_PREFIX | 0X0010) #endif /* __MEMORY_EV_CODES_H__ */ eztrace-1.1-2/src/modules/mpi/000077500000000000000000000000001265506773700162155ustar00rootroot00000000000000eztrace-1.1-2/src/modules/mpi/Makefile.am000066400000000000000000000121621265506773700202530ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. TLCFLAGS=$(TL_CPPFLAGS) TLLDFLAGS=$(TL_LDFLAGS) TLLIBADD=$(TL_LIB) GTGCFLAGS=$(GTG_CPPFLAGS) GTGLDFLAGS=$(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD=$(GTG_LIB) AM_CPPFLAGS = -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ -I$(top_srcdir)/src/pptrace -DMPI_MODULE_NAME=@MPI_MODULE_NAME@ \ -DMPI_EVENT_ID=@MPI_EVENT_ID@ lib_LTLIBRARIES = if USE_MPI lib_LTLIBRARIES += libeztrace-convert-@MPI_MODULE_NAME@.la \ libeztrace-@MPI_MODULE_NAME@.la \ libeztrace-autostart-@MPI_MODULE_NAME@.la AM_CPPFLAGS += -W -Wall -Wextra -DUSE_MPI AM_LDFLAGS = @MPI_LDFLAGS@ endif # USE_MPI libeztrace_convert_@MPI_MODULE_NAME@_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) libeztrace_convert_@MPI_MODULE_NAME@_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) libeztrace_convert_@MPI_MODULE_NAME@_la_LDFLAGS = --no-undefined $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_@MPI_MODULE_NAME@_la_SOURCES = eztrace_convert_mpi.c \ eztrace_convert_mpi.h\ mpi_ev_codes.h\ eztrace_convert_mpi_p2p.c\ eztrace_convert_mpi_p2p.h\ eztrace_convert_mpi_coll.c\ eztrace_convert_mpi_coll.h\ eztrace_convert_mpi_pers.c\ eztrace_convert_mpi_pers.h\ eztrace_stats_mpi.h\ eztrace_stats_mpi.c libeztrace_convert_@MPI_MODULE_NAME@_la_DEPENDENCIES = $(GTGDEPENDENCIES) mpi_function_files = mpi_funcs/mpi_allgather.c \ mpi_funcs/mpi_allgatherv.c \ mpi_funcs/mpi_allreduce.c \ mpi_funcs/mpi_alltoall.c \ mpi_funcs/mpi_alltoallv.c \ mpi_funcs/mpi_barrier.c \ mpi_funcs/mpi_bcast.c \ mpi_funcs/mpi_bsend.c \ mpi_funcs/mpi_bsend_init.c \ mpi_funcs/mpi_gather.c \ mpi_funcs/mpi_gatherv.c \ mpi_funcs/mpi_get.c \ mpi_funcs/mpi_ibsend.c \ mpi_funcs/mpi_iprobe.c \ mpi_funcs/mpi_irecv.c \ mpi_funcs/mpi_irsend.c \ mpi_funcs/mpi_isend.c \ mpi_funcs/mpi_issend.c \ mpi_funcs/mpi_probe.c \ mpi_funcs/mpi_put.c \ mpi_funcs/mpi_recv.c \ mpi_funcs/mpi_recv_init.c \ mpi_funcs/mpi_reduce.c \ mpi_funcs/mpi_reduce_scatter.c \ mpi_funcs/mpi_rsend.c \ mpi_funcs/mpi_rsend_init.c \ mpi_funcs/mpi_scan.c \ mpi_funcs/mpi_scatter.c \ mpi_funcs/mpi_scatterv.c \ mpi_funcs/mpi_send.c \ mpi_funcs/mpi_send_init.c \ mpi_funcs/mpi_sendrecv.c \ mpi_funcs/mpi_sendrecv_replace.c\ mpi_funcs/mpi_ssend.c \ mpi_funcs/mpi_ssend_init.c \ mpi_funcs/mpi_start.c \ mpi_funcs/mpi_startall.c \ mpi_funcs/mpi_test.c \ mpi_funcs/mpi_testall.c \ mpi_funcs/mpi_testany.c \ mpi_funcs/mpi_testsome.c \ mpi_funcs/mpi_wait.c \ mpi_funcs/mpi_waitall.c \ mpi_funcs/mpi_waitany.c \ mpi_funcs/mpi_waitsome.c \ mpi_funcs/mpi_ibarrier.c \ mpi_funcs/mpi_ibcast.c \ mpi_funcs/mpi_igather.c \ mpi_funcs/mpi_igatherv.c \ mpi_funcs/mpi_iscatter.c \ mpi_funcs/mpi_iscatterv.c \ mpi_funcs/mpi_iallgather.c \ mpi_funcs/mpi_iallgatherv.c \ mpi_funcs/mpi_ialltoall.c \ mpi_funcs/mpi_ialltoallv.c \ mpi_funcs/mpi_ireduce.c \ mpi_funcs/mpi_iallreduce.c \ mpi_funcs/mpi_ireduce_scatter.c \ mpi_funcs/mpi_iscan.c \ mpi_funcs/mpi_cancel.c libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) \ -DLD_PRELOAD_NAME=\"@LD_PRELOAD_NAME@\" libeztrace_@MPI_MODULE_NAME@_la_LIBADD = -lm -lpthread $(TLLIBADD) libeztrace_@MPI_MODULE_NAME@_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_@MPI_MODULE_NAME@_la_SOURCES = mpi.c mpi_fortran.c mpi_f.f90\ fortran_utils.f90 mpi_ev_codes.h mpi_eztrace.h $(mpi_function_files) libeztrace_autostart_@MPI_MODULE_NAME@_la_FCFLAGS = $(AM_FFLAGS) -Wall libeztrace_@MPI_MODULE_NAME@_la_FCFLAGS = $(AM_FFLAGS) -Wall libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) \ -DLD_PRELOAD_NAME=\"@LD_PRELOAD_NAME@\" libeztrace_autostart_@MPI_MODULE_NAME@_la_LIBADD = -lm -lpthread $(TLLIBADD) $(AM_LDFLAGS) libeztrace_autostart_@MPI_MODULE_NAME@_la_LDFLAGS = $(TLLDFLAGS) -rdynamic libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra \ -DEZTRACE_AUTOSTART libeztrace_autostart_@MPI_MODULE_NAME@_la_SOURCES = mpi.c mpi_fortran.c mpi_f.f90\ fortran_utils.f90 mpi_ev_codes.h mpi_eztrace.h $(mpi_function_files) if USE_MPI3 libeztrace_@MPI_MODULE_NAME@_la_SOURCES += mpi3_f.f90 libeztrace_autostart_@MPI_MODULE_NAME@_la_SOURCES += mpi3_f.f90 AM_CPPFLAGS += -DUSE_MPI3 endif #noinst_HEADERS = eztrace_convert_mpi.h \ # mpi_ev_codes.h eztrace-1.1-2/src/modules/mpi/Makefile.in000066400000000000000000010217721265506773700202740ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @USE_MPI_TRUE@am__append_1 = libeztrace-convert-@MPI_MODULE_NAME@.la \ @USE_MPI_TRUE@ libeztrace-@MPI_MODULE_NAME@.la \ @USE_MPI_TRUE@ libeztrace-autostart-@MPI_MODULE_NAME@.la @USE_MPI_TRUE@am__append_2 = -W -Wall -Wextra -DUSE_MPI @USE_MPI3_TRUE@am__append_3 = mpi3_f.f90 @USE_MPI3_TRUE@am__append_4 = mpi3_f.f90 @USE_MPI3_TRUE@am__append_5 = -DUSE_MPI3 subdir = src/modules/mpi ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(libdir)" LTLIBRARIES = $(lib_LTLIBRARIES) am__DEPENDENCIES_1 = am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) libeztrace_@MPI_MODULE_NAME@_la_DEPENDENCIES = $(am__DEPENDENCIES_2) am__libeztrace_@MPI_MODULE_NAME@_la_SOURCES_DIST = mpi.c mpi_fortran.c \ mpi_f.f90 fortran_utils.f90 mpi_ev_codes.h mpi_eztrace.h \ mpi_funcs/mpi_allgather.c mpi_funcs/mpi_allgatherv.c \ mpi_funcs/mpi_allreduce.c mpi_funcs/mpi_alltoall.c \ mpi_funcs/mpi_alltoallv.c mpi_funcs/mpi_barrier.c \ mpi_funcs/mpi_bcast.c mpi_funcs/mpi_bsend.c \ mpi_funcs/mpi_bsend_init.c mpi_funcs/mpi_gather.c \ mpi_funcs/mpi_gatherv.c mpi_funcs/mpi_get.c \ mpi_funcs/mpi_ibsend.c mpi_funcs/mpi_iprobe.c \ mpi_funcs/mpi_irecv.c mpi_funcs/mpi_irsend.c \ mpi_funcs/mpi_isend.c mpi_funcs/mpi_issend.c \ mpi_funcs/mpi_probe.c mpi_funcs/mpi_put.c mpi_funcs/mpi_recv.c \ mpi_funcs/mpi_recv_init.c mpi_funcs/mpi_reduce.c \ mpi_funcs/mpi_reduce_scatter.c mpi_funcs/mpi_rsend.c \ mpi_funcs/mpi_rsend_init.c mpi_funcs/mpi_scan.c \ mpi_funcs/mpi_scatter.c mpi_funcs/mpi_scatterv.c \ mpi_funcs/mpi_send.c mpi_funcs/mpi_send_init.c \ mpi_funcs/mpi_sendrecv.c mpi_funcs/mpi_sendrecv_replace.c \ mpi_funcs/mpi_ssend.c mpi_funcs/mpi_ssend_init.c \ mpi_funcs/mpi_start.c mpi_funcs/mpi_startall.c \ mpi_funcs/mpi_test.c mpi_funcs/mpi_testall.c \ mpi_funcs/mpi_testany.c mpi_funcs/mpi_testsome.c \ mpi_funcs/mpi_wait.c mpi_funcs/mpi_waitall.c \ mpi_funcs/mpi_waitany.c mpi_funcs/mpi_waitsome.c \ mpi_funcs/mpi_ibarrier.c mpi_funcs/mpi_ibcast.c \ mpi_funcs/mpi_igather.c mpi_funcs/mpi_igatherv.c \ mpi_funcs/mpi_iscatter.c mpi_funcs/mpi_iscatterv.c \ mpi_funcs/mpi_iallgather.c mpi_funcs/mpi_iallgatherv.c \ mpi_funcs/mpi_ialltoall.c mpi_funcs/mpi_ialltoallv.c \ mpi_funcs/mpi_ireduce.c mpi_funcs/mpi_iallreduce.c \ mpi_funcs/mpi_ireduce_scatter.c mpi_funcs/mpi_iscan.c \ mpi_funcs/mpi_cancel.c mpi3_f.f90 am__dirstamp = $(am__leading_dot)dirstamp am__objects_1 = \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgather.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allreduce.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoall.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_barrier.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bcast.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gather.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gatherv.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_get.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibsend.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iprobe.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irecv.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irsend.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_isend.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_issend.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_probe.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_put.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv_init.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scan.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatter.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatterv.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send_init.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_start.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_startall.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_test.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testall.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testany.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testsome.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_wait.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitall.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitany.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitsome.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibcast.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igather.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igatherv.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatter.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgather.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscan.lo \ mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_cancel.lo @USE_MPI3_TRUE@am__objects_2 = \ @USE_MPI3_TRUE@ libeztrace_@MPI_MODULE_NAME@_la-mpi3_f.lo am_libeztrace_@MPI_MODULE_NAME@_la_OBJECTS = \ libeztrace_@MPI_MODULE_NAME@_la-mpi.lo \ libeztrace_@MPI_MODULE_NAME@_la-mpi_fortran.lo \ libeztrace_@MPI_MODULE_NAME@_la-mpi_f.lo \ libeztrace_@MPI_MODULE_NAME@_la-fortran_utils.lo \ $(am__objects_1) $(am__objects_2) libeztrace_@MPI_MODULE_NAME@_la_OBJECTS = \ $(am_libeztrace_@MPI_MODULE_NAME@_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libeztrace_@MPI_MODULE_NAME@_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=FC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(FCLD) \ $(libeztrace_@MPI_MODULE_NAME@_la_FCFLAGS) $(FCFLAGS) \ $(libeztrace_@MPI_MODULE_NAME@_la_LDFLAGS) $(LDFLAGS) -o $@ @USE_MPI_TRUE@am_libeztrace_@MPI_MODULE_NAME@_la_rpath = -rpath \ @USE_MPI_TRUE@ $(libdir) libeztrace_autostart_@MPI_MODULE_NAME@_la_DEPENDENCIES = \ $(am__DEPENDENCIES_2) $(am__DEPENDENCIES_1) am__libeztrace_autostart_@MPI_MODULE_NAME@_la_SOURCES_DIST = mpi.c \ mpi_fortran.c mpi_f.f90 fortran_utils.f90 mpi_ev_codes.h \ mpi_eztrace.h mpi_funcs/mpi_allgather.c \ mpi_funcs/mpi_allgatherv.c mpi_funcs/mpi_allreduce.c \ mpi_funcs/mpi_alltoall.c mpi_funcs/mpi_alltoallv.c \ mpi_funcs/mpi_barrier.c mpi_funcs/mpi_bcast.c \ mpi_funcs/mpi_bsend.c mpi_funcs/mpi_bsend_init.c \ mpi_funcs/mpi_gather.c mpi_funcs/mpi_gatherv.c \ mpi_funcs/mpi_get.c mpi_funcs/mpi_ibsend.c \ mpi_funcs/mpi_iprobe.c mpi_funcs/mpi_irecv.c \ mpi_funcs/mpi_irsend.c mpi_funcs/mpi_isend.c \ mpi_funcs/mpi_issend.c mpi_funcs/mpi_probe.c \ mpi_funcs/mpi_put.c mpi_funcs/mpi_recv.c \ mpi_funcs/mpi_recv_init.c mpi_funcs/mpi_reduce.c \ mpi_funcs/mpi_reduce_scatter.c mpi_funcs/mpi_rsend.c \ mpi_funcs/mpi_rsend_init.c mpi_funcs/mpi_scan.c \ mpi_funcs/mpi_scatter.c mpi_funcs/mpi_scatterv.c \ mpi_funcs/mpi_send.c mpi_funcs/mpi_send_init.c \ mpi_funcs/mpi_sendrecv.c mpi_funcs/mpi_sendrecv_replace.c \ mpi_funcs/mpi_ssend.c mpi_funcs/mpi_ssend_init.c \ mpi_funcs/mpi_start.c mpi_funcs/mpi_startall.c \ mpi_funcs/mpi_test.c mpi_funcs/mpi_testall.c \ mpi_funcs/mpi_testany.c mpi_funcs/mpi_testsome.c \ mpi_funcs/mpi_wait.c mpi_funcs/mpi_waitall.c \ mpi_funcs/mpi_waitany.c mpi_funcs/mpi_waitsome.c \ mpi_funcs/mpi_ibarrier.c mpi_funcs/mpi_ibcast.c \ mpi_funcs/mpi_igather.c mpi_funcs/mpi_igatherv.c \ mpi_funcs/mpi_iscatter.c mpi_funcs/mpi_iscatterv.c \ mpi_funcs/mpi_iallgather.c mpi_funcs/mpi_iallgatherv.c \ mpi_funcs/mpi_ialltoall.c mpi_funcs/mpi_ialltoallv.c \ mpi_funcs/mpi_ireduce.c mpi_funcs/mpi_iallreduce.c \ mpi_funcs/mpi_ireduce_scatter.c mpi_funcs/mpi_iscan.c \ mpi_funcs/mpi_cancel.c mpi3_f.f90 am__objects_3 = mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgather.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allreduce.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoall.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_barrier.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bcast.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gather.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gatherv.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_get.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibsend.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iprobe.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irecv.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irsend.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_isend.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_issend.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_probe.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_put.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv_init.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scan.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatter.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatterv.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send_init.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_start.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_startall.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_test.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testall.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testany.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testsome.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_wait.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitall.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitany.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitsome.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibcast.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igather.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igatherv.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatter.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgather.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscan.lo \ mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_cancel.lo @USE_MPI3_TRUE@am__objects_4 = libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi3_f.lo am_libeztrace_autostart_@MPI_MODULE_NAME@_la_OBJECTS = \ libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi.lo \ libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_fortran.lo \ libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_f.lo \ libeztrace_autostart_@MPI_MODULE_NAME@_la-fortran_utils.lo \ $(am__objects_3) $(am__objects_4) libeztrace_autostart_@MPI_MODULE_NAME@_la_OBJECTS = \ $(am_libeztrace_autostart_@MPI_MODULE_NAME@_la_OBJECTS) libeztrace_autostart_@MPI_MODULE_NAME@_la_LINK = $(LIBTOOL) $(AM_V_lt) \ --tag=FC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link \ $(FCLD) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_FCFLAGS) \ $(FCFLAGS) \ $(libeztrace_autostart_@MPI_MODULE_NAME@_la_LDFLAGS) \ $(LDFLAGS) -o $@ @USE_MPI_TRUE@am_libeztrace_autostart_@MPI_MODULE_NAME@_la_rpath = \ @USE_MPI_TRUE@ -rpath $(libdir) am_libeztrace_convert_@MPI_MODULE_NAME@_la_OBJECTS = libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi.lo \ libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_p2p.lo \ libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_coll.lo \ libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_pers.lo \ libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_stats_mpi.lo libeztrace_convert_@MPI_MODULE_NAME@_la_OBJECTS = \ $(am_libeztrace_convert_@MPI_MODULE_NAME@_la_OBJECTS) libeztrace_convert_@MPI_MODULE_NAME@_la_LINK = $(LIBTOOL) $(AM_V_lt) \ --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link \ $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(libeztrace_convert_@MPI_MODULE_NAME@_la_LDFLAGS) $(LDFLAGS) \ -o $@ @USE_MPI_TRUE@am_libeztrace_convert_@MPI_MODULE_NAME@_la_rpath = \ @USE_MPI_TRUE@ -rpath $(libdir) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = FCCOMPILE = $(FC) $(AM_FCFLAGS) $(FCFLAGS) LTFCCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=FC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(FC) $(AM_FCFLAGS) $(FCFLAGS) AM_V_FC = $(am__v_FC_@AM_V@) am__v_FC_ = $(am__v_FC_@AM_DEFAULT_V@) am__v_FC_0 = @echo " FC " $@; am__v_FC_1 = FCLD = $(FC) FCLINK = $(LIBTOOL) $(AM_V_lt) --tag=FC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(FCLD) $(AM_FCFLAGS) $(FCFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_FCLD = $(am__v_FCLD_@AM_V@) am__v_FCLD_ = $(am__v_FCLD_@AM_DEFAULT_V@) am__v_FCLD_0 = @echo " FCLD " $@; am__v_FCLD_1 = SOURCES = $(libeztrace_@MPI_MODULE_NAME@_la_SOURCES) \ $(libeztrace_autostart_@MPI_MODULE_NAME@_la_SOURCES) \ $(libeztrace_convert_@MPI_MODULE_NAME@_la_SOURCES) DIST_SOURCES = $(am__libeztrace_@MPI_MODULE_NAME@_la_SOURCES_DIST) \ $(am__libeztrace_autostart_@MPI_MODULE_NAME@_la_SOURCES_DIST) \ $(libeztrace_convert_@MPI_MODULE_NAME@_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ TLCFLAGS = $(TL_CPPFLAGS) TLLDFLAGS = $(TL_LDFLAGS) TLLIBADD = $(TL_LIB) GTGCFLAGS = $(GTG_CPPFLAGS) GTGLDFLAGS = $(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD = $(GTG_LIB) AM_CPPFLAGS = -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ -I$(top_srcdir)/src/pptrace \ -DMPI_MODULE_NAME=@MPI_MODULE_NAME@ \ -DMPI_EVENT_ID=@MPI_EVENT_ID@ $(am__append_2) $(am__append_5) lib_LTLIBRARIES = $(am__append_1) @USE_MPI_TRUE@AM_LDFLAGS = @MPI_LDFLAGS@ libeztrace_convert_@MPI_MODULE_NAME@_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) libeztrace_convert_@MPI_MODULE_NAME@_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) libeztrace_convert_@MPI_MODULE_NAME@_la_LDFLAGS = --no-undefined $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_@MPI_MODULE_NAME@_la_SOURCES = eztrace_convert_mpi.c \ eztrace_convert_mpi.h\ mpi_ev_codes.h\ eztrace_convert_mpi_p2p.c\ eztrace_convert_mpi_p2p.h\ eztrace_convert_mpi_coll.c\ eztrace_convert_mpi_coll.h\ eztrace_convert_mpi_pers.c\ eztrace_convert_mpi_pers.h\ eztrace_stats_mpi.h\ eztrace_stats_mpi.c libeztrace_convert_@MPI_MODULE_NAME@_la_DEPENDENCIES = $(GTGDEPENDENCIES) mpi_function_files = mpi_funcs/mpi_allgather.c \ mpi_funcs/mpi_allgatherv.c \ mpi_funcs/mpi_allreduce.c \ mpi_funcs/mpi_alltoall.c \ mpi_funcs/mpi_alltoallv.c \ mpi_funcs/mpi_barrier.c \ mpi_funcs/mpi_bcast.c \ mpi_funcs/mpi_bsend.c \ mpi_funcs/mpi_bsend_init.c \ mpi_funcs/mpi_gather.c \ mpi_funcs/mpi_gatherv.c \ mpi_funcs/mpi_get.c \ mpi_funcs/mpi_ibsend.c \ mpi_funcs/mpi_iprobe.c \ mpi_funcs/mpi_irecv.c \ mpi_funcs/mpi_irsend.c \ mpi_funcs/mpi_isend.c \ mpi_funcs/mpi_issend.c \ mpi_funcs/mpi_probe.c \ mpi_funcs/mpi_put.c \ mpi_funcs/mpi_recv.c \ mpi_funcs/mpi_recv_init.c \ mpi_funcs/mpi_reduce.c \ mpi_funcs/mpi_reduce_scatter.c \ mpi_funcs/mpi_rsend.c \ mpi_funcs/mpi_rsend_init.c \ mpi_funcs/mpi_scan.c \ mpi_funcs/mpi_scatter.c \ mpi_funcs/mpi_scatterv.c \ mpi_funcs/mpi_send.c \ mpi_funcs/mpi_send_init.c \ mpi_funcs/mpi_sendrecv.c \ mpi_funcs/mpi_sendrecv_replace.c\ mpi_funcs/mpi_ssend.c \ mpi_funcs/mpi_ssend_init.c \ mpi_funcs/mpi_start.c \ mpi_funcs/mpi_startall.c \ mpi_funcs/mpi_test.c \ mpi_funcs/mpi_testall.c \ mpi_funcs/mpi_testany.c \ mpi_funcs/mpi_testsome.c \ mpi_funcs/mpi_wait.c \ mpi_funcs/mpi_waitall.c \ mpi_funcs/mpi_waitany.c \ mpi_funcs/mpi_waitsome.c \ mpi_funcs/mpi_ibarrier.c \ mpi_funcs/mpi_ibcast.c \ mpi_funcs/mpi_igather.c \ mpi_funcs/mpi_igatherv.c \ mpi_funcs/mpi_iscatter.c \ mpi_funcs/mpi_iscatterv.c \ mpi_funcs/mpi_iallgather.c \ mpi_funcs/mpi_iallgatherv.c \ mpi_funcs/mpi_ialltoall.c \ mpi_funcs/mpi_ialltoallv.c \ mpi_funcs/mpi_ireduce.c \ mpi_funcs/mpi_iallreduce.c \ mpi_funcs/mpi_ireduce_scatter.c \ mpi_funcs/mpi_iscan.c \ mpi_funcs/mpi_cancel.c libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) \ -DLD_PRELOAD_NAME=\"@LD_PRELOAD_NAME@\" libeztrace_@MPI_MODULE_NAME@_la_LIBADD = -lm -lpthread $(TLLIBADD) libeztrace_@MPI_MODULE_NAME@_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_@MPI_MODULE_NAME@_la_SOURCES = mpi.c mpi_fortran.c \ mpi_f.f90 fortran_utils.f90 mpi_ev_codes.h mpi_eztrace.h \ $(mpi_function_files) $(am__append_3) libeztrace_autostart_@MPI_MODULE_NAME@_la_FCFLAGS = $(AM_FFLAGS) -Wall libeztrace_@MPI_MODULE_NAME@_la_FCFLAGS = $(AM_FFLAGS) -Wall libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) \ -DLD_PRELOAD_NAME=\"@LD_PRELOAD_NAME@\" libeztrace_autostart_@MPI_MODULE_NAME@_la_LIBADD = -lm -lpthread $(TLLIBADD) $(AM_LDFLAGS) libeztrace_autostart_@MPI_MODULE_NAME@_la_LDFLAGS = $(TLLDFLAGS) -rdynamic libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra \ -DEZTRACE_AUTOSTART libeztrace_autostart_@MPI_MODULE_NAME@_la_SOURCES = mpi.c \ mpi_fortran.c mpi_f.f90 fortran_utils.f90 mpi_ev_codes.h \ mpi_eztrace.h $(mpi_function_files) $(am__append_4) all: all-am .SUFFIXES: .SUFFIXES: .c .f90 .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/modules/mpi/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu src/modules/mpi/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ } uninstall-libLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ done clean-libLTLIBRARIES: -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) @list='$(lib_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } mpi_funcs/$(am__dirstamp): @$(MKDIR_P) mpi_funcs @: > mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp): @$(MKDIR_P) mpi_funcs/$(DEPDIR) @: > mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgather.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allreduce.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoall.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_barrier.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bcast.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gather.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gatherv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_get.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibsend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iprobe.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irecv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irsend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_isend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_issend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_probe.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_put.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv_init.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scan.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatter.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatterv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send_init.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_start.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_startall.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_test.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testall.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testany.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testsome.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_wait.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitall.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitany.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitsome.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibcast.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igather.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igatherv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatter.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgather.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscan.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_cancel.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) libeztrace-@MPI_MODULE_NAME@.la: $(libeztrace_@MPI_MODULE_NAME@_la_OBJECTS) $(libeztrace_@MPI_MODULE_NAME@_la_DEPENDENCIES) $(EXTRA_libeztrace_@MPI_MODULE_NAME@_la_DEPENDENCIES) $(AM_V_FCLD)$(libeztrace_@MPI_MODULE_NAME@_la_LINK) $(am_libeztrace_@MPI_MODULE_NAME@_la_rpath) $(libeztrace_@MPI_MODULE_NAME@_la_OBJECTS) $(libeztrace_@MPI_MODULE_NAME@_la_LIBADD) $(LIBS) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgather.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allreduce.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoall.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_barrier.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bcast.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gather.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gatherv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_get.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibsend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iprobe.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irecv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irsend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_isend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_issend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_probe.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_put.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv_init.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scan.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatter.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatterv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send_init.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_start.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_startall.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_test.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testall.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testany.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testsome.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_wait.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitall.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitany.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitsome.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibcast.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igather.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igatherv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatter.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgather.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscan.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_cancel.lo: \ mpi_funcs/$(am__dirstamp) mpi_funcs/$(DEPDIR)/$(am__dirstamp) libeztrace-autostart-@MPI_MODULE_NAME@.la: $(libeztrace_autostart_@MPI_MODULE_NAME@_la_OBJECTS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_DEPENDENCIES) $(EXTRA_libeztrace_autostart_@MPI_MODULE_NAME@_la_DEPENDENCIES) $(AM_V_FCLD)$(libeztrace_autostart_@MPI_MODULE_NAME@_la_LINK) $(am_libeztrace_autostart_@MPI_MODULE_NAME@_la_rpath) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_OBJECTS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_LIBADD) $(LIBS) libeztrace-convert-@MPI_MODULE_NAME@.la: $(libeztrace_convert_@MPI_MODULE_NAME@_la_OBJECTS) $(libeztrace_convert_@MPI_MODULE_NAME@_la_DEPENDENCIES) $(EXTRA_libeztrace_convert_@MPI_MODULE_NAME@_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_convert_@MPI_MODULE_NAME@_la_LINK) $(am_libeztrace_convert_@MPI_MODULE_NAME@_la_rpath) $(libeztrace_convert_@MPI_MODULE_NAME@_la_OBJECTS) $(libeztrace_convert_@MPI_MODULE_NAME@_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) -rm -f mpi_funcs/*.$(OBJEXT) -rm -f mpi_funcs/*.lo distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_fortran.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_fortran.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_coll.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_p2p.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_pers.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_stats_mpi.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgather.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgatherv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_allreduce.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoall.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoallv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_barrier.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_bcast.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend_init.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_cancel.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_gather.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_gatherv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_get.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgather.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgatherv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallreduce.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoall.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoallv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibarrier.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibcast.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibsend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_igather.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_igatherv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iprobe.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_irecv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_irsend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscan.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatter.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatterv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_isend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_issend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_probe.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_put.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv_init.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend_init.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_scan.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatter.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatterv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_send.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_send_init.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend_init.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_start.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_startall.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_test.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_testall.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_testany.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_testsome.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_wait.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitall.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitany.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitsome.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgather.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgatherv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allreduce.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoall.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoallv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_barrier.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bcast.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend_init.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_cancel.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gather.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gatherv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_get.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgather.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgatherv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallreduce.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoall.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoallv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibarrier.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibcast.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibsend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igather.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igatherv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iprobe.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irecv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irsend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscan.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatter.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatterv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_isend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_issend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_probe.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_put.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv_init.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend_init.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scan.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatter.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatterv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send_init.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend_init.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_start.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_startall.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_test.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testall.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testany.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testsome.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_wait.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitall.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitany.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitsome.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< libeztrace_@MPI_MODULE_NAME@_la-mpi.lo: mpi.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_@MPI_MODULE_NAME@_la-mpi.lo -MD -MP -MF $(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi.Tpo -c -o libeztrace_@MPI_MODULE_NAME@_la-mpi.lo `test -f 'mpi.c' || echo '$(srcdir)/'`mpi.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi.Tpo $(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi.c' object='libeztrace_@MPI_MODULE_NAME@_la-mpi.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_@MPI_MODULE_NAME@_la-mpi.lo `test -f 'mpi.c' || echo '$(srcdir)/'`mpi.c libeztrace_@MPI_MODULE_NAME@_la-mpi_fortran.lo: mpi_fortran.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_@MPI_MODULE_NAME@_la-mpi_fortran.lo -MD -MP -MF $(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_fortran.Tpo -c -o libeztrace_@MPI_MODULE_NAME@_la-mpi_fortran.lo `test -f 'mpi_fortran.c' || echo '$(srcdir)/'`mpi_fortran.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_fortran.Tpo $(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_fortran.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_fortran.c' object='libeztrace_@MPI_MODULE_NAME@_la-mpi_fortran.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_@MPI_MODULE_NAME@_la-mpi_fortran.lo `test -f 'mpi_fortran.c' || echo '$(srcdir)/'`mpi_fortran.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgather.lo: mpi_funcs/mpi_allgather.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgather.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgather.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgather.lo `test -f 'mpi_funcs/mpi_allgather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_allgather.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgather.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgather.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_allgather.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgather.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgather.lo `test -f 'mpi_funcs/mpi_allgather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_allgather.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo: mpi_funcs/mpi_allgatherv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgatherv.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo `test -f 'mpi_funcs/mpi_allgatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_allgatherv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgatherv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgatherv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_allgatherv.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo `test -f 'mpi_funcs/mpi_allgatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_allgatherv.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allreduce.lo: mpi_funcs/mpi_allreduce.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allreduce.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_allreduce.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allreduce.lo `test -f 'mpi_funcs/mpi_allreduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_allreduce.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_allreduce.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_allreduce.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_allreduce.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allreduce.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_allreduce.lo `test -f 'mpi_funcs/mpi_allreduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_allreduce.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoall.lo: mpi_funcs/mpi_alltoall.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoall.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoall.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoall.lo `test -f 'mpi_funcs/mpi_alltoall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_alltoall.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoall.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoall.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_alltoall.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoall.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoall.lo `test -f 'mpi_funcs/mpi_alltoall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_alltoall.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo: mpi_funcs/mpi_alltoallv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoallv.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo `test -f 'mpi_funcs/mpi_alltoallv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_alltoallv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoallv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoallv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_alltoallv.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo `test -f 'mpi_funcs/mpi_alltoallv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_alltoallv.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_barrier.lo: mpi_funcs/mpi_barrier.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_barrier.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_barrier.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_barrier.lo `test -f 'mpi_funcs/mpi_barrier.c' || echo '$(srcdir)/'`mpi_funcs/mpi_barrier.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_barrier.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_barrier.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_barrier.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_barrier.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_barrier.lo `test -f 'mpi_funcs/mpi_barrier.c' || echo '$(srcdir)/'`mpi_funcs/mpi_barrier.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bcast.lo: mpi_funcs/mpi_bcast.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bcast.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_bcast.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bcast.lo `test -f 'mpi_funcs/mpi_bcast.c' || echo '$(srcdir)/'`mpi_funcs/mpi_bcast.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_bcast.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_bcast.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_bcast.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bcast.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bcast.lo `test -f 'mpi_funcs/mpi_bcast.c' || echo '$(srcdir)/'`mpi_funcs/mpi_bcast.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend.lo: mpi_funcs/mpi_bsend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend.lo `test -f 'mpi_funcs/mpi_bsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_bsend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_bsend.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend.lo `test -f 'mpi_funcs/mpi_bsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_bsend.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo: mpi_funcs/mpi_bsend_init.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend_init.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo `test -f 'mpi_funcs/mpi_bsend_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_bsend_init.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend_init.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend_init.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_bsend_init.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo `test -f 'mpi_funcs/mpi_bsend_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_bsend_init.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gather.lo: mpi_funcs/mpi_gather.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gather.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_gather.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gather.lo `test -f 'mpi_funcs/mpi_gather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_gather.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_gather.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_gather.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_gather.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gather.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gather.lo `test -f 'mpi_funcs/mpi_gather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_gather.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gatherv.lo: mpi_funcs/mpi_gatherv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gatherv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_gatherv.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gatherv.lo `test -f 'mpi_funcs/mpi_gatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_gatherv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_gatherv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_gatherv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_gatherv.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gatherv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_gatherv.lo `test -f 'mpi_funcs/mpi_gatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_gatherv.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_get.lo: mpi_funcs/mpi_get.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_get.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_get.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_get.lo `test -f 'mpi_funcs/mpi_get.c' || echo '$(srcdir)/'`mpi_funcs/mpi_get.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_get.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_get.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_get.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_get.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_get.lo `test -f 'mpi_funcs/mpi_get.c' || echo '$(srcdir)/'`mpi_funcs/mpi_get.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibsend.lo: mpi_funcs/mpi_ibsend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibsend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibsend.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibsend.lo `test -f 'mpi_funcs/mpi_ibsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ibsend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibsend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibsend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ibsend.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibsend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibsend.lo `test -f 'mpi_funcs/mpi_ibsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ibsend.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iprobe.lo: mpi_funcs/mpi_iprobe.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iprobe.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iprobe.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iprobe.lo `test -f 'mpi_funcs/mpi_iprobe.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iprobe.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iprobe.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iprobe.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iprobe.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iprobe.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iprobe.lo `test -f 'mpi_funcs/mpi_iprobe.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iprobe.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irecv.lo: mpi_funcs/mpi_irecv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irecv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_irecv.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irecv.lo `test -f 'mpi_funcs/mpi_irecv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_irecv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_irecv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_irecv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_irecv.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irecv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irecv.lo `test -f 'mpi_funcs/mpi_irecv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_irecv.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irsend.lo: mpi_funcs/mpi_irsend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irsend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_irsend.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irsend.lo `test -f 'mpi_funcs/mpi_irsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_irsend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_irsend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_irsend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_irsend.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irsend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_irsend.lo `test -f 'mpi_funcs/mpi_irsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_irsend.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_isend.lo: mpi_funcs/mpi_isend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_isend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_isend.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_isend.lo `test -f 'mpi_funcs/mpi_isend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_isend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_isend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_isend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_isend.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_isend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_isend.lo `test -f 'mpi_funcs/mpi_isend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_isend.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_issend.lo: mpi_funcs/mpi_issend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_issend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_issend.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_issend.lo `test -f 'mpi_funcs/mpi_issend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_issend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_issend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_issend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_issend.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_issend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_issend.lo `test -f 'mpi_funcs/mpi_issend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_issend.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_probe.lo: mpi_funcs/mpi_probe.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_probe.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_probe.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_probe.lo `test -f 'mpi_funcs/mpi_probe.c' || echo '$(srcdir)/'`mpi_funcs/mpi_probe.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_probe.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_probe.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_probe.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_probe.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_probe.lo `test -f 'mpi_funcs/mpi_probe.c' || echo '$(srcdir)/'`mpi_funcs/mpi_probe.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_put.lo: mpi_funcs/mpi_put.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_put.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_put.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_put.lo `test -f 'mpi_funcs/mpi_put.c' || echo '$(srcdir)/'`mpi_funcs/mpi_put.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_put.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_put.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_put.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_put.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_put.lo `test -f 'mpi_funcs/mpi_put.c' || echo '$(srcdir)/'`mpi_funcs/mpi_put.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv.lo: mpi_funcs/mpi_recv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv.lo `test -f 'mpi_funcs/mpi_recv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_recv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_recv.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv.lo `test -f 'mpi_funcs/mpi_recv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_recv.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv_init.lo: mpi_funcs/mpi_recv_init.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv_init.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv_init.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv_init.lo `test -f 'mpi_funcs/mpi_recv_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_recv_init.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv_init.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv_init.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_recv_init.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv_init.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_recv_init.lo `test -f 'mpi_funcs/mpi_recv_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_recv_init.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce.lo: mpi_funcs/mpi_reduce.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce.lo `test -f 'mpi_funcs/mpi_reduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_reduce.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_reduce.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce.lo `test -f 'mpi_funcs/mpi_reduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_reduce.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo: mpi_funcs/mpi_reduce_scatter.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo `test -f 'mpi_funcs/mpi_reduce_scatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_reduce_scatter.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_reduce_scatter.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo `test -f 'mpi_funcs/mpi_reduce_scatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_reduce_scatter.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend.lo: mpi_funcs/mpi_rsend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend.lo `test -f 'mpi_funcs/mpi_rsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_rsend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_rsend.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend.lo `test -f 'mpi_funcs/mpi_rsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_rsend.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo: mpi_funcs/mpi_rsend_init.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend_init.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo `test -f 'mpi_funcs/mpi_rsend_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_rsend_init.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend_init.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend_init.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_rsend_init.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo `test -f 'mpi_funcs/mpi_rsend_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_rsend_init.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scan.lo: mpi_funcs/mpi_scan.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scan.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_scan.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scan.lo `test -f 'mpi_funcs/mpi_scan.c' || echo '$(srcdir)/'`mpi_funcs/mpi_scan.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_scan.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_scan.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_scan.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scan.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scan.lo `test -f 'mpi_funcs/mpi_scan.c' || echo '$(srcdir)/'`mpi_funcs/mpi_scan.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatter.lo: mpi_funcs/mpi_scatter.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatter.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatter.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatter.lo `test -f 'mpi_funcs/mpi_scatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_scatter.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatter.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatter.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_scatter.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatter.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatter.lo `test -f 'mpi_funcs/mpi_scatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_scatter.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatterv.lo: mpi_funcs/mpi_scatterv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatterv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatterv.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatterv.lo `test -f 'mpi_funcs/mpi_scatterv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_scatterv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatterv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatterv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_scatterv.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatterv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_scatterv.lo `test -f 'mpi_funcs/mpi_scatterv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_scatterv.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send.lo: mpi_funcs/mpi_send.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_send.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send.lo `test -f 'mpi_funcs/mpi_send.c' || echo '$(srcdir)/'`mpi_funcs/mpi_send.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_send.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_send.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_send.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send.lo `test -f 'mpi_funcs/mpi_send.c' || echo '$(srcdir)/'`mpi_funcs/mpi_send.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send_init.lo: mpi_funcs/mpi_send_init.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send_init.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_send_init.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send_init.lo `test -f 'mpi_funcs/mpi_send_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_send_init.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_send_init.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_send_init.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_send_init.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send_init.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_send_init.lo `test -f 'mpi_funcs/mpi_send_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_send_init.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo: mpi_funcs/mpi_sendrecv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo `test -f 'mpi_funcs/mpi_sendrecv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_sendrecv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_sendrecv.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo `test -f 'mpi_funcs/mpi_sendrecv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_sendrecv.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo: mpi_funcs/mpi_sendrecv_replace.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo `test -f 'mpi_funcs/mpi_sendrecv_replace.c' || echo '$(srcdir)/'`mpi_funcs/mpi_sendrecv_replace.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_sendrecv_replace.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo `test -f 'mpi_funcs/mpi_sendrecv_replace.c' || echo '$(srcdir)/'`mpi_funcs/mpi_sendrecv_replace.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend.lo: mpi_funcs/mpi_ssend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend.lo `test -f 'mpi_funcs/mpi_ssend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ssend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ssend.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend.lo `test -f 'mpi_funcs/mpi_ssend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ssend.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo: mpi_funcs/mpi_ssend_init.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend_init.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo `test -f 'mpi_funcs/mpi_ssend_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ssend_init.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend_init.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend_init.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ssend_init.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo `test -f 'mpi_funcs/mpi_ssend_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ssend_init.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_start.lo: mpi_funcs/mpi_start.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_start.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_start.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_start.lo `test -f 'mpi_funcs/mpi_start.c' || echo '$(srcdir)/'`mpi_funcs/mpi_start.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_start.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_start.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_start.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_start.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_start.lo `test -f 'mpi_funcs/mpi_start.c' || echo '$(srcdir)/'`mpi_funcs/mpi_start.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_startall.lo: mpi_funcs/mpi_startall.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_startall.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_startall.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_startall.lo `test -f 'mpi_funcs/mpi_startall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_startall.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_startall.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_startall.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_startall.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_startall.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_startall.lo `test -f 'mpi_funcs/mpi_startall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_startall.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_test.lo: mpi_funcs/mpi_test.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_test.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_test.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_test.lo `test -f 'mpi_funcs/mpi_test.c' || echo '$(srcdir)/'`mpi_funcs/mpi_test.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_test.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_test.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_test.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_test.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_test.lo `test -f 'mpi_funcs/mpi_test.c' || echo '$(srcdir)/'`mpi_funcs/mpi_test.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testall.lo: mpi_funcs/mpi_testall.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testall.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_testall.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testall.lo `test -f 'mpi_funcs/mpi_testall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_testall.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_testall.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_testall.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_testall.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testall.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testall.lo `test -f 'mpi_funcs/mpi_testall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_testall.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testany.lo: mpi_funcs/mpi_testany.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testany.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_testany.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testany.lo `test -f 'mpi_funcs/mpi_testany.c' || echo '$(srcdir)/'`mpi_funcs/mpi_testany.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_testany.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_testany.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_testany.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testany.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testany.lo `test -f 'mpi_funcs/mpi_testany.c' || echo '$(srcdir)/'`mpi_funcs/mpi_testany.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testsome.lo: mpi_funcs/mpi_testsome.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testsome.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_testsome.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testsome.lo `test -f 'mpi_funcs/mpi_testsome.c' || echo '$(srcdir)/'`mpi_funcs/mpi_testsome.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_testsome.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_testsome.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_testsome.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testsome.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_testsome.lo `test -f 'mpi_funcs/mpi_testsome.c' || echo '$(srcdir)/'`mpi_funcs/mpi_testsome.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_wait.lo: mpi_funcs/mpi_wait.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_wait.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_wait.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_wait.lo `test -f 'mpi_funcs/mpi_wait.c' || echo '$(srcdir)/'`mpi_funcs/mpi_wait.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_wait.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_wait.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_wait.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_wait.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_wait.lo `test -f 'mpi_funcs/mpi_wait.c' || echo '$(srcdir)/'`mpi_funcs/mpi_wait.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitall.lo: mpi_funcs/mpi_waitall.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitall.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitall.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitall.lo `test -f 'mpi_funcs/mpi_waitall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_waitall.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitall.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitall.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_waitall.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitall.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitall.lo `test -f 'mpi_funcs/mpi_waitall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_waitall.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitany.lo: mpi_funcs/mpi_waitany.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitany.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitany.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitany.lo `test -f 'mpi_funcs/mpi_waitany.c' || echo '$(srcdir)/'`mpi_funcs/mpi_waitany.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitany.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitany.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_waitany.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitany.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitany.lo `test -f 'mpi_funcs/mpi_waitany.c' || echo '$(srcdir)/'`mpi_funcs/mpi_waitany.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitsome.lo: mpi_funcs/mpi_waitsome.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitsome.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitsome.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitsome.lo `test -f 'mpi_funcs/mpi_waitsome.c' || echo '$(srcdir)/'`mpi_funcs/mpi_waitsome.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitsome.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitsome.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_waitsome.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitsome.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_waitsome.lo `test -f 'mpi_funcs/mpi_waitsome.c' || echo '$(srcdir)/'`mpi_funcs/mpi_waitsome.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo: mpi_funcs/mpi_ibarrier.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibarrier.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo `test -f 'mpi_funcs/mpi_ibarrier.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ibarrier.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibarrier.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibarrier.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ibarrier.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo `test -f 'mpi_funcs/mpi_ibarrier.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ibarrier.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibcast.lo: mpi_funcs/mpi_ibcast.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibcast.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibcast.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibcast.lo `test -f 'mpi_funcs/mpi_ibcast.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ibcast.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibcast.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibcast.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ibcast.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibcast.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ibcast.lo `test -f 'mpi_funcs/mpi_ibcast.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ibcast.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igather.lo: mpi_funcs/mpi_igather.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igather.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_igather.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igather.lo `test -f 'mpi_funcs/mpi_igather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_igather.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_igather.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_igather.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_igather.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igather.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igather.lo `test -f 'mpi_funcs/mpi_igather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_igather.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igatherv.lo: mpi_funcs/mpi_igatherv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igatherv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_igatherv.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igatherv.lo `test -f 'mpi_funcs/mpi_igatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_igatherv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_igatherv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_igatherv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_igatherv.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igatherv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_igatherv.lo `test -f 'mpi_funcs/mpi_igatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_igatherv.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatter.lo: mpi_funcs/mpi_iscatter.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatter.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatter.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatter.lo `test -f 'mpi_funcs/mpi_iscatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iscatter.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatter.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatter.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iscatter.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatter.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatter.lo `test -f 'mpi_funcs/mpi_iscatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iscatter.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo: mpi_funcs/mpi_iscatterv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatterv.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo `test -f 'mpi_funcs/mpi_iscatterv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iscatterv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatterv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatterv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iscatterv.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo `test -f 'mpi_funcs/mpi_iscatterv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iscatterv.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgather.lo: mpi_funcs/mpi_iallgather.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgather.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgather.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgather.lo `test -f 'mpi_funcs/mpi_iallgather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iallgather.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgather.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgather.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iallgather.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgather.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgather.lo `test -f 'mpi_funcs/mpi_iallgather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iallgather.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo: mpi_funcs/mpi_iallgatherv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgatherv.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo `test -f 'mpi_funcs/mpi_iallgatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iallgatherv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgatherv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgatherv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iallgatherv.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo `test -f 'mpi_funcs/mpi_iallgatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iallgatherv.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo: mpi_funcs/mpi_ialltoall.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoall.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo `test -f 'mpi_funcs/mpi_ialltoall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ialltoall.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoall.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoall.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ialltoall.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo `test -f 'mpi_funcs/mpi_ialltoall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ialltoall.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo: mpi_funcs/mpi_ialltoallv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoallv.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo `test -f 'mpi_funcs/mpi_ialltoallv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ialltoallv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoallv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoallv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ialltoallv.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo `test -f 'mpi_funcs/mpi_ialltoallv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ialltoallv.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce.lo: mpi_funcs/mpi_ireduce.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce.lo `test -f 'mpi_funcs/mpi_ireduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ireduce.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ireduce.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce.lo `test -f 'mpi_funcs/mpi_ireduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ireduce.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo: mpi_funcs/mpi_iallreduce.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallreduce.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo `test -f 'mpi_funcs/mpi_iallreduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iallreduce.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallreduce.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallreduce.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iallreduce.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo `test -f 'mpi_funcs/mpi_iallreduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iallreduce.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo: mpi_funcs/mpi_ireduce_scatter.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo `test -f 'mpi_funcs/mpi_ireduce_scatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ireduce_scatter.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ireduce_scatter.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo `test -f 'mpi_funcs/mpi_ireduce_scatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ireduce_scatter.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscan.lo: mpi_funcs/mpi_iscan.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscan.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscan.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscan.lo `test -f 'mpi_funcs/mpi_iscan.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iscan.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscan.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscan.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iscan.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscan.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_iscan.lo `test -f 'mpi_funcs/mpi_iscan.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iscan.c mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_cancel.lo: mpi_funcs/mpi_cancel.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_cancel.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_cancel.Tpo -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_cancel.lo `test -f 'mpi_funcs/mpi_cancel.c' || echo '$(srcdir)/'`mpi_funcs/mpi_cancel.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_cancel.Tpo mpi_funcs/$(DEPDIR)/libeztrace_@MPI_MODULE_NAME@_la-mpi_cancel.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_cancel.c' object='mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_cancel.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_@MPI_MODULE_NAME@_la-mpi_cancel.lo `test -f 'mpi_funcs/mpi_cancel.c' || echo '$(srcdir)/'`mpi_funcs/mpi_cancel.c libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi.lo: mpi.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi.lo -MD -MP -MF $(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi.Tpo -c -o libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi.lo `test -f 'mpi.c' || echo '$(srcdir)/'`mpi.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi.Tpo $(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi.c' object='libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi.lo `test -f 'mpi.c' || echo '$(srcdir)/'`mpi.c libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_fortran.lo: mpi_fortran.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_fortran.lo -MD -MP -MF $(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_fortran.Tpo -c -o libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_fortran.lo `test -f 'mpi_fortran.c' || echo '$(srcdir)/'`mpi_fortran.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_fortran.Tpo $(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_fortran.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_fortran.c' object='libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_fortran.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_fortran.lo `test -f 'mpi_fortran.c' || echo '$(srcdir)/'`mpi_fortran.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgather.lo: mpi_funcs/mpi_allgather.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgather.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgather.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgather.lo `test -f 'mpi_funcs/mpi_allgather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_allgather.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgather.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgather.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_allgather.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgather.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgather.lo `test -f 'mpi_funcs/mpi_allgather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_allgather.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo: mpi_funcs/mpi_allgatherv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgatherv.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo `test -f 'mpi_funcs/mpi_allgatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_allgatherv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgatherv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgatherv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_allgatherv.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allgatherv.lo `test -f 'mpi_funcs/mpi_allgatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_allgatherv.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allreduce.lo: mpi_funcs/mpi_allreduce.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allreduce.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allreduce.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allreduce.lo `test -f 'mpi_funcs/mpi_allreduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_allreduce.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allreduce.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allreduce.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_allreduce.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allreduce.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_allreduce.lo `test -f 'mpi_funcs/mpi_allreduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_allreduce.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoall.lo: mpi_funcs/mpi_alltoall.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoall.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoall.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoall.lo `test -f 'mpi_funcs/mpi_alltoall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_alltoall.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoall.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoall.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_alltoall.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoall.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoall.lo `test -f 'mpi_funcs/mpi_alltoall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_alltoall.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo: mpi_funcs/mpi_alltoallv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoallv.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo `test -f 'mpi_funcs/mpi_alltoallv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_alltoallv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoallv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoallv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_alltoallv.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_alltoallv.lo `test -f 'mpi_funcs/mpi_alltoallv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_alltoallv.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_barrier.lo: mpi_funcs/mpi_barrier.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_barrier.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_barrier.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_barrier.lo `test -f 'mpi_funcs/mpi_barrier.c' || echo '$(srcdir)/'`mpi_funcs/mpi_barrier.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_barrier.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_barrier.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_barrier.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_barrier.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_barrier.lo `test -f 'mpi_funcs/mpi_barrier.c' || echo '$(srcdir)/'`mpi_funcs/mpi_barrier.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bcast.lo: mpi_funcs/mpi_bcast.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bcast.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bcast.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bcast.lo `test -f 'mpi_funcs/mpi_bcast.c' || echo '$(srcdir)/'`mpi_funcs/mpi_bcast.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bcast.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bcast.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_bcast.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bcast.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bcast.lo `test -f 'mpi_funcs/mpi_bcast.c' || echo '$(srcdir)/'`mpi_funcs/mpi_bcast.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend.lo: mpi_funcs/mpi_bsend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend.lo `test -f 'mpi_funcs/mpi_bsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_bsend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_bsend.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend.lo `test -f 'mpi_funcs/mpi_bsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_bsend.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo: mpi_funcs/mpi_bsend_init.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend_init.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo `test -f 'mpi_funcs/mpi_bsend_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_bsend_init.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend_init.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend_init.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_bsend_init.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_bsend_init.lo `test -f 'mpi_funcs/mpi_bsend_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_bsend_init.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gather.lo: mpi_funcs/mpi_gather.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gather.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gather.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gather.lo `test -f 'mpi_funcs/mpi_gather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_gather.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gather.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gather.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_gather.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gather.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gather.lo `test -f 'mpi_funcs/mpi_gather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_gather.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gatherv.lo: mpi_funcs/mpi_gatherv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gatherv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gatherv.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gatherv.lo `test -f 'mpi_funcs/mpi_gatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_gatherv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gatherv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gatherv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_gatherv.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gatherv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_gatherv.lo `test -f 'mpi_funcs/mpi_gatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_gatherv.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_get.lo: mpi_funcs/mpi_get.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_get.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_get.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_get.lo `test -f 'mpi_funcs/mpi_get.c' || echo '$(srcdir)/'`mpi_funcs/mpi_get.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_get.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_get.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_get.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_get.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_get.lo `test -f 'mpi_funcs/mpi_get.c' || echo '$(srcdir)/'`mpi_funcs/mpi_get.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibsend.lo: mpi_funcs/mpi_ibsend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibsend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibsend.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibsend.lo `test -f 'mpi_funcs/mpi_ibsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ibsend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibsend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibsend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ibsend.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibsend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibsend.lo `test -f 'mpi_funcs/mpi_ibsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ibsend.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iprobe.lo: mpi_funcs/mpi_iprobe.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iprobe.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iprobe.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iprobe.lo `test -f 'mpi_funcs/mpi_iprobe.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iprobe.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iprobe.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iprobe.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iprobe.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iprobe.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iprobe.lo `test -f 'mpi_funcs/mpi_iprobe.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iprobe.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irecv.lo: mpi_funcs/mpi_irecv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irecv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irecv.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irecv.lo `test -f 'mpi_funcs/mpi_irecv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_irecv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irecv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irecv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_irecv.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irecv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irecv.lo `test -f 'mpi_funcs/mpi_irecv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_irecv.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irsend.lo: mpi_funcs/mpi_irsend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irsend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irsend.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irsend.lo `test -f 'mpi_funcs/mpi_irsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_irsend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irsend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irsend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_irsend.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irsend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_irsend.lo `test -f 'mpi_funcs/mpi_irsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_irsend.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_isend.lo: mpi_funcs/mpi_isend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_isend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_isend.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_isend.lo `test -f 'mpi_funcs/mpi_isend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_isend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_isend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_isend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_isend.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_isend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_isend.lo `test -f 'mpi_funcs/mpi_isend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_isend.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_issend.lo: mpi_funcs/mpi_issend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_issend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_issend.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_issend.lo `test -f 'mpi_funcs/mpi_issend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_issend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_issend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_issend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_issend.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_issend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_issend.lo `test -f 'mpi_funcs/mpi_issend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_issend.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_probe.lo: mpi_funcs/mpi_probe.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_probe.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_probe.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_probe.lo `test -f 'mpi_funcs/mpi_probe.c' || echo '$(srcdir)/'`mpi_funcs/mpi_probe.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_probe.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_probe.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_probe.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_probe.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_probe.lo `test -f 'mpi_funcs/mpi_probe.c' || echo '$(srcdir)/'`mpi_funcs/mpi_probe.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_put.lo: mpi_funcs/mpi_put.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_put.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_put.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_put.lo `test -f 'mpi_funcs/mpi_put.c' || echo '$(srcdir)/'`mpi_funcs/mpi_put.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_put.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_put.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_put.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_put.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_put.lo `test -f 'mpi_funcs/mpi_put.c' || echo '$(srcdir)/'`mpi_funcs/mpi_put.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv.lo: mpi_funcs/mpi_recv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv.lo `test -f 'mpi_funcs/mpi_recv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_recv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_recv.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv.lo `test -f 'mpi_funcs/mpi_recv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_recv.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv_init.lo: mpi_funcs/mpi_recv_init.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv_init.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv_init.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv_init.lo `test -f 'mpi_funcs/mpi_recv_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_recv_init.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv_init.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv_init.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_recv_init.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv_init.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_recv_init.lo `test -f 'mpi_funcs/mpi_recv_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_recv_init.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce.lo: mpi_funcs/mpi_reduce.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce.lo `test -f 'mpi_funcs/mpi_reduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_reduce.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_reduce.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce.lo `test -f 'mpi_funcs/mpi_reduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_reduce.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo: mpi_funcs/mpi_reduce_scatter.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo `test -f 'mpi_funcs/mpi_reduce_scatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_reduce_scatter.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_reduce_scatter.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_reduce_scatter.lo `test -f 'mpi_funcs/mpi_reduce_scatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_reduce_scatter.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend.lo: mpi_funcs/mpi_rsend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend.lo `test -f 'mpi_funcs/mpi_rsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_rsend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_rsend.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend.lo `test -f 'mpi_funcs/mpi_rsend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_rsend.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo: mpi_funcs/mpi_rsend_init.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend_init.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo `test -f 'mpi_funcs/mpi_rsend_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_rsend_init.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend_init.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend_init.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_rsend_init.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_rsend_init.lo `test -f 'mpi_funcs/mpi_rsend_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_rsend_init.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scan.lo: mpi_funcs/mpi_scan.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scan.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scan.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scan.lo `test -f 'mpi_funcs/mpi_scan.c' || echo '$(srcdir)/'`mpi_funcs/mpi_scan.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scan.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scan.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_scan.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scan.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scan.lo `test -f 'mpi_funcs/mpi_scan.c' || echo '$(srcdir)/'`mpi_funcs/mpi_scan.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatter.lo: mpi_funcs/mpi_scatter.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatter.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatter.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatter.lo `test -f 'mpi_funcs/mpi_scatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_scatter.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatter.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatter.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_scatter.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatter.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatter.lo `test -f 'mpi_funcs/mpi_scatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_scatter.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatterv.lo: mpi_funcs/mpi_scatterv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatterv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatterv.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatterv.lo `test -f 'mpi_funcs/mpi_scatterv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_scatterv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatterv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatterv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_scatterv.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatterv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_scatterv.lo `test -f 'mpi_funcs/mpi_scatterv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_scatterv.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send.lo: mpi_funcs/mpi_send.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send.lo `test -f 'mpi_funcs/mpi_send.c' || echo '$(srcdir)/'`mpi_funcs/mpi_send.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_send.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send.lo `test -f 'mpi_funcs/mpi_send.c' || echo '$(srcdir)/'`mpi_funcs/mpi_send.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send_init.lo: mpi_funcs/mpi_send_init.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send_init.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send_init.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send_init.lo `test -f 'mpi_funcs/mpi_send_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_send_init.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send_init.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send_init.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_send_init.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send_init.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_send_init.lo `test -f 'mpi_funcs/mpi_send_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_send_init.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo: mpi_funcs/mpi_sendrecv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo `test -f 'mpi_funcs/mpi_sendrecv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_sendrecv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_sendrecv.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv.lo `test -f 'mpi_funcs/mpi_sendrecv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_sendrecv.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo: mpi_funcs/mpi_sendrecv_replace.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo `test -f 'mpi_funcs/mpi_sendrecv_replace.c' || echo '$(srcdir)/'`mpi_funcs/mpi_sendrecv_replace.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_sendrecv_replace.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_sendrecv_replace.lo `test -f 'mpi_funcs/mpi_sendrecv_replace.c' || echo '$(srcdir)/'`mpi_funcs/mpi_sendrecv_replace.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend.lo: mpi_funcs/mpi_ssend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend.lo `test -f 'mpi_funcs/mpi_ssend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ssend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ssend.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend.lo `test -f 'mpi_funcs/mpi_ssend.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ssend.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo: mpi_funcs/mpi_ssend_init.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend_init.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo `test -f 'mpi_funcs/mpi_ssend_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ssend_init.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend_init.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend_init.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ssend_init.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ssend_init.lo `test -f 'mpi_funcs/mpi_ssend_init.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ssend_init.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_start.lo: mpi_funcs/mpi_start.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_start.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_start.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_start.lo `test -f 'mpi_funcs/mpi_start.c' || echo '$(srcdir)/'`mpi_funcs/mpi_start.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_start.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_start.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_start.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_start.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_start.lo `test -f 'mpi_funcs/mpi_start.c' || echo '$(srcdir)/'`mpi_funcs/mpi_start.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_startall.lo: mpi_funcs/mpi_startall.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_startall.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_startall.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_startall.lo `test -f 'mpi_funcs/mpi_startall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_startall.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_startall.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_startall.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_startall.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_startall.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_startall.lo `test -f 'mpi_funcs/mpi_startall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_startall.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_test.lo: mpi_funcs/mpi_test.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_test.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_test.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_test.lo `test -f 'mpi_funcs/mpi_test.c' || echo '$(srcdir)/'`mpi_funcs/mpi_test.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_test.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_test.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_test.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_test.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_test.lo `test -f 'mpi_funcs/mpi_test.c' || echo '$(srcdir)/'`mpi_funcs/mpi_test.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testall.lo: mpi_funcs/mpi_testall.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testall.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testall.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testall.lo `test -f 'mpi_funcs/mpi_testall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_testall.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testall.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testall.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_testall.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testall.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testall.lo `test -f 'mpi_funcs/mpi_testall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_testall.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testany.lo: mpi_funcs/mpi_testany.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testany.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testany.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testany.lo `test -f 'mpi_funcs/mpi_testany.c' || echo '$(srcdir)/'`mpi_funcs/mpi_testany.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testany.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testany.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_testany.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testany.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testany.lo `test -f 'mpi_funcs/mpi_testany.c' || echo '$(srcdir)/'`mpi_funcs/mpi_testany.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testsome.lo: mpi_funcs/mpi_testsome.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testsome.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testsome.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testsome.lo `test -f 'mpi_funcs/mpi_testsome.c' || echo '$(srcdir)/'`mpi_funcs/mpi_testsome.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testsome.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testsome.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_testsome.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testsome.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_testsome.lo `test -f 'mpi_funcs/mpi_testsome.c' || echo '$(srcdir)/'`mpi_funcs/mpi_testsome.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_wait.lo: mpi_funcs/mpi_wait.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_wait.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_wait.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_wait.lo `test -f 'mpi_funcs/mpi_wait.c' || echo '$(srcdir)/'`mpi_funcs/mpi_wait.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_wait.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_wait.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_wait.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_wait.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_wait.lo `test -f 'mpi_funcs/mpi_wait.c' || echo '$(srcdir)/'`mpi_funcs/mpi_wait.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitall.lo: mpi_funcs/mpi_waitall.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitall.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitall.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitall.lo `test -f 'mpi_funcs/mpi_waitall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_waitall.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitall.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitall.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_waitall.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitall.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitall.lo `test -f 'mpi_funcs/mpi_waitall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_waitall.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitany.lo: mpi_funcs/mpi_waitany.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitany.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitany.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitany.lo `test -f 'mpi_funcs/mpi_waitany.c' || echo '$(srcdir)/'`mpi_funcs/mpi_waitany.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitany.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitany.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_waitany.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitany.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitany.lo `test -f 'mpi_funcs/mpi_waitany.c' || echo '$(srcdir)/'`mpi_funcs/mpi_waitany.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitsome.lo: mpi_funcs/mpi_waitsome.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitsome.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitsome.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitsome.lo `test -f 'mpi_funcs/mpi_waitsome.c' || echo '$(srcdir)/'`mpi_funcs/mpi_waitsome.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitsome.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitsome.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_waitsome.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitsome.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_waitsome.lo `test -f 'mpi_funcs/mpi_waitsome.c' || echo '$(srcdir)/'`mpi_funcs/mpi_waitsome.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo: mpi_funcs/mpi_ibarrier.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibarrier.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo `test -f 'mpi_funcs/mpi_ibarrier.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ibarrier.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibarrier.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibarrier.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ibarrier.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibarrier.lo `test -f 'mpi_funcs/mpi_ibarrier.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ibarrier.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibcast.lo: mpi_funcs/mpi_ibcast.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibcast.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibcast.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibcast.lo `test -f 'mpi_funcs/mpi_ibcast.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ibcast.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibcast.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibcast.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ibcast.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibcast.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ibcast.lo `test -f 'mpi_funcs/mpi_ibcast.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ibcast.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igather.lo: mpi_funcs/mpi_igather.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igather.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igather.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igather.lo `test -f 'mpi_funcs/mpi_igather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_igather.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igather.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igather.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_igather.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igather.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igather.lo `test -f 'mpi_funcs/mpi_igather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_igather.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igatherv.lo: mpi_funcs/mpi_igatherv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igatherv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igatherv.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igatherv.lo `test -f 'mpi_funcs/mpi_igatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_igatherv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igatherv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igatherv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_igatherv.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igatherv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_igatherv.lo `test -f 'mpi_funcs/mpi_igatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_igatherv.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatter.lo: mpi_funcs/mpi_iscatter.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatter.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatter.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatter.lo `test -f 'mpi_funcs/mpi_iscatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iscatter.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatter.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatter.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iscatter.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatter.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatter.lo `test -f 'mpi_funcs/mpi_iscatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iscatter.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo: mpi_funcs/mpi_iscatterv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatterv.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo `test -f 'mpi_funcs/mpi_iscatterv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iscatterv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatterv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatterv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iscatterv.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscatterv.lo `test -f 'mpi_funcs/mpi_iscatterv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iscatterv.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgather.lo: mpi_funcs/mpi_iallgather.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgather.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgather.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgather.lo `test -f 'mpi_funcs/mpi_iallgather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iallgather.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgather.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgather.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iallgather.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgather.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgather.lo `test -f 'mpi_funcs/mpi_iallgather.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iallgather.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo: mpi_funcs/mpi_iallgatherv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgatherv.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo `test -f 'mpi_funcs/mpi_iallgatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iallgatherv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgatherv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgatherv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iallgatherv.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallgatherv.lo `test -f 'mpi_funcs/mpi_iallgatherv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iallgatherv.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo: mpi_funcs/mpi_ialltoall.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoall.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo `test -f 'mpi_funcs/mpi_ialltoall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ialltoall.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoall.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoall.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ialltoall.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoall.lo `test -f 'mpi_funcs/mpi_ialltoall.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ialltoall.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo: mpi_funcs/mpi_ialltoallv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoallv.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo `test -f 'mpi_funcs/mpi_ialltoallv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ialltoallv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoallv.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoallv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ialltoallv.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ialltoallv.lo `test -f 'mpi_funcs/mpi_ialltoallv.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ialltoallv.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce.lo: mpi_funcs/mpi_ireduce.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce.lo `test -f 'mpi_funcs/mpi_ireduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ireduce.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ireduce.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce.lo `test -f 'mpi_funcs/mpi_ireduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ireduce.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo: mpi_funcs/mpi_iallreduce.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallreduce.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo `test -f 'mpi_funcs/mpi_iallreduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iallreduce.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallreduce.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallreduce.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iallreduce.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iallreduce.lo `test -f 'mpi_funcs/mpi_iallreduce.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iallreduce.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo: mpi_funcs/mpi_ireduce_scatter.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo `test -f 'mpi_funcs/mpi_ireduce_scatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ireduce_scatter.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_ireduce_scatter.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_ireduce_scatter.lo `test -f 'mpi_funcs/mpi_ireduce_scatter.c' || echo '$(srcdir)/'`mpi_funcs/mpi_ireduce_scatter.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscan.lo: mpi_funcs/mpi_iscan.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscan.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscan.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscan.lo `test -f 'mpi_funcs/mpi_iscan.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iscan.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscan.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscan.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_iscan.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscan.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_iscan.lo `test -f 'mpi_funcs/mpi_iscan.c' || echo '$(srcdir)/'`mpi_funcs/mpi_iscan.c mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_cancel.lo: mpi_funcs/mpi_cancel.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -MT mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_cancel.lo -MD -MP -MF mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_cancel.Tpo -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_cancel.lo `test -f 'mpi_funcs/mpi_cancel.c' || echo '$(srcdir)/'`mpi_funcs/mpi_cancel.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_cancel.Tpo mpi_funcs/$(DEPDIR)/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_cancel.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mpi_funcs/mpi_cancel.c' object='mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_cancel.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_CFLAGS) $(CFLAGS) -c -o mpi_funcs/libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_cancel.lo `test -f 'mpi_funcs/mpi_cancel.c' || echo '$(srcdir)/'`mpi_funcs/mpi_cancel.c libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi.lo: eztrace_convert_mpi.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi.Tpo -c -o libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi.lo `test -f 'eztrace_convert_mpi.c' || echo '$(srcdir)/'`eztrace_convert_mpi.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi.Tpo $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_mpi.c' object='libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi.lo `test -f 'eztrace_convert_mpi.c' || echo '$(srcdir)/'`eztrace_convert_mpi.c libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_p2p.lo: eztrace_convert_mpi_p2p.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_p2p.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_p2p.Tpo -c -o libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_p2p.lo `test -f 'eztrace_convert_mpi_p2p.c' || echo '$(srcdir)/'`eztrace_convert_mpi_p2p.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_p2p.Tpo $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_p2p.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_mpi_p2p.c' object='libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_p2p.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_p2p.lo `test -f 'eztrace_convert_mpi_p2p.c' || echo '$(srcdir)/'`eztrace_convert_mpi_p2p.c libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_coll.lo: eztrace_convert_mpi_coll.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_coll.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_coll.Tpo -c -o libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_coll.lo `test -f 'eztrace_convert_mpi_coll.c' || echo '$(srcdir)/'`eztrace_convert_mpi_coll.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_coll.Tpo $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_coll.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_mpi_coll.c' object='libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_coll.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_coll.lo `test -f 'eztrace_convert_mpi_coll.c' || echo '$(srcdir)/'`eztrace_convert_mpi_coll.c libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_pers.lo: eztrace_convert_mpi_pers.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_pers.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_pers.Tpo -c -o libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_pers.lo `test -f 'eztrace_convert_mpi_pers.c' || echo '$(srcdir)/'`eztrace_convert_mpi_pers.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_pers.Tpo $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_pers.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_mpi_pers.c' object='libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_pers.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_convert_mpi_pers.lo `test -f 'eztrace_convert_mpi_pers.c' || echo '$(srcdir)/'`eztrace_convert_mpi_pers.c libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_stats_mpi.lo: eztrace_stats_mpi.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_stats_mpi.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_stats_mpi.Tpo -c -o libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_stats_mpi.lo `test -f 'eztrace_stats_mpi.c' || echo '$(srcdir)/'`eztrace_stats_mpi.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_stats_mpi.Tpo $(DEPDIR)/libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_stats_mpi.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_stats_mpi.c' object='libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_stats_mpi.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_@MPI_MODULE_NAME@_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_@MPI_MODULE_NAME@_la-eztrace_stats_mpi.lo `test -f 'eztrace_stats_mpi.c' || echo '$(srcdir)/'`eztrace_stats_mpi.c .f90.o: $(AM_V_FC)$(FCCOMPILE) -c -o $@ $< .f90.obj: $(AM_V_FC)$(FCCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .f90.lo: $(AM_V_FC)$(LTFCCOMPILE) -c -o $@ $< libeztrace_@MPI_MODULE_NAME@_la-mpi_f.lo: mpi_f.f90 $(AM_V_FC)$(LIBTOOL) $(AM_V_lt) --tag=FC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(FC) $(libeztrace_@MPI_MODULE_NAME@_la_FCFLAGS) $(FCFLAGS) -c -o libeztrace_@MPI_MODULE_NAME@_la-mpi_f.lo `test -f 'mpi_f.f90' || echo '$(srcdir)/'`mpi_f.f90 libeztrace_@MPI_MODULE_NAME@_la-fortran_utils.lo: fortran_utils.f90 $(AM_V_FC)$(LIBTOOL) $(AM_V_lt) --tag=FC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(FC) $(libeztrace_@MPI_MODULE_NAME@_la_FCFLAGS) $(FCFLAGS) -c -o libeztrace_@MPI_MODULE_NAME@_la-fortran_utils.lo `test -f 'fortran_utils.f90' || echo '$(srcdir)/'`fortran_utils.f90 libeztrace_@MPI_MODULE_NAME@_la-mpi3_f.lo: mpi3_f.f90 $(AM_V_FC)$(LIBTOOL) $(AM_V_lt) --tag=FC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(FC) $(libeztrace_@MPI_MODULE_NAME@_la_FCFLAGS) $(FCFLAGS) -c -o libeztrace_@MPI_MODULE_NAME@_la-mpi3_f.lo `test -f 'mpi3_f.f90' || echo '$(srcdir)/'`mpi3_f.f90 libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_f.lo: mpi_f.f90 $(AM_V_FC)$(LIBTOOL) $(AM_V_lt) --tag=FC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(FC) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_FCFLAGS) $(FCFLAGS) -c -o libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi_f.lo `test -f 'mpi_f.f90' || echo '$(srcdir)/'`mpi_f.f90 libeztrace_autostart_@MPI_MODULE_NAME@_la-fortran_utils.lo: fortran_utils.f90 $(AM_V_FC)$(LIBTOOL) $(AM_V_lt) --tag=FC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(FC) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_FCFLAGS) $(FCFLAGS) -c -o libeztrace_autostart_@MPI_MODULE_NAME@_la-fortran_utils.lo `test -f 'fortran_utils.f90' || echo '$(srcdir)/'`fortran_utils.f90 libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi3_f.lo: mpi3_f.f90 $(AM_V_FC)$(LIBTOOL) $(AM_V_lt) --tag=FC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(FC) $(libeztrace_autostart_@MPI_MODULE_NAME@_la_FCFLAGS) $(FCFLAGS) -c -o libeztrace_autostart_@MPI_MODULE_NAME@_la-mpi3_f.lo `test -f 'mpi3_f.f90' || echo '$(srcdir)/'`mpi3_f.f90 mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs -rm -rf mpi_funcs/.libs mpi_funcs/_libs tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: for dir in "$(DESTDIR)$(libdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) -rm -f mpi_funcs/$(DEPDIR)/$(am__dirstamp) -rm -f mpi_funcs/$(am__dirstamp) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) mpi_funcs/$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-libLTLIBRARIES install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) mpi_funcs/$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-libLTLIBRARIES .MAKE: install-am install-strip .PHONY: all all-am check check-am clean clean-generic \ clean-libLTLIBRARIES clean-libtool cscopelist-am ctags-am \ distclean distclean-compile distclean-generic \ distclean-libtool distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-info install-info-am \ install-libLTLIBRARIES install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags-am uninstall uninstall-am uninstall-libLTLIBRARIES .PRECIOUS: Makefile #noinst_HEADERS = eztrace_convert_mpi.h \ # mpi_ev_codes.h # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/src/modules/mpi/eztrace_convert_mpi.c000066400000000000000000002630751265506773700224400ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include #include #include #include "mpi_ev_codes.h" #include "mpi_eztrace.h" #include "eztrace_list.h" #include "eztrace_convert.h" #include "eztrace_convert_mpi.h" #include "eztrace_convert_mpi_p2p.h" #include "eztrace_convert_mpi_coll.h" #include "eztrace_convert_mpi_pers.h" #include "eztrace_stats_mpi.h" #ifdef USE_MPI /* todo: we should get rid of these lists. Use the hierarchical arrays instead. */ /* list that contains pending MPI_Comm_spawn */ struct ezt_list_t spawn_list; static int recording_stats = 0; static unsigned nb_mpi_calls[MPI_ID_SIZE]; int *rank_to_trace_id = NULL; #define MPI_CHANGE() if(!recording_stats) CHANGE() static void mpi_synchronize_processes(struct mpi_coll_msg_t* msg, int my_rank); static struct ezt_list_token_t* __find_matching_spawn(int ppid) { struct ezt_list_token_t *t = NULL; struct mpi_spawn_t *r; ezt_list_foreach(&spawn_list, t) { r = (struct mpi_spawn_t *) t->data; if(r->ppid == ppid) return t; } return t; } static struct ezt_mpi_comm* ezt_find_communicator(int index, app_ptr comm_id) { INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(index), p_info); if(p_info->__MPI_COMM_WORLD.comm_id == comm_id) return &p_info->__MPI_COMM_WORLD; if(p_info->__MPI_COMM_SELF.comm_id == comm_id) return &p_info->__MPI_COMM_SELF; struct ezt_list_token_t *token; ezt_list_foreach(&p_info->communicators, token) { struct ezt_mpi_comm* p_comm = (struct ezt_mpi_comm*) token->data; assert(p_comm); if(p_comm->comm_id == comm_id) { /* we found the communicator ! */ return p_comm; } } return 0; } #if EZTRACE_DEBUG /* return 1 if comm_id already exists in comm_list * for debugging purpose only */ static int __find_communicator(app_ptr comm_id, struct ezt_list_t *comm_list) { struct ezt_list_token_t *token; ezt_list_foreach(comm_list, token) { struct ezt_mpi_comm* p_comm = (struct ezt_mpi_comm*) token->data; assert(p_comm); if(p_comm->comm_id == comm_id) { /* we found the communicator ! */ return 1; } return 0; } } #endif /* destroy an mpi communicator */ void handle_mpi_delete_comm() { FUNC_NAME; INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); /* get the communicator id (eg. MPI_COMM_WORLD) and the number of processes */ app_ptr comm_id; GET_PARAM_PACKED_1(CUR_EV, comm_id); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); assert(comm); ezt_list_remove(&comm->token); ezt_list_add(&p_info->deleted_communicators, &comm->token); } /* create a new mpi communicator */ void handle_mpi_new_comm() { FUNC_NAME; /* get the communicator id (eg. MPI_COMM_WORLD) and the number of processes */ app_ptr comm_id; int comm_size; GET_PARAM_PACKED_2(CUR_EV, comm_id, comm_size); INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); /* allocate a new ezt_mpi_comm and fill it */ struct ezt_mpi_comm* p_comm = malloc(sizeof(struct ezt_mpi_comm)); p_comm->comm_id = comm_id; p_comm->comm_size = comm_size; p_comm->ranks = malloc(sizeof(int)*comm_size); p_comm->p_process = p_info; #if EZTRACE_DEBUG if(__find_communicator(comm_id, &p_info->communicators)) { fprintf(stderr, "[%d] Error: trying to add a communicator (%d) that already exists!\n", comm_id); abort(); } #endif /* for each rank in the new communicator, translate to the global rank * (the corresponding rank in MPI_COMM_WORLD) */ int i; for(i=0; iranks[i]); if(CUR_RANK == p_comm->ranks[i]) p_comm->my_rank = i; } p_comm->token.data = p_comm; ezt_list_add(&p_info->communicators, &p_comm->token); } int is_comm_mine(int global_rank, struct ezt_mpi_comm*comm) { if(comm->ranks[comm->my_rank] == global_rank) return 1; return 0; } static struct mpi_p2p_msg_t* __mpi_send_generic(const char* thread_id, int src, int dest, int len, uint32_t tag, struct mpi_request* mpi_req, app_ptr comm) { int actual_dest = ezt_get_global_rank_generic(rank_to_trace_id[src], comm, dest); assert(actual_dest!= -1); struct mpi_p2p_msg_t* msg = __start_send_message(CUR_TIME(CUR_INDEX), src, actual_dest, len, tag, thread_id, mpi_req); assert(msg); if(! msg->times[stop_recv]) { #ifndef GTG_OUT_OF_ORDER MPI_CHANGE() startLink(CURRENT, "L_MPI_P2P", "C_Prog", msg->sender_thread_id, msg->recver_thread_id, msg->link_value, msg->id); #endif } return msg; } static struct mpi_p2p_msg_t * __mpi_start_recv_generic (char*thread_id, int src, int dest, int len, int tag, struct mpi_request* mpi_req, app_ptr comm) { INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(rank_to_trace_id[dest]), p_info); if (src == p_info->__MPI_PROC_NULL || dest == p_info->__MPI_PROC_NULL) return NULL; int actual_src = src; if(src != p_info->__MPI_ANY_SOURCE) { actual_src = ezt_get_global_rank_generic(rank_to_trace_id[dest], comm, src); assert(actual_src!= -1); assert(actual_src!= -1); } return __start_recv_message(CUR_TIME(CUR_INDEX), actual_src, dest, len, tag, thread_id, mpi_req); } /* return 1 if the matching isend didn't occured yet. * In that case, this function has to be called again when the matching isend occurs * In case a synchronization problem is detected, timestamp is updated */ static int __mpi_stop_recv_generic (uint64_t *timestamp, char*thread_id, int src, int dest, int len, int tag, struct mpi_request* mpi_req, app_ptr comm) { int delay_added = 0; INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(rank_to_trace_id[dest]), p_info); if (src == p_info->__MPI_PROC_NULL || dest == p_info->__MPI_PROC_NULL) { return 0; } int actual_src = src; if(src != p_info->__MPI_ANY_SOURCE) { actual_src = ezt_get_global_rank_generic(CUR_INDEX, comm, src); assert(actual_src!= -1); } struct mpi_p2p_msg_t *msg = __stop_recv_message(*timestamp, actual_src, dest, len, tag, thread_id, mpi_req); if(!msg) { /* There is no matching MPI_Isend yet. * This means there's a synchronisation problem between the traces. * Let's wait until the remote process calls MPI_Isend */ SKIP = 1; CUR_TRACE->skip = 1; return 1; } if(msg->times[start_isend]) { if(msg->times[start_isend] > msg->times[stop_recv]) { msg->times[stop_recv] += add_delay_to_trace(rank_to_trace_id[dest], msg->times[stop_recv], msg->times[start_isend], msg->recver_thread_id); *timestamp = msg->times[stop_recv]; delay_added = 1; } assert(msg->id); assert(msg->link_value); assert(msg->sender_thread_id); assert(msg->recver_thread_id); #ifdef GTG_OUT_OF_ORDER MPI_CHANGE() startLink(NS_TO_MS(msg->times[start_isend]), "L_MPI_P2P", "C_Prog", msg->sender_thread_id, msg->recver_thread_id, msg->link_value, msg->id); MPI_CHANGE() endLink(NS_TO_MS(msg->times[stop_recv]), "L_MPI_P2P", "C_Prog", msg->sender_thread_id, thread_id, msg->link_value, msg->id); char* message_str = NULL; float throughput = -1; /* duration in us */ float duration = ((NS_TO_MS(*timestamp)) - (NS_TO_MS(msg->times[start_isend])))*1e3; int res __attribute__ ((__unused__)); if(!delay_added) { if(len) { /* byte / us = MB/s */ throughput = len/duration; } res = asprintf(&message_str, "duration = %f us -- len=%d bytes -- throughput=%f MB/s", duration, len, throughput); } else { /* There was a synchronization problem that was corrected. Thus, the duration of the * communication is 0 (which does not make sense). We still need to add an event here since * some trace analysis tools (eg. eztrace pattern detection) may expect an event. */ res = asprintf(&message_str, "duration = ? (lost due to a synchronization correction) -- len=%d bytes -- throughput=? MB/s", len); } MPI_CHANGE() addEvent((NS_TO_MS(*timestamp)), "E_MPI_EndComm", thread_id, message_str); #else /* GTG_OUT_OF_ORDER */ MPI_CHANGE() endLink((NS_TO_MS(*timestamp)), "L_MPI_P2P", "C_Prog", msg->sender_thread_id, msg->recver_thread_id, msg->link_value, msg->id); #endif } return 0; } #define start_coll_link(msg, src, dest) \ startLink (NS_TO_MS(msg->times[src][start_coll]), \ "L_MPI_Coll", "C_Prog", \ msg->thread_ids[src], msg->thread_ids[dest], \ msg->link_value[src][dest], msg->link_id[src][dest]) #define end_coll_link(msg, src, dest) \ endLink(NS_TO_MS(msg->times[dest][stop_coll]), \ "L_MPI_Coll", "C_Prog", \ msg->thread_ids[src], msg->thread_ids[dest], \ msg->link_value[src][dest], msg->link_id[src][dest]) static void __mpi_barrier_start_generic(struct mpi_coll_msg_t* msg, int my_rank) { int i; for(i=0; icomm[my_rank]->comm_size; i++) { if(i != my_rank) { #ifdef GTG_OUT_OF_ORDER assert(msg->thread_ids[my_rank]); if(msg->times[i][stop_coll]) { /* the remote process stop_coll already happened. * This means that there's a synchronisation problem between the traces */ msg->times[i][stop_coll] += add_delay_to_trace(i, msg->times[i][stop_coll], msg->times[my_rank][start_coll], msg->thread_ids[i]); } #else /* todo: not implemented yet */ #endif /* GTG_OUT_OF_ORDER */ } } } /* return 1 if the matching isend didn't occured yet. * In that case, this function has to be called again when the matching isend occurs */ static int __mpi_barrier_stop_generic(struct mpi_coll_msg_t* msg, int my_rank) { int i; if(!msg) { SKIP = 1; CUR_TRACE->skip = 1; return 1; } for(i=0; icomm[my_rank]->comm_size; i++) { if(i != my_rank) { if(! msg->times[i][start_coll]) { /* ith process has not yet reached the MPI_Barrier. * This means there's a synchronisation problem between the traces. * Let's wait until the remote process starts MPI_Barrier */ SKIP = 1; CUR_TRACE->skip = 1; msg->times[my_rank][stop_coll] = 0; return 1; } } } for(i=0; icomm[my_rank]->comm_size; i++) { if(i != my_rank) { #ifdef GTG_OUT_OF_ORDER assert(msg->thread_ids[my_rank]); assert(msg->thread_ids[i]); MPI_CHANGE() start_coll_link(msg, my_rank, i); MPI_CHANGE() end_coll_link(msg, i, my_rank); #else /* todo: not implemented yet */ #endif /* GTG_OUT_OF_ORDER */ } } return 0; } void handle_mpi_init () { int rank; int world_size; int mpi_any_source; int mpi_any_tag; app_ptr mpi_request_null; int mpi_proc_null; GET_PARAM_PACKED_6(CUR_EV, rank, world_size, mpi_any_source, mpi_any_tag, mpi_request_null, mpi_proc_null); EZT_CONVERT_PRINTF(1, "MPI_Init(rank=%d, world_size=%d, mpi_any_source=%x, mpi_any_tag=%x, mpi_request_null=%x, mpi_proc_null=%d)\n", rank, world_size, mpi_any_source, mpi_any_tag, mpi_request_null, mpi_proc_null); if(!rank_to_trace_id) { int *nb = get_nb_traces(); rank_to_trace_id = calloc(*nb, sizeof(int)); } rank_to_trace_id[rank] = CUR_INDEX; CUR_TRACE->start_time = LITL_READ_GET_TIME(CUR_EV); /* Check wether MPI_SPAWNED event has already occur. * In that case, the rank is already known. */ if(!CUR_TRACE->start) { CUR_RANK = rank; int res __attribute__ ((__unused__)); res = CREATE_TRACE_ID_STR(CUR_ID, rank); GET_PROCESS_INFO(CUR_INDEX)->pid = rank; eztrace_create_ids(CUR_INDEX); CUR_TRACE->start = 1; NB_START++; /* Create the process and the main thread */ DECLARE_PROCESS_ID_STR(process_id, CUR_INDEX); if(!recording_stats)addContainer (CURRENT, process_id, "CT_Process", "C_Prog", process_id, "0"); new_thread(CUR_THREAD_ID); } else { CUR_TRACE->start = 1; NB_START++; } INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); p_info->__MPI_ANY_SOURCE = mpi_any_source; p_info->__MPI_ANY_TAG = mpi_any_tag; p_info->__MPI_REQUEST_NULL = mpi_request_null; p_info->__MPI_PROC_NULL = mpi_proc_null; wait_for_an_event(CUR_TRACE->id, EZTRACE_MPI_INIT_Info); GET_PARAM_PACKED_2(CUR_EV, p_info->__MPI_COMM_WORLD.comm_id, p_info->__MPI_COMM_SELF.comm_id); p_info->__MPI_COMM_WORLD.comm_size = world_size; p_info->__MPI_COMM_WORLD.ranks = malloc(world_size * sizeof(int)); int i; for(i=0;i__MPI_COMM_WORLD.ranks[i] = i; p_info->__MPI_COMM_WORLD.my_rank = rank; p_info->__MPI_COMM_WORLD.p_process = p_info; p_info->__MPI_COMM_SELF.comm_size = 1; p_info->__MPI_COMM_SELF.ranks = malloc(1 * sizeof(int)); p_info->__MPI_COMM_SELF.ranks[0] = rank; p_info->__MPI_COMM_SELF.my_rank = 0; p_info->__MPI_COMM_SELF.p_process = p_info; ezt_list_new(&p_info->communicators); ezt_list_new(&p_info->deleted_communicators); FUNC_NAME; } void handle_mpi_spawned() { /* set the start time */ if(CUR_TRACE->start == 0) CUR_TRACE->start_time = LITL_READ_GET_TIME(CUR_EV); CUR_TRACE->start = 1; int ppid; /* local_rank = rank amoung the spawned processes */ int local_rank; GET_PARAM_PACKED_2(CUR_EV, ppid, local_rank); struct ezt_list_token_t *token = __find_matching_spawn(ppid); if(!token) { /* the MPI_Comm_spawn has not been handled yet. We have to wait for it */ SKIP = 1; CUR_TRACE->skip = 1; return; } struct mpi_spawn_t *spawn; spawn = (struct mpi_spawn_t *) token->data; /* We have to add a delay to all events on this trace */ CUR_TRACE->delay = spawn->start_time; spawn->nb_children--; struct trace_t *parent_trace = spawn->parent_trace; if(!spawn->nb_children) { /* all the spawned processes have been handled, we can free this structure. */ ezt_list_remove(token); free(spawn); free(token); } CUR_RANK = ppid + local_rank; /* initialize the trace_id */ int res __attribute__ ((__unused__)); res = asprintf(&CUR_ID, "%s_%d", parent_trace->trace_id, local_rank); eztrace_create_ids(CUR_INDEX); DECLARE_PROCESS_ID_STR(process_id, CUR_INDEX); if(!recording_stats)addContainer (CURRENT, process_id, "CT_Process", "C_Prog", process_id, "0"); new_thread(CUR_THREAD_ID); /* Crappy hack: we know that next event is MPI_Init and * we need the trace to be properly started before continuing the function. */ wait_for_an_event(CUR_TRACE->id, EZTRACE_MPI_INIT); /* We should at least check if the code corresponds to MPI_INIT */ handle_mpi_init (); FUNC_NAME; /* prepare the link value */ char*link_id = NULL; int __attribute__((unused)) ret = asprintf(&link_id, "%s_%d", parent_trace->trace_id, local_rank); MPI_CHANGE() endLink (CURRENT, "L_MPI_SPAWN", "C_Prog", parent_trace->trace_id, process_id, link_id, link_id); free(link_id); } void __ezt_mpi_enter_function(MPI_id_t id) { DECLARE_CUR_THREAD(p_thread); INIT_MPI_THREAD_INFO(p_thread, thread_info); assert(thread_info->enter_date_mpi_calls[id] == 0); thread_info->nb_mpi_calls[id]++; thread_info->enter_date_mpi_calls[id] = CURRENT; } void __ezt_mpi_leave_function(MPI_id_t id) { DECLARE_CUR_THREAD(p_thread); INIT_MPI_THREAD_INFO(p_thread, thread_info); assert(thread_info->enter_date_mpi_calls[id] != 0); assert(thread_info->leave_date_mpi_calls[id] == 0); thread_info->leave_date_mpi_calls[id] = CURRENT; thread_info->total_time_mpi_calls[id] += thread_info->leave_date_mpi_calls[id]-thread_info->enter_date_mpi_calls[id]; thread_info->enter_date_mpi_calls[id] = 0; thread_info->leave_date_mpi_calls[id] = 0; } void handle_mpi_start_send () { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_SEND_ID); int len; int dest; uint32_t tag; app_ptr comm; GET_PARAM_PACKED_4(CUR_EV, len, dest, tag, comm); struct mpi_p2p_msg_t* msg = __mpi_send_generic( thread_id, CUR_RANK, dest, len, tag, NULL, comm); if(!msg->times[stop_isend]) msg->times[stop_isend] = CUR_TIME(CUR_INDEX); if(!msg->times[start_swait]) msg->times[start_swait] = CUR_TIME(CUR_INDEX); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Send"); } void handle_mpi_stop_send () { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_leave_function(MPI_SEND_ID); int dest; int tag; app_ptr comm_id; GET_PARAM_PACKED_3(CUR_EV, dest, tag, comm_id); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); int actual_dest = ezt_get_global_rank(comm, dest); assert(actual_dest != -1); __stop_send_message(CUR_TIME(CUR_INDEX), CUR_RANK, actual_dest, -1, tag, thread_id, NULL); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_mpi_start_recv () { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_RECV_ID); int len; int src; int dest = CUR_RANK; uint32_t tag; app_ptr comm_id; GET_PARAM_PACKED_4(CUR_EV, len, src, tag, comm_id); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, (app_ptr) comm_id); INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); int actual_src = src; if(src != p_info->__MPI_ANY_SOURCE) { actual_src = ezt_get_global_rank(comm, src); assert(actual_src!= -1); } struct mpi_p2p_msg_t* msg = __start_recv_message(CUR_TIME(CUR_INDEX), actual_src, dest, len, tag, thread_id, NULL); if(!msg->times[stop_irecv]) msg->times[stop_irecv] = CUR_TIME(CUR_INDEX); if(!msg->times[start_rwait]) msg->times[start_rwait] = CUR_TIME(CUR_INDEX); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Recv"); } void handle_mpi_stop_recv () { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); int len; int src; uint32_t tag; app_ptr comm; GET_PARAM_PACKED_4(CUR_EV, len, src, tag, comm); uint64_t timestamp = CUR_TIME(CUR_INDEX); if(__mpi_stop_recv_generic (×tamp, thread_id, src, CUR_RANK, len, tag, NULL, comm)) { /* waiting for a mpi_send that matches */ return; } __ezt_mpi_leave_function(MPI_RECV_ID); MPI_CHANGE() popState(NS_TO_MS(timestamp), "ST_Thread", thread_id); } void handle_mpi_start_sendrecv () { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_SENDRECV_ID); int rsrc = 0; int rdest = CUR_RANK; uint32_t rtag = 0; int rlen = 0; int ssrc = CUR_RANK; int sdest = 0; uint32_t stag = 0; int slen = 0; app_ptr comm = 0; GET_PARAM_PACKED_4(CUR_EV, rlen, rsrc, rtag, comm); /* process the recv */ wait_for_an_event(CUR_TRACE->id, EZTRACE_MPI_Info); GET_PARAM_PACKED_3(CUR_EV, slen, sdest, stag); INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); struct mpi_p2p_msg_t* msg; /* process the send */ if (ssrc != p_info->__MPI_PROC_NULL && sdest != p_info->__MPI_PROC_NULL) { msg = __mpi_send_generic( thread_id, ssrc, sdest, slen, stag, NULL, comm); if(!msg->times[stop_isend]) { msg->times[stop_isend] = CUR_TIME(CUR_INDEX); } if(!msg->times[start_swait]) { msg->times[start_swait] = CUR_TIME(CUR_INDEX); } } /* process the recv */ if (rsrc != p_info->__MPI_PROC_NULL && rdest != p_info->__MPI_PROC_NULL) { int actual_src = rsrc; if(rsrc != p_info->__MPI_ANY_SOURCE) { actual_src = ezt_get_global_rank_generic(CUR_INDEX, comm, rsrc); assert(actual_src!= -1); } msg = __start_recv_message(CUR_TIME(CUR_INDEX), actual_src, rdest, rlen, rtag, thread_id, NULL); if(!msg->times[stop_irecv]) msg->times[stop_irecv] = CUR_TIME(CUR_INDEX); if(!msg->times[start_rwait]) msg->times[start_rwait] = CUR_TIME(CUR_INDEX); } MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Sendrecv"); } void handle_mpi_stop_sendrecv () { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); /* we need to process the recv first because we may have to re-synchronize traces * and thus, we may have to call handle_mpi_sop_sendrecv several times (until the corresponding * send occurs). */ int rsrc = 0; int rdest = CUR_RANK; uint32_t rtag = 0; int rlen = 0; int ssrc = CUR_RANK; int sdest = 0; uint32_t stag = 0; int slen = 0; app_ptr comm; GET_PARAM_PACKED_4(CUR_EV, rlen, rsrc, rtag, comm); uint64_t timestamp = CUR_TIME(CUR_INDEX); INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); /* process the recv */ if (rsrc != p_info->__MPI_PROC_NULL && rdest != p_info->__MPI_PROC_NULL) { if(__mpi_stop_recv_generic (×tamp, thread_id, rsrc, rdest, rlen, rtag, NULL, comm)) { /* waiting for a mpi _send that matches */ return; } } /* process the send */ wait_for_an_event(CUR_TRACE->id, EZTRACE_MPI_Info); GET_PARAM_PACKED_3(CUR_EV, slen, sdest, stag); if (ssrc != p_info->__MPI_PROC_NULL && sdest != p_info->__MPI_PROC_NULL) { int actual_dest = ezt_get_global_rank_generic(CUR_INDEX, comm, sdest); __stop_send_message(timestamp, CUR_RANK, actual_dest, -1, stag, thread_id, NULL); } __ezt_mpi_leave_function(MPI_SENDRECV_ID); /* pop the sendrecv state */ MPI_CHANGE() popState(NS_TO_MS(timestamp), "ST_Thread", thread_id); } void handle_mpi_start_sendrecv_replace () { handle_mpi_start_sendrecv(); /* todo: implement this */ } void handle_mpi_stop_sendrecv_replace () { handle_mpi_stop_sendrecv(); } /* todo: implement this ! */ void handle_mpi_start_bsend() { /* for now, let's assume that bsend and send are the same */ handle_mpi_start_send (); } void handle_mpi_stop_bsend() { handle_mpi_stop_send (); } void handle_mpi_start_ssend() { handle_mpi_start_send (); } void handle_mpi_stop_ssend() { handle_mpi_stop_send (); } void handle_mpi_start_rsend() { handle_mpi_start_send (); } void handle_mpi_stop_rsend() { handle_mpi_stop_send (); } void handle_mpi_isend_generic(const char* state) { DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_ISEND_ID); int len; __attribute__((unused)) int src = CUR_RANK; int dest; uint32_t tag; app_ptr app_req; app_ptr comm; GET_PARAM_PACKED_5(CUR_EV, len, dest, tag, app_req, comm); struct mpi_request * mpi_req = __mpi_new_mpi_request(CUR_RANK, app_req, mpi_req_send); assert(mpi_req); __mpi_send_generic( thread_id, CUR_RANK, dest, len, tag, mpi_req, comm); /* todo: add a send event here */ MPI_CHANGE() pushState (CURRENT, "ST_Thread", thread_id, state); } void handle_mpi_isend() { FUNC_NAME; handle_mpi_isend_generic("STV_MPI_Isend"); } void handle_mpi_ibsend() { FUNC_NAME; handle_mpi_isend_generic("STV_MPI_Ibsend"); } void handle_mpi_issend() { FUNC_NAME; handle_mpi_isend_generic("STV_MPI_Irsend"); } void handle_mpi_irsend() { FUNC_NAME; handle_mpi_isend_generic("STV_MPI_Irsend"); } void handle_mpi_stop_isend_generic() { DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_leave_function(MPI_ISEND_ID); app_ptr app_req; GET_PARAM_PACKED_1(CUR_EV, app_req); struct mpi_request * mpi_req = __mpi_find_pending_mpi_req(CUR_RANK, app_req, mpi_req_send); assert(mpi_req); struct mpi_p2p_msg_t* msg = __mpi_find_p2p_message_by_mpi_req(CUR_RANK, mpi_req); assert(msg); if(!msg->times[stop_isend]) msg->times[stop_isend] = CUR_TIME(CUR_INDEX); /* todo: add a send event here */ MPI_CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handle_mpi_stop_isend() { FUNC_NAME; handle_mpi_stop_isend_generic(); } void handle_mpi_stop_ibsend() { FUNC_NAME; handle_mpi_stop_isend_generic(); } void handle_mpi_stop_issend() { FUNC_NAME; handle_mpi_stop_isend_generic(); } void handle_mpi_stop_irsend() { FUNC_NAME; handle_mpi_stop_isend_generic(); } void handle_mpi_irecv() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_IRECV_ID); int len; int src; int dest = CUR_RANK; uint32_t tag; app_ptr app_req; app_ptr comm; GET_PARAM_PACKED_5(CUR_EV, len, src, tag, app_req, comm); struct mpi_request * mpi_req = __mpi_new_mpi_request(CUR_RANK, app_req, mpi_req_recv); assert(mpi_req); __mpi_start_recv_generic (thread_id, src, dest, len, tag, mpi_req, comm); MPI_CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "STV_MPI_Irecv"); } void handle_mpi_stop_irecv() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr app_req; GET_PARAM_PACKED_1(CUR_EV, app_req); __ezt_mpi_leave_function(MPI_IRECV_ID); struct mpi_request * mpi_req = __mpi_find_pending_mpi_req(CUR_RANK, app_req, mpi_req_recv); assert(mpi_req); struct mpi_p2p_msg_t* msg = __mpi_find_p2p_message_by_mpi_req(CUR_RANK, mpi_req); assert(msg); if(!msg->times[stop_irecv]) msg->times[stop_irecv] = CUR_TIME(CUR_INDEX); /* todo: add a recv event here */ MPI_CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handle_mpi_start_put() { /* todo */ } void handle_mpi_stop_put() { /* todo */ } void handle_mpi_start_get() { /* todo */ } void handle_mpi_stop_get() { /* todo */ } int __handle_mpi_start_wait_generic(struct mpi_request * req) { if (!req || req->status == mpi_req_status_none) { return 0; } DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); if(req->req_type == mpi_req_recv) { /* this is a receive request */ struct mpi_p2p_msg_t* msg = __mpi_find_p2p_message_by_mpi_req(CUR_RANK, req); assert(msg); msg->times[start_rwait] = CUR_TIME(CUR_INDEX); return 1; } else if(req->req_type == mpi_req_send) { /* this is a send request */ struct mpi_p2p_msg_t* msg = __mpi_find_p2p_message_by_mpi_req(CUR_RANK, req); assert(msg); msg->times[start_swait] = CUR_TIME(CUR_INDEX); return 1; } else { /* non blocking collective */ #if 0 struct mpi_coll_msg_t *coll_msg = req->coll_msg; switch(coll_msg->type) { case mpi_coll_barrier: MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Barrier"); break; case mpi_coll_bcast: MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_BCast"); break; case mpi_coll_gather: MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Gather"); break; case mpi_coll_scatter: MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Scatter"); break; case mpi_coll_allgather: MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Allgather"); break; case mpi_coll_alltoall: MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Alltoall"); break; case mpi_coll_reduce: MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Reduce"); break; case mpi_coll_allreduce: MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Allreduce"); break; case mpi_coll_reduce_scatter: MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_reduce_scatter"); break; case mpi_coll_scan: MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Scan"); break; default: fprintf(stderr, "%s: Unknown collective type : %d\n", __FUNCTION__, coll_msg->type); } #endif return 1; } return 0; } void handle_mpi_start_wait() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_WAIT_ID); app_ptr mpi_req; GET_PARAM_PACKED_1(CUR_EV, mpi_req); struct mpi_request * req = __mpi_find_pending_mpi_req(CUR_RANK, mpi_req, mpi_req_none); if(__handle_mpi_start_wait_generic(req)) { MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Wait"); } } void handle_mpi_start_waitany() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); __ezt_mpi_enter_function(MPI_WAITANY_ID); int nb_reqs; GET_PARAM_PACKED_1(CUR_EV, nb_reqs); int i; MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Wait"); for(i=0; iid, EZTRACE_MPI_Info); app_ptr mpi_req; GET_PARAM_PACKED_1(CUR_EV, mpi_req); if(mpi_req == p_info->__MPI_REQUEST_NULL) continue; struct mpi_request * req = __mpi_find_pending_mpi_req(CUR_RANK, mpi_req, mpi_req_none); __handle_mpi_start_wait_generic(req); } } void handle_mpi_start_waitall() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); __ezt_mpi_enter_function(MPI_WAITALL_ID); int nb_reqs; GET_PARAM_PACKED_1(CUR_EV, nb_reqs); int i; double cur_time = CURRENT; for(i=0; iid, EZTRACE_MPI_Info); app_ptr mpi_req; GET_PARAM_PACKED_1(CUR_EV, mpi_req); if(mpi_req == p_info->__MPI_REQUEST_NULL) { continue; } struct mpi_request * req = __mpi_find_pending_mpi_req(CUR_RANK, mpi_req, mpi_req_none); __handle_mpi_start_wait_generic(req); } MPI_CHANGE() pushState(cur_time, "ST_Thread", thread_id, "STV_MPI_Wait"); } static int __handle_mpi_test_success(app_ptr req, uint64_t timestamp) { DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); struct mpi_request * mpi_req = __mpi_find_pending_mpi_req(CUR_RANK, req, mpi_req_none); if(!mpi_req) { /* this means the request was already freed, let's skip this one */ return 1; } if(mpi_req->req_type == mpi_req_recv) { /* this is a recv request */ struct mpi_p2p_msg_t* msg = __mpi_find_p2p_message_by_mpi_req(CUR_RANK, mpi_req); assert(msg); assert(msg->recver_request == mpi_req); if(__mpi_stop_recv_generic(×tamp, thread_id, msg->src, msg->dest, msg->len, msg->tag, mpi_req,p_info->__MPI_COMM_WORLD.comm_id)) return 0; } else if(mpi_req->req_type == mpi_req_send) { struct mpi_p2p_msg_t* msg = __mpi_find_p2p_message_by_mpi_req(CUR_RANK, mpi_req); assert(msg); assert(mpi_req->req_type == mpi_req_send); assert(msg->sender_request == mpi_req); /* this is a send request */ __stop_send_message(timestamp, msg->src, msg->dest, msg->len, msg->tag, thread_id, mpi_req); } else { /* non blocking collective */ int local_rank = -1; int i; /* find the rank of the process in this collective */ for(i=0; icoll_msg->comm_size; i++) { if(mpi_req->coll_msg->requests[i] == mpi_req) { local_rank = i; break; } } assert(local_rank >= 0); struct mpi_coll_msg_t* msg = __leave_coll(timestamp, mpi_req->coll_msg->type, mpi_req->coll_msg->comm[local_rank], CUR_RANK, mpi_req, mpi_req->coll_msg->thread_ids[local_rank]); if(__mpi_barrier_stop_generic(msg, CUR_RANK)) return 0; if(msg->type == mpi_coll_barrier) { mpi_synchronize_processes(msg, local_rank); } } return 1; } static void handle_mpi_start_probe() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_PROBE_ID); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Probe"); } static void handle_mpi_stop_probe() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_leave_function(MPI_PROBE_ID); char* probe_str = NULL; int src; uint32_t tag; int len; GET_PARAM_PACKED_3(CUR_EV, src, tag, len); int res __attribute__ ((__unused__)); res = asprintf(&probe_str, "src=%d, tag=%x, length=%d", src, tag, len); MPI_CHANGE() addEvent(CURRENT, "E_MPI_Probe_success", thread_id, probe_str); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); free(probe_str); } void handle_mpi_iprobe_success() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); char* probe_str = NULL; int src; uint32_t tag; int len; GET_PARAM_PACKED_3(CUR_EV, src, tag, len); int res __attribute__ ((__unused__)); res = asprintf(&probe_str, "src=%d, tag=%x, length=%d", src, tag, len); MPI_CHANGE() addEvent(CURRENT, "E_MPI_Iprobe_success", thread_id, probe_str); free(probe_str); } void handle_mpi_iprobe_failed() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); char* probe_str = NULL; int src; uint32_t tag; GET_PARAM_PACKED_2(CUR_EV, src, tag); int res __attribute__ ((__unused__)); res = asprintf(&probe_str, "src=%d, tag=%x", src, tag); MPI_CHANGE() addEvent(CURRENT, "E_MPI_Iprobe_failed", thread_id, probe_str); free(probe_str); } void __handle_cancel_mpi_request(app_ptr req) { #warning TODO struct mpi_request * mpi_req = __mpi_find_mpi_req(CUR_RANK, req, mpi_req_none); if(!mpi_req) { /* this means the request was already freed, let's skip this one */ return ; } mpi_req->status = mpi_req_status_none; } void handle_mpi_cancel() { FUNC_NAME; app_ptr req; GET_PARAM_PACKED_1(CUR_EV, req); __handle_cancel_mpi_request(req); } void handle_mpi_stop_wait() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr req; GET_PARAM_PACKED_1(CUR_EV, req); if(!__handle_mpi_test_success(req, CUR_TIME(CUR_INDEX))) return; __ezt_mpi_leave_function(MPI_WAIT_ID); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_mpi_stop_wait_failed() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr req; GET_PARAM_PACKED_1(CUR_EV, req); __handle_cancel_mpi_request(req); __ezt_mpi_leave_function(MPI_WAIT_ID); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_mpi_stop_waitany() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); int nb_reqs; int index; GET_PARAM_PACKED_2(CUR_EV, nb_reqs, index); /* process each request*/ int i; uint64_t timestamp = CUR_TIME(CUR_INDEX); for(i=0; iid, EZTRACE_MPI_Info); app_ptr mpi_req; GET_PARAM_PACKED_1(CUR_EV, mpi_req); if(index == i) { /* the successful request */ if(__handle_mpi_test_success(mpi_req, timestamp)) continue; } else { if(mpi_req == p_info->__MPI_REQUEST_NULL) continue; /* the other requests */ struct mpi_request * req = __mpi_find_pending_mpi_req(CUR_RANK, mpi_req, mpi_req_none); if (!req) { continue; } assert(req); struct mpi_p2p_msg_t* msg = __mpi_find_p2p_message_by_mpi_req(CUR_RANK, req); assert(msg); if(req->req_type == mpi_req_recv) { /* this is a receive request */ msg->times[start_rwait] = 0; } else { /* this is a send request */ msg->times[start_swait] = timestamp; } } } __ezt_mpi_leave_function(MPI_WAITANY_ID); MPI_CHANGE() popState(NS_TO_MS(timestamp), "ST_Thread", thread_id); } struct mpi_stop_waitall_replay { int nb_reqs; int i; uint64_t timestamp; app_ptr mpi_req; }; void handle_mpi_stop_waitall( struct mpi_stop_waitall_replay *r) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); int nb_reqs; if(r) nb_reqs = r->nb_reqs; else GET_PARAM_PACKED_1(CUR_EV, nb_reqs); uint64_t timestamp = CUR_TIME(CUR_INDEX); /* process each request*/ int i = 0; if(r) { i = r->i; timestamp = r->timestamp; } for(; ii == i)) { /* unless this is the replay first look, fetch next event */ wait_for_an_event(CUR_TRACE->id, EZTRACE_MPI_Info); } app_ptr mpi_req; GET_PARAM_PACKED_1(CUR_EV, mpi_req); if(r && (r->i == i)) { assert(mpi_req == r->mpi_req); } if(mpi_req == p_info->__MPI_REQUEST_NULL) continue; if(! __handle_mpi_test_success(mpi_req, timestamp)) { /* The matching isend has not occured yet. We need to wait until it happens */ struct mpi_stop_waitall_replay* replay = malloc(sizeof(struct mpi_stop_waitall_replay)); replay->nb_reqs = nb_reqs; replay->i = i; replay->mpi_req = mpi_req; replay->timestamp = timestamp; ask_for_replay(CUR_INDEX, (void (*)(void *)) handle_mpi_stop_waitall, replay); goto out; } } __ezt_mpi_leave_function(MPI_WAITALL_ID); MPI_CHANGE() popState(NS_TO_MS(timestamp), "ST_Thread", thread_id); out: if( r ) free(r); return; } void handle_mpi_test_success() { FUNC_NAME; app_ptr mpi_req; GET_PARAM_PACKED_1(CUR_EV, mpi_req); if(__handle_mpi_test_success(mpi_req, CUR_TIME(CUR_INDEX))) return; } void handle_mpi_start_BCast() { /* some collective communications won't work with communicators != COMM_WORLD * (rank in the wrong communicator used) */ FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_BCAST_ID); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_BCast"); app_ptr comm_id; int my_rank; int comm_size; int __attribute__((unused)) root; GET_PARAM_PACKED_4(CUR_EV, comm_id, comm_size, my_rank, root); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_bcast, comm, my_rank, NULL, thread_id); __mpi_barrier_start_generic(msg, my_rank); } void handle_mpi_start_Gather() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_GATHER_ID); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Gather"); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); assert(comm->my_rank == my_rank); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_gather, comm, my_rank, NULL, thread_id); __mpi_barrier_start_generic(msg, my_rank); } void handle_mpi_start_Gatherv() { handle_mpi_start_Gather(); } void handle_mpi_start_Scatter() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_SCATTER_ID); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Scatter"); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_scatter, comm, my_rank, NULL, thread_id); __mpi_barrier_start_generic(msg, my_rank); } void handle_mpi_start_Scatterv() { handle_mpi_start_Scatter(); } void handle_mpi_start_Allgather() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_ALLGATHER_ID); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Allgather"); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); assert(comm); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_allgather, comm, my_rank, NULL, thread_id); __mpi_barrier_start_generic(msg, my_rank); } void handle_mpi_start_Allgatherv() { handle_mpi_start_Allgather(); } void handle_mpi_start_Alltoall() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_ALLTOALL_ID); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Alltoall"); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_alltoall, comm, my_rank, NULL, thread_id); __mpi_barrier_start_generic(msg, my_rank); } void handle_mpi_start_Alltoallv() { handle_mpi_start_Alltoall(); } void handle_mpi_start_Reduce() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_REDUCE_ID); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Reduce"); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_reduce, comm, my_rank, NULL, thread_id); __mpi_barrier_start_generic(msg, my_rank); } void handle_mpi_start_Allreduce() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_ALLREDUCE_ID); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Allreduce"); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_allreduce, comm, my_rank, NULL, thread_id); __mpi_barrier_start_generic(msg, my_rank); } void handle_mpi_start_Reduce_scatter() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_REDUCE_SCATTER_ID); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_reduce_scatter"); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_reduce_scatter, comm, my_rank, NULL, thread_id); __mpi_barrier_start_generic(msg, my_rank); } void handle_mpi_start_Scan() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_SCAN_ID); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Scan"); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_scan, comm, my_rank, NULL, thread_id); __mpi_barrier_start_generic(msg, my_rank); } void handle_mpi_start_barrier() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); MPI_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_MPI_Barrier"); __ezt_mpi_enter_function(MPI_BARRIER_ID); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, my_rank, comm_size); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_barrier, comm, my_rank, NULL, thread_id); __mpi_barrier_start_generic(msg, my_rank); } void handle_mpi_stop_BCast() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __leave_coll(CUR_TIME(CUR_INDEX), mpi_coll_bcast, comm, my_rank, NULL, thread_id); if(__mpi_barrier_stop_generic(msg, my_rank)) /* one of the process that belong to this collective didn't reach it. * We need to wait until it reach the begining of the collective before * pursuing. */ return; __ezt_mpi_leave_function(MPI_BCAST_ID); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_mpi_stop_Gather() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); assert(comm->my_rank == my_rank); struct mpi_coll_msg_t* msg = __leave_coll(CUR_TIME(CUR_INDEX), mpi_coll_gather, comm, my_rank, NULL, thread_id); if(__mpi_barrier_stop_generic(msg, my_rank)) /* one of the process that belong to this collective didn't reach it. * We need to wait until it reach the begining of the collective before * pursuing. */ return; __ezt_mpi_leave_function(MPI_GATHER_ID); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_mpi_stop_Gatherv() { handle_mpi_stop_Gather(); } void handle_mpi_stop_Scatter() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __leave_coll(CUR_TIME(CUR_INDEX), mpi_coll_scatter, comm, my_rank, NULL, thread_id); if(__mpi_barrier_stop_generic(msg, my_rank)) /* one of the process that belong to this collective didn't reach it. * We need to wait until it reach the begining of the collective before * pursuing. */ return; __ezt_mpi_leave_function(MPI_SCATTER_ID); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_mpi_stop_Scatterv() { handle_mpi_stop_Scatter(); } void handle_mpi_stop_Allgather() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __leave_coll(CUR_TIME(CUR_INDEX), mpi_coll_allgather, comm, my_rank, NULL, thread_id); if(__mpi_barrier_stop_generic(msg, my_rank)) /* one of the process that belong to this collective didn't reach it. * We need to wait until it reach the begining of the collective before * pursuing. */ return; __ezt_mpi_leave_function(MPI_ALLGATHER_ID); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_mpi_stop_Allgatherv() { handle_mpi_stop_Allgather(); } void handle_mpi_stop_Alltoall() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __leave_coll(CUR_TIME(CUR_INDEX), mpi_coll_alltoall, comm, my_rank, NULL, thread_id); if(__mpi_barrier_stop_generic(msg, my_rank)) /* one of the process that belong to this collective didn't reach it. * We need to wait until it reach the begining of the collective before * pursuing. */ return; __ezt_mpi_leave_function(MPI_ALLTOALL_ID); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_mpi_stop_Alltoallv() { handle_mpi_stop_Alltoall(); } void handle_mpi_stop_Reduce() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __leave_coll(CUR_TIME(CUR_INDEX), mpi_coll_reduce, comm, my_rank, NULL, thread_id); if(__mpi_barrier_stop_generic(msg, my_rank)) { /* one of the process that belong to this collective didn't reach it. * We need to wait until it reach the begining of the collective before * pursuing. */ return; } __ezt_mpi_leave_function(MPI_REDUCE_ID); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_mpi_stop_Allreduce() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __leave_coll(CUR_TIME(CUR_INDEX), mpi_coll_allreduce, comm, my_rank, NULL, thread_id); if(__mpi_barrier_stop_generic(msg, my_rank)) /* one of the process that belong to this collective didn't reach it. * We need to wait until it reach the begining of the collective before * pursuing. */ return; __ezt_mpi_leave_function(MPI_ALLREDUCE_ID); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_mpi_stop_Reduce_scatter() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __leave_coll(CUR_TIME(CUR_INDEX), mpi_coll_reduce_scatter, comm, my_rank, NULL, thread_id); if(__mpi_barrier_stop_generic(msg, my_rank)) /* one of the process that belong to this collective didn't reach it. * We need to wait until it reach the begining of the collective before * pursuing. */ return; __ezt_mpi_leave_function(MPI_REDUCE_SCATTER_ID); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_mpi_stop_Scan() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, comm_size, my_rank); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __leave_coll(CUR_TIME(CUR_INDEX), mpi_coll_scan, comm, my_rank, NULL, thread_id); if(__mpi_barrier_stop_generic(msg, my_rank)) /* one of the process that belong to this collective didn't reach it. * We need to wait until it reach the begining of the collective before * pursuing. */ return; __ezt_mpi_leave_function(MPI_SCAN_ID); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } static void mpi_synchronize_processes(struct mpi_coll_msg_t* msg, int my_rank) { uint64_t my_stop_time = msg->times[my_rank][stop_coll]; int i; for(i=0; icomm[my_rank]->comm_size; i++) { if(i != my_rank) { /* search for the max(times[start_coll], my_stop_coll) */ if(msg->times[i][start_coll] > my_stop_time) { my_stop_time = msg->times[i][start_coll]; } } } /* If one of the processes arrived after process #my_rank left, there's a * synchronisation problem: we need to delay process #my_rank so that it * leaves the collective operation after all the processes arrived. */ if(my_stop_time > msg->times[my_rank][stop_coll]) { int global_rank = ezt_get_global_rank(msg->comm[my_rank], my_rank); msg->times[my_rank][stop_coll] += add_delay_to_trace(global_rank, msg->times[my_rank][stop_coll], my_stop_time, msg->thread_ids[my_rank]); } } void handle_mpi_stop_barrier() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr comm_id; int my_rank; int comm_size; GET_PARAM_PACKED_3(CUR_EV, comm_id, my_rank, comm_size); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_coll_msg_t* msg = __leave_coll(CUR_TIME(CUR_INDEX), mpi_coll_barrier, comm, my_rank, NULL, thread_id); if(__mpi_barrier_stop_generic(msg, my_rank)) /* one of the process that belong to this collective didn't reach it. * We need to wait until it reach the begining of the collective before * pursuing. */ return; mpi_synchronize_processes(msg, my_rank); __ezt_mpi_leave_function(MPI_BARRIER_ID); MPI_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } /* non-blocking collective */ void handle_mpi_Ibcast() { /* some collective communications won't work with communicators != COMM_WORLD * (rank in the wrong communicator used) */ FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_IBCAST_ID); app_ptr comm_id; int my_rank; int comm_size; app_ptr req; GET_PARAM_PACKED_4(CUR_EV, comm_id, comm_size, my_rank, req); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_request * mpi_req = __mpi_new_mpi_request(CUR_RANK, req, mpi_req_coll); assert(mpi_req); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_bcast, comm, my_rank, mpi_req, thread_id); __mpi_barrier_start_generic(msg, my_rank); MPI_CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "STV_MPI_Ibcast"); } void handle_mpi_Ibarrier() { /* some collective communications won't work with communicators != COMM_WORLD * (rank in the wrong communicator used) */ FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_IBARRIER_ID); app_ptr comm_id; int my_rank; int comm_size; app_ptr req; GET_PARAM_PACKED_4(CUR_EV, comm_id, my_rank, comm_size, req); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_request * mpi_req = __mpi_new_mpi_request(CUR_RANK, req, mpi_req_coll); assert(mpi_req); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_barrier, comm, my_rank, mpi_req, thread_id); __mpi_barrier_start_generic(msg, my_rank); MPI_CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "STV_MPI_Ibarrier"); } void handle_mpi_Igather() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_IGATHER_ID); app_ptr comm_id; int my_rank; int comm_size; app_ptr req; GET_PARAM_PACKED_4(CUR_EV, comm_id, comm_size, my_rank, req); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_request * mpi_req = __mpi_new_mpi_request(CUR_RANK, req, mpi_req_coll); assert(mpi_req); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_gather, comm, my_rank, mpi_req, thread_id); __mpi_barrier_start_generic(msg, my_rank); MPI_CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "STV_MPI_Igather"); } void handle_mpi_Igatherv() { handle_mpi_Igather(); } void handle_mpi_Iscatter() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_ISCATTER_ID); app_ptr comm_id; int my_rank; int comm_size; int len; app_ptr req; GET_PARAM_PACKED_5(CUR_EV, comm_id, comm_size, my_rank,len, req); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_request * mpi_req = __mpi_new_mpi_request(CUR_RANK, req, mpi_req_coll); assert(mpi_req); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_scatter, comm, my_rank, mpi_req, thread_id); __mpi_barrier_start_generic(msg, my_rank); MPI_CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "STV_MPI_Iscatter"); } void handle_mpi_Iscatterv() { handle_mpi_Iscatter(); } void handle_mpi_Iallgather() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_IALLGATHER_ID); app_ptr comm_id; int my_rank; int comm_size; app_ptr req; GET_PARAM_PACKED_4(CUR_EV, comm_id, comm_size, my_rank, req); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_request * mpi_req = __mpi_new_mpi_request(CUR_RANK, req, mpi_req_coll); assert(mpi_req); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_allgather, comm, my_rank, mpi_req, thread_id); __mpi_barrier_start_generic(msg, my_rank); MPI_CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "STV_MPI_Iallgather"); } void handle_mpi_Iallgatherv() { handle_mpi_Iallgather(); } void handle_mpi_Ialltoall() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_IALLTOALL_ID); app_ptr comm_id; int my_rank; int comm_size; app_ptr req; GET_PARAM_PACKED_4(CUR_EV, comm_id, comm_size, my_rank, req); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_request * mpi_req = __mpi_new_mpi_request(CUR_RANK, req, mpi_req_coll); assert(mpi_req); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_alltoall, comm, my_rank, mpi_req, thread_id); __mpi_barrier_start_generic(msg, my_rank); MPI_CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "STV_MPI_Ialltoall"); } void handle_mpi_Ialltoallv() { handle_mpi_Ialltoall(); } void handle_mpi_Ireduce() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_IREDUCE_ID); app_ptr comm_id; int my_rank; int comm_size; app_ptr req; GET_PARAM_PACKED_4(CUR_EV, comm_id, comm_size, my_rank, req); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_request * mpi_req = __mpi_new_mpi_request(CUR_RANK, req, mpi_req_coll); assert(mpi_req); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_reduce, comm, my_rank, mpi_req, thread_id); __mpi_barrier_start_generic(msg, my_rank); MPI_CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "STV_MPI_Ireduce"); } void handle_mpi_Iallreduce() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_IALLREDUCE_ID); app_ptr comm_id; int my_rank; int comm_size; app_ptr req; GET_PARAM_PACKED_4(CUR_EV, comm_id, comm_size, my_rank, req); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_request * mpi_req = __mpi_new_mpi_request(CUR_RANK, req, mpi_req_coll); assert(mpi_req); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_allreduce, comm, my_rank, mpi_req, thread_id); __mpi_barrier_start_generic(msg, my_rank); MPI_CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "STV_MPI_Iallreduce"); } void handle_mpi_Ireduce_scatter() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_IREDUCE_SCATTER_ID); app_ptr comm_id; int my_rank; int comm_size; app_ptr req; GET_PARAM_PACKED_4(CUR_EV, comm_id, comm_size, my_rank, req); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_request * mpi_req = __mpi_new_mpi_request(CUR_RANK, req, mpi_req_coll); assert(mpi_req); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_reduce_scatter, comm, my_rank, mpi_req, thread_id); __mpi_barrier_start_generic(msg, my_rank); MPI_CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "STV_MPI_Ireduce_scatter"); } void handle_mpi_Iscan() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); __ezt_mpi_enter_function(MPI_ISCAN_ID); app_ptr comm_id; int my_rank; int comm_size; app_ptr req; GET_PARAM_PACKED_4(CUR_EV, comm_id, comm_size, my_rank, req); struct ezt_mpi_comm* comm = ezt_find_communicator(CUR_INDEX, comm_id); struct mpi_request * mpi_req = __mpi_new_mpi_request(CUR_RANK, req, mpi_req_coll); assert(mpi_req); struct mpi_coll_msg_t* msg = __enter_coll(CUR_TIME(CUR_INDEX), mpi_coll_scan, comm, my_rank, mpi_req, thread_id); __mpi_barrier_start_generic(msg, my_rank); MPI_CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "STV_MPI_Iscan"); } struct mpi_coll_msg_t* __mpi_find_coll_message_by_mpi_req(int rank, struct mpi_request *mpi_req); static void handle_mpi_stop_nonblocking_collective_generic() { DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); app_ptr app_req; GET_PARAM_PACKED_1(CUR_EV, app_req); struct mpi_request * mpi_req = __mpi_find_pending_mpi_req(CUR_RANK, app_req, mpi_req_coll); assert(mpi_req); struct mpi_coll_msg_t* msg = __mpi_find_coll_message_by_mpi_req(CUR_RANK, mpi_req); assert(msg); MPI_CHANGE() popState (CURRENT, "ST_Thread", thread_id); } /* non-blocking collective */ void handle_mpi_stop_ibcast() { FUNC_NAME; __ezt_mpi_leave_function(MPI_IBCAST_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_ibarrier() { FUNC_NAME; __ezt_mpi_leave_function(MPI_IBARRIER_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_igather() { FUNC_NAME; __ezt_mpi_leave_function(MPI_IGATHER_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_igatherv() { FUNC_NAME; __ezt_mpi_leave_function(MPI_IGATHER_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_iscatter() { FUNC_NAME; __ezt_mpi_leave_function(MPI_ISCATTER_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_iscatterv() { FUNC_NAME; __ezt_mpi_leave_function(MPI_ISCATTER_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_iallgather() { FUNC_NAME; __ezt_mpi_leave_function(MPI_IALLGATHER_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_iallgatherv() { FUNC_NAME; __ezt_mpi_leave_function(MPI_IALLGATHER_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_ialltoall() { FUNC_NAME; __ezt_mpi_leave_function(MPI_IALLTOALL_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_ialltoallv() { FUNC_NAME; __ezt_mpi_leave_function(MPI_IALLTOALL_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_ireduce() { FUNC_NAME; __ezt_mpi_leave_function(MPI_IREDUCE_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_iallreduce() { FUNC_NAME; __ezt_mpi_leave_function(MPI_IALLREDUCE_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_ireduce_scatter() { FUNC_NAME; __ezt_mpi_leave_function(MPI_IREDUCE_SCATTER_ID); handle_mpi_stop_nonblocking_collective_generic(); } void handle_mpi_stop_iscan() { FUNC_NAME; __ezt_mpi_leave_function(MPI_ISCAN_ID); handle_mpi_stop_nonblocking_collective_generic(); } /* end of non-blocking collective */ void handle_mpi_spawn() { FUNC_NAME; /* This event happens when a process calls MPI_Comm_spawn * We have to: * - add the process info (PID, etc.) to the spawn_list * - create a few links */ int pid; int nb_spawned; GET_PARAM_PACKED_2(CUR_EV, pid, nb_spawned); char *link_prefix = NULL; int ret = asprintf(&link_prefix, "%s_", CUR_ID); assert(ret>=0); int i; /* add the current spawn to the list of pending spawns */ struct mpi_spawn_t *spawn = malloc(sizeof(struct mpi_spawn_t)); spawn->nb_children = nb_spawned; spawn->start_time = CUR_TIME(CUR_INDEX); spawn->ppid = pid; spawn->parent_trace = CUR_TRACE; struct ezt_list_token_t* token = malloc(sizeof(struct ezt_list_token_t)); token->data = spawn; ezt_list_add(&spawn_list, token); /* start one link per spawned process */ for(i=0; i=0); MPI_CHANGE() startLink (CURRENT, "L_MPI_SPAWN", "C_Prog", CUR_ID, NULL, link_id, link_id); free(link_id); } free(link_prefix); } void handle_mpi_send_init() { FUNC_NAME; app_ptr buffer; int len; int dest; int src = CUR_RANK; GET_PARAM_PACKED_3(CUR_EV, buffer, len, dest); wait_for_an_event(CUR_TRACE->id, EZTRACE_MPI_Info); uint32_t tag; app_ptr comm; app_ptr mpi_req; GET_PARAM_PACKED_3(CUR_EV, tag, comm, mpi_req); int actual_dest = ezt_get_global_rank_generic(CUR_INDEX, comm, dest); assert(actual_dest!= -1); struct mpi_pers_req_t __attribute__((unused)) *req = __pers_init(CURRENT, mpi_req_send, buffer, src, actual_dest, len, tag, mpi_req); DECLARE_CUR_THREAD(cur_thread); } void handle_mpi_bsend_init() { handle_mpi_send_init(); } void handle_mpi_rsend_init() { handle_mpi_send_init(); } void handle_mpi_ssend_init() { handle_mpi_send_init(); } void handle_mpi_recv_init() { FUNC_NAME; INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); app_ptr buffer; int len; int src; int dest = CUR_RANK; GET_PARAM_PACKED_3(CUR_EV, buffer, len, src); wait_for_an_event(CUR_TRACE->id, EZTRACE_MPI_Info); uint32_t tag; app_ptr comm; app_ptr mpi_req; GET_PARAM_PACKED_3(CUR_EV, tag, comm, mpi_req); int actual_src = src; if(src != p_info->__MPI_ANY_SOURCE) { actual_src = ezt_get_global_rank_generic(CUR_INDEX, comm, src); } assert(actual_src!= -1); struct mpi_pers_req_t __attribute__((unused)) *req = __pers_init(CURRENT, mpi_req_recv, buffer, actual_src, dest, len, tag, mpi_req); DECLARE_CUR_THREAD(cur_thread); } void handle_mpi_start() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(CUR_INDEX), p_info); app_ptr mpi_req; GET_PARAM_PACKED_1(CUR_EV, mpi_req); struct mpi_pers_req_t* req = __pers_start(CURRENT, CUR_RANK, mpi_req); assert(req); if(req->type == mpi_req_send) { /* todo: mpi communicator */ struct mpi_p2p_msg_t* msg = __mpi_send_generic( thread_id, CUR_RANK, req->dest, req->len, req->tag, req->mpi_req, p_info->__MPI_COMM_WORLD.comm_id); if(!msg->times[stop_isend]) msg->times[stop_isend] = CUR_TIME(CUR_INDEX); } else { struct mpi_p2p_msg_t* msg = __mpi_start_recv_generic( thread_id, req->src, CUR_RANK, req->len, req->tag, req->mpi_req, p_info->__MPI_COMM_WORLD.comm_id); if(!msg->times[stop_irecv]) msg->times[stop_irecv] = CUR_TIME(CUR_INDEX); } /* todo: add a send event here */ } int eztrace_convert_mpi_init() { if(get_mode() == EZTRACE_CONVERT) { /* Process send a message */ addEntityValue("STV_MPI_Send", "ST_Thread", "Sending", GTG_ORANGE); addEntityValue("STV_MPI_Isend", "ST_Thread", "MPI_Isend", GTG_ORANGE); addEntityValue("STV_MPI_Ibsend", "ST_Thread", "MPI_Ibsend", GTG_ORANGE); addEntityValue("STV_MPI_Issend", "ST_Thread", "MPI_Issend", GTG_ORANGE); addEntityValue("STV_MPI_Irsend", "ST_Thread", "MPI_Irsend", GTG_ORANGE); addEntityValue("STV_MPI_Sendrecv", "ST_Thread", "SendRecv", GTG_ORANGE); /* Process receive a message */ addEntityValue("STV_MPI_Recv", "ST_Thread", "Receiving", GTG_PURPLE); addEntityValue("STV_MPI_Irecv", "ST_Thread", "MPI_Irecv", GTG_PURPLE); addEntityValue("STV_MPI_Wait", "ST_Thread", "MPI_Wait", GTG_RED); addEntityValue("STV_MPI_Barrier", "ST_Thread", "MPI_Barrier", GTG_PINK); addEntityValue("STV_MPI_BCast", "ST_Thread", "MPI_BCast", GTG_PINK); addEntityValue("STV_MPI_Gather", "ST_Thread", "MPI_Gather", GTG_PINK); addEntityValue("STV_MPI_Scatter", "ST_Thread", "MPI_Scatter", GTG_PINK); addEntityValue("STV_MPI_Allgather", "ST_Thread", "MPI_Allgather", GTG_PINK); addEntityValue("STV_MPI_Alltoall", "ST_Thread", "MPI_Alltoall", GTG_PINK); addEntityValue("STV_MPI_Reduce", "ST_Thread", "MPI_Reduce", GTG_PINK); addEntityValue("STV_MPI_Allreduce", "ST_Thread", "MPI_Allreduce", GTG_PINK); addEntityValue("STV_MPI_reduce_scatter", "ST_Thread", "MPI_Reduce_scatter", GTG_PINK); addEntityValue("STV_MPI_Scan", "ST_Thread", "MPI_Scan", GTG_PINK); addEntityValue("STV_MPI_Ibarrier", "ST_Thread", "MPI_Ibarrier", GTG_PINK); addEntityValue("STV_MPI_Ibcast", "ST_Thread", "MPI_Ibcast", GTG_PINK); addEntityValue("STV_MPI_Igather", "ST_Thread", "MPI_Igather", GTG_PINK); addEntityValue("STV_MPI_Iscatter", "ST_Thread", "MPI_Iscatter", GTG_PINK); addEntityValue("STV_MPI_Iallgather", "ST_Thread", "MPI_Iallgather", GTG_PINK); addEntityValue("STV_MPI_Ialltoall", "ST_Thread", "MPI_Ialltoall", GTG_PINK); addEntityValue("STV_MPI_Ireduce", "ST_Thread", "MPI_Ireduce", GTG_PINK); addEntityValue("STV_MPI_Iallreduce", "ST_Thread", "MPI_Iallreduce", GTG_PINK); addEntityValue("STV_MPI_Ireduce_scatter", "ST_Thread", "MPI_Ireduce_scatter", GTG_PINK); addEntityValue("STV_MPI_Iscan", "ST_Thread", "MPI_Iscan", GTG_PINK); addEntityValue("STV_MPI_Probe", "ST_Thread", "MPI_Probe", GTG_PURPLE); addLinkType ("L_MPI_Coll", "MPI collective communication", "CT_Program", "CT_Thread", "CT_Thread"); addLinkType ("L_MPI_P2P", "MPI point to point communication", "CT_Program", "CT_Thread", "CT_Thread"); addLinkType ("L_MPI_SPAWN", "MPI SPAWN", "CT_Program", "CT_Thread", "CT_Thread"); addEventType ("E_MPI_CommSend", "CT_Thread", "MPI Send"); addEventType ("E_MPI_CommRecv", "CT_Thread", "MPI Recv"); addEventType ("E_MPI_EndComm", "CT_Thread", "End of an MPI communication"); addEventType ("E_MPI_Probe_success", "CT_Thread", "MPI_Probe"); addEventType ("E_MPI_Iprobe_success", "CT_Thread", "MPI_IProbe success"); addEventType ("E_MPI_Iprobe_failed", "CT_Thread", "MPI_IProbe failed"); } ezt_list_new(&spawn_list); init_mpi_pers_messages(); init_mpi_p2p_messages(); init_mpi_coll_messages(); init_mpi_stats(); return 0; } /* return 1 if the event was handled */ int handle_mpi_events(eztrace_event_t *ev) { switch (LITL_READ_GET_CODE(ev)) { case EZTRACE_MPI_INIT: handle_mpi_init (); break; case EZTRACE_MPI_DELETE_COMM: handle_mpi_delete_comm (); break; case EZTRACE_MPI_NEW_COMM: handle_mpi_new_comm (); break; case EZTRACE_MPI_START_SEND: nb_mpi_calls[MPI_SEND_ID]++; handle_mpi_start_send (); break; case EZTRACE_MPI_STOP_SEND: handle_mpi_stop_send (); break; case EZTRACE_MPI_START_RECV: nb_mpi_calls[MPI_RECV_ID]++; handle_mpi_start_recv (); break; case EZTRACE_MPI_STOP_RECV: handle_mpi_stop_recv (); break; case EZTRACE_MPI_CANCEL: handle_mpi_cancel (); break; case EZTRACE_MPI_START_SENDRECV: nb_mpi_calls[MPI_SENDRECV_ID]++; handle_mpi_start_sendrecv (); break; case EZTRACE_MPI_STOP_SENDRECV: handle_mpi_stop_sendrecv (); break; case EZTRACE_MPI_START_SENDRECV_REPLACE: nb_mpi_calls[MPI_SENDRECV_REPLACE_ID]++; handle_mpi_start_sendrecv_replace (); break; case EZTRACE_MPI_STOP_SENDRECV_REPLACE: handle_mpi_stop_sendrecv_replace (); break; case EZTRACE_MPI_START_BSEND: nb_mpi_calls[MPI_BSEND_ID]++; handle_mpi_start_bsend (); break; case EZTRACE_MPI_STOP_BSEND: handle_mpi_stop_bsend (); break; case EZTRACE_MPI_START_SSEND: nb_mpi_calls[MPI_SSEND_ID]++; handle_mpi_start_ssend (); break; case EZTRACE_MPI_STOP_SSEND: handle_mpi_stop_ssend (); break; case EZTRACE_MPI_START_RSEND: nb_mpi_calls[MPI_RSEND_ID]++; handle_mpi_start_rsend (); break; case EZTRACE_MPI_STOP_RSEND: handle_mpi_stop_rsend (); break; case EZTRACE_MPI_ISEND: nb_mpi_calls[MPI_ISEND_ID]++; handle_mpi_isend (); break; case EZTRACE_MPI_IBSEND: nb_mpi_calls[MPI_IBSEND_ID]++; handle_mpi_ibsend (); break; case EZTRACE_MPI_ISSEND: nb_mpi_calls[MPI_ISSEND_ID]++; handle_mpi_issend (); break; case EZTRACE_MPI_IRSEND: nb_mpi_calls[MPI_IRSEND_ID]++; handle_mpi_irsend (); break; case EZTRACE_MPI_IRECV: nb_mpi_calls[MPI_IRECV_ID]++; handle_mpi_irecv (); break; case EZTRACE_MPI_STOP_IRECV: handle_mpi_stop_irecv (); break; case EZTRACE_MPI_STOP_ISEND: handle_mpi_stop_isend (); break; case EZTRACE_MPI_STOP_IBSEND: handle_mpi_stop_ibsend (); break; case EZTRACE_MPI_STOP_ISSEND: handle_mpi_stop_issend (); break; case EZTRACE_MPI_STOP_IRSEND: handle_mpi_stop_irsend (); break; case EZTRACE_MPI_START_PUT: nb_mpi_calls[MPI_PUT_ID]++; handle_mpi_start_put(); break; case EZTRACE_MPI_STOP_PUT: handle_mpi_stop_put(); break; case EZTRACE_MPI_START_GET: nb_mpi_calls[MPI_GET_ID]++; handle_mpi_start_get(); break; case EZTRACE_MPI_STOP_GET: handle_mpi_stop_get(); break; case EZTRACE_MPI_START_WAIT: nb_mpi_calls[MPI_WAIT_ID]++; handle_mpi_start_wait(); break; case EZTRACE_MPI_STOP_WAIT: handle_mpi_stop_wait(); break; case EZTRACE_MPI_STOP_WAIT_FAILED: handle_mpi_stop_wait_failed(); break; case EZTRACE_MPI_START_WAITANY: nb_mpi_calls[MPI_WAITANY_ID]++; handle_mpi_start_waitany(); break; case EZTRACE_MPI_STOP_WAITANY: handle_mpi_stop_waitany(); break; case EZTRACE_MPI_START_WAITALL: nb_mpi_calls[MPI_WAITALL_ID]++; handle_mpi_start_waitall(); break; case EZTRACE_MPI_STOP_WAITALL: handle_mpi_stop_waitall(NULL); break; case EZTRACE_MPI_TEST_SUCCESS: nb_mpi_calls[MPI_TEST_ID]++; handle_mpi_test_success(); break; case EZTRACE_MPI_START_PROBE: nb_mpi_calls[MPI_PROBE_ID]++; handle_mpi_start_probe(); break; case EZTRACE_MPI_STOP_PROBE: handle_mpi_stop_probe(); break; case EZTRACE_MPI_IPROBE_SUCCESS: nb_mpi_calls[MPI_IPROBE_ID]++; handle_mpi_iprobe_success(); break; case EZTRACE_MPI_IPROBE_FAILED: handle_mpi_iprobe_failed(); break; case EZTRACE_MPI_START_BCast: nb_mpi_calls[MPI_BCAST_ID]++; handle_mpi_start_BCast(); break; case EZTRACE_MPI_START_Gather: nb_mpi_calls[MPI_GATHER_ID]++; handle_mpi_start_Gather(); break; case EZTRACE_MPI_START_Gatherv: nb_mpi_calls[MPI_GATHERV_ID]++; handle_mpi_start_Gatherv(); break; case EZTRACE_MPI_START_Scatter: nb_mpi_calls[MPI_SCATTER_ID]++; handle_mpi_start_Scatter(); break; case EZTRACE_MPI_START_Scatterv: nb_mpi_calls[MPI_SCATTERV_ID]++; handle_mpi_start_Scatterv(); break; case EZTRACE_MPI_START_Allgather: nb_mpi_calls[MPI_ALLGATHER_ID]++; handle_mpi_start_Allgather(); break; case EZTRACE_MPI_START_Allgatherv: nb_mpi_calls[MPI_ALLGATHERV_ID]++; handle_mpi_start_Allgatherv(); break; case EZTRACE_MPI_START_Alltoall: nb_mpi_calls[MPI_ALLTOALL_ID]++; handle_mpi_start_Alltoall(); break; case EZTRACE_MPI_START_Alltoallv: nb_mpi_calls[MPI_ALLTOALLV_ID]++; handle_mpi_start_Alltoallv(); break; case EZTRACE_MPI_START_Reduce: nb_mpi_calls[MPI_REDUCE_ID]++; handle_mpi_start_Reduce(); break; case EZTRACE_MPI_START_Allreduce: nb_mpi_calls[MPI_ALLREDUCE_ID]++; handle_mpi_start_Allreduce(); break; case EZTRACE_MPI_START_Reduce_scatter: nb_mpi_calls[MPI_REDUCE_SCATTER_ID]++; handle_mpi_start_Reduce_scatter(); break; case EZTRACE_MPI_START_Scan: nb_mpi_calls[MPI_SCAN_ID]++; handle_mpi_start_Scan(); break; case EZTRACE_MPI_START_BARRIER: nb_mpi_calls[MPI_BARRIER_ID]++; handle_mpi_start_barrier(); break; case EZTRACE_MPI_STOP_BCast : handle_mpi_stop_BCast(); break; case EZTRACE_MPI_STOP_Gather : handle_mpi_stop_Gather(); break; case EZTRACE_MPI_STOP_Gatherv : handle_mpi_stop_Gatherv(); break; case EZTRACE_MPI_STOP_Scatter : handle_mpi_stop_Scatter(); break; case EZTRACE_MPI_STOP_Scatterv : handle_mpi_stop_Scatterv(); break; case EZTRACE_MPI_STOP_Allgather : handle_mpi_stop_Allgather(); break; case EZTRACE_MPI_STOP_Allgatherv : handle_mpi_stop_Allgatherv(); break; case EZTRACE_MPI_STOP_Alltoall : handle_mpi_stop_Alltoall(); break; case EZTRACE_MPI_STOP_Alltoallv : handle_mpi_stop_Alltoallv(); break; case EZTRACE_MPI_STOP_Reduce : handle_mpi_stop_Reduce(); break; case EZTRACE_MPI_STOP_Allreduce : handle_mpi_stop_Allreduce(); break; case EZTRACE_MPI_STOP_Reduce_scatter : handle_mpi_stop_Reduce_scatter(); break; case EZTRACE_MPI_STOP_Scan : handle_mpi_stop_Scan(); break; case EZTRACE_MPI_STOP_BARRIER : handle_mpi_stop_barrier(); break; case EZTRACE_MPI_IBCAST: nb_mpi_calls[MPI_IBCAST_ID]++; handle_mpi_Ibcast(); break; case EZTRACE_MPI_IGATHER: nb_mpi_calls[MPI_IGATHER_ID]++; handle_mpi_Igather(); break; case EZTRACE_MPI_IGATHERV: nb_mpi_calls[MPI_IGATHERV_ID]++; handle_mpi_Igatherv(); break; case EZTRACE_MPI_ISCATTER: nb_mpi_calls[MPI_ISCATTER_ID]++; handle_mpi_Iscatter(); break; case EZTRACE_MPI_ISCATTERV: nb_mpi_calls[MPI_ISCATTERV_ID]++; handle_mpi_Iscatterv(); break; case EZTRACE_MPI_IALLGATHER: nb_mpi_calls[MPI_IALLGATHER_ID]++; handle_mpi_Iallgather(); break; case EZTRACE_MPI_IALLGATHERV: nb_mpi_calls[MPI_IALLGATHERV_ID]++; handle_mpi_Iallgatherv(); break; case EZTRACE_MPI_IALLTOALL: nb_mpi_calls[MPI_IALLTOALL_ID]++; handle_mpi_Ialltoall(); break; case EZTRACE_MPI_IALLTOALLV: nb_mpi_calls[MPI_IALLTOALLV_ID]++; handle_mpi_Ialltoallv(); break; case EZTRACE_MPI_IREDUCE: nb_mpi_calls[MPI_IREDUCE_ID]++; handle_mpi_Ireduce(); break; case EZTRACE_MPI_IALLREDUCE: nb_mpi_calls[MPI_IALLREDUCE_ID]++; handle_mpi_Iallreduce(); break; case EZTRACE_MPI_IREDUCE_SCATTER: nb_mpi_calls[MPI_IREDUCE_SCATTER_ID]++; handle_mpi_Ireduce_scatter(); break; case EZTRACE_MPI_ISCAN: nb_mpi_calls[MPI_ISCAN_ID]++; handle_mpi_Iscan(); break; case EZTRACE_MPI_IBARRIER: nb_mpi_calls[MPI_IBARRIER_ID]++; handle_mpi_Ibarrier(); break; case EZTRACE_MPI_STOP_IBCAST: handle_mpi_stop_ibcast(); break; case EZTRACE_MPI_STOP_IGATHER: handle_mpi_stop_igather(); break; case EZTRACE_MPI_STOP_IGATHERV: handle_mpi_stop_igatherv(); break; case EZTRACE_MPI_STOP_ISCATTER: handle_mpi_stop_iscatter(); break; case EZTRACE_MPI_STOP_ISCATTERV: handle_mpi_stop_iscatterv(); break; case EZTRACE_MPI_STOP_IALLGATHER: handle_mpi_stop_iallgather(); break; case EZTRACE_MPI_STOP_IALLGATHERV: handle_mpi_stop_iallgatherv(); break; case EZTRACE_MPI_STOP_IALLTOALL: handle_mpi_stop_ialltoall(); break; case EZTRACE_MPI_STOP_IALLTOALLV: handle_mpi_stop_ialltoallv(); break; case EZTRACE_MPI_STOP_IREDUCE: handle_mpi_stop_ireduce(); break; case EZTRACE_MPI_STOP_IALLREDUCE: handle_mpi_stop_iallreduce(); break; case EZTRACE_MPI_STOP_IREDUCE_SCATTER: handle_mpi_stop_ireduce_scatter(); break; case EZTRACE_MPI_STOP_ISCAN: handle_mpi_stop_iscan(); break; case EZTRACE_MPI_STOP_IBARRIER: handle_mpi_stop_ibarrier(); break; case EZTRACE_MPI_SPAWN : handle_mpi_spawn(); break; case EZTRACE_MPI_SPAWNED : handle_mpi_spawned(); break; case EZTRACE_MPI_SEND_INIT: handle_mpi_send_init(); break; case EZTRACE_MPI_BSEND_INIT: handle_mpi_bsend_init(); break; case EZTRACE_MPI_RSEND_INIT: handle_mpi_rsend_init(); break; case EZTRACE_MPI_SSEND_INIT: handle_mpi_ssend_init(); break; case EZTRACE_MPI_RECV_INIT: handle_mpi_recv_init(); break; case EZTRACE_MPI_START: nb_mpi_calls[MPI_START_ID]++; handle_mpi_start(); break; default: return 0; } return 1; } int handle_mpi_stats(eztrace_event_t *ev) { recording_stats = 1; return handle_mpi_events(ev); } #define FORMAT_BYTES(nb_bytes) \ ((uint64_t)nb_bytes<1024?"B": \ ((uint64_t)nb_bytes<1024*1024?"KB": \ ((uint64_t)nb_bytes<1024*1024*1024?"MB": \ ((uint64_t)nb_bytes<(uint64_t)1024*1024*1024*1024?"GB": \ ((uint64_t)nb_bytes<(uint64_t)1024*1024*1024*1024*1024?"TB": \ "PB"))))) float VALUE_BYTES(uint64_t nb_bytes) { int i; uint64_t div=1; for(i=0; i<6; i++) { if((nb_bytes/div)<1024) return (nb_bytes/(double)div); div*=1024; } return (float)nb_bytes; } void print_mpi_stats() { printf ( "\nMPI:\n"); printf ( "---\n"); /* todo: * add: * - communication pattern (matrix) * - min/max/average message length * - min/max/average communication duration */ int i; #if 0 /* Print the of mpi_send, isend, issend, bcast, gather, scatter etc. */ for(i=0; inb_children; thread_id++) { struct eztrace_container_t *p_thread = process_cont->children[thread_id]; struct thread_info_t* thread_info = (struct thread_info_t*) (p_thread->container_info); INIT_MPI_THREAD_INFO(thread_info, mpi_info); int should_print = 0; double mpi_duration = 0; for(i=0; inb_mpi_calls[i]) { should_print = 1 ; mpi_duration += mpi_info->total_time_mpi_calls[i]; } } if(!should_print) continue; double thread_duration = p_thread->end_timestamp - p_thread->start_timestamp; printf("Thread %s -- total duration: %lf ms, time spent in mpi: %lf ms (%lf %%)\n", p_thread->name, thread_duration, mpi_duration, 100*mpi_duration/thread_duration); /* Print the of mpi_send, isend, issend, bcast, gather, scatter etc. */ for(i=0; inb_mpi_calls[i]) { printf("\t"); switch(i) { case MPI_SEND_ID : printf("MPI_SEND :"); break; case MPI_RECV_ID : printf("MPI_RECV :"); break; case MPI_BSEND_ID : printf("MPI_BSEND :"); break; case MPI_SSEND_ID : printf("MPI_SSEND :"); break; case MPI_RSEND_ID : printf("MPI_RSEND :"); break; case MPI_ISEND_ID : printf("MPI_ISEND :"); break; case MPI_IBSEND_ID : printf("MPI_IBSEND :"); break; case MPI_ISSEND_ID : printf("MPI_ISSEND :"); break; case MPI_IRSEND_ID : printf("MPI_IRSEND :"); break; case MPI_IRECV_ID : printf("MPI_IRECV :"); break; case MPI_SENDRECV_ID : printf("MPI_SENDRECV :"); break; case MPI_SENDRECV_REPLACE_ID : printf("MPI_SENDRECV_REPLACE :"); break; case MPI_START_ID : printf("MPI_START :"); break; case MPI_STARTALL_ID : printf("MPI_STARTALL :"); break; case MPI_WAIT_ID : printf("MPI_WAIT :"); break; case MPI_TEST_ID : printf("MPI_TEST :"); break; case MPI_WAITANY_ID : printf("MPI_WAITANY :"); break; case MPI_TESTANY_ID : printf("MPI_TESTANY :"); break; case MPI_WAITALL_ID : printf("MPI_WAITALL :"); break; case MPI_TESTALL_ID : printf("MPI_TESTALL :"); break; case MPI_WAITSOME_ID : printf("MPI_WAITSOME :"); break; case MPI_TESTSOME_ID : printf("MPI_TESTSOME :"); break; case MPI_PROBE_ID : printf("MPI_PROBE :"); break; case MPI_IPROBE_ID : printf("MPI_IPROBE :"); break; case MPI_BARRIER_ID : printf("MPI_BARRIER :"); break; case MPI_BCAST_ID : printf("MPI_BCAST :"); break; case MPI_GATHER_ID : printf("MPI_GATHER :"); break; case MPI_GATHERV_ID : printf("MPI_GATHERV :"); break; case MPI_SCATTER_ID : printf("MPI_SCATTER :"); break; case MPI_SCATTERV_ID : printf("MPI_SCATTERV :"); break; case MPI_ALLGATHER_ID : printf("MPI_ALLGATHER :"); break; case MPI_ALLGATHERV_ID : printf("MPI_ALLGATHERV :"); break; case MPI_ALLTOALL_ID : printf("MPI_ALLTOALL :"); break; case MPI_ALLTOALLV_ID : printf("MPI_ALLTOALLV :"); break; case MPI_REDUCE_ID : printf("MPI_REDUCE :"); break; case MPI_ALLREDUCE_ID : printf("MPI_ALLREDUCE :"); break; case MPI_REDUCE_SCATTER_ID : printf("MPI_REDUCE_SCATTER :"); break; case MPI_SCAN_ID : printf("MPI_SCAN :"); break; case MPI_IBARRIER_ID : printf("MPI_IBARRIER :"); break; case MPI_IBCAST_ID : printf("MPI_IBCAST :"); break; case MPI_IGATHER_ID : printf("MPI_IGATHER :"); break; case MPI_IGATHERV_ID : printf("MPI_IGATHERV :"); break; case MPI_ISCATTER_ID : printf("MPI_ISCATTER :"); break; case MPI_ISCATTERV_ID : printf("MPI_ISCATTERV :"); break; case MPI_IALLGATHER_ID : printf("MPI_IALLGATHER :"); break; case MPI_IALLGATHERV_ID : printf("MPI_IALLGATHERV :"); break; case MPI_IALLTOALL_ID : printf("MPI_IALLTOALL :"); break; case MPI_IALLTOALLV_ID : printf("MPI_IALLTOALLV :"); break; case MPI_IREDUCE_ID : printf("MPI_IREDUCE :"); break; case MPI_IALLREDUCE_ID : printf("MPI_IALLREDUCE :"); break; case MPI_IREDUCE_SCATTER_ID : printf("MPI_IREDUCE_SCATTER :"); break; case MPI_ISCAN_ID : printf("MPI_ISCAN :"); break; case MPI_GET_ID : printf("MPI_GET :"); break; case MPI_PUT_ID : printf("MPI_PUT :"); break; } printf("%d calls -- %lf ms (%lf %% of the thread runtime)\n", mpi_info->nb_mpi_calls[i], mpi_info->total_time_mpi_calls[i], 100*mpi_info->total_time_mpi_calls[i]/thread_duration); } } } } #endif printf("\n"); print_p2p_stats(); printf("\n"); mpi_stats_plot_message_size(); printf("\n"); } #define QUOTE(name) #name #define STR(macro) QUOTE(macro) #ifndef MPI_MODULE_NAME #define MPI_MODULE_NAME mpi #endif #define MPI_MODULE_NAME_STR STR(MPI_MODULE_NAME) struct eztrace_convert_module mpi_module; void libinit(void) __attribute__ ((constructor)); void libinit(void) { mpi_module.api_version = EZTRACE_API_VERSION; mpi_module.init = eztrace_convert_mpi_init; mpi_module.handle = handle_mpi_events; mpi_module.handle_stats = handle_mpi_stats; mpi_module.print_stats = print_mpi_stats; mpi_module.module_prefix = EZTRACE_MPI_EVENTS_ID; int res __attribute__ ((__unused__)); res = asprintf(&mpi_module.name, MPI_MODULE_NAME_STR); res = asprintf(&mpi_module.description, "Module for MPI functions"); mpi_module.token.data = &mpi_module; eztrace_convert_register_module(&mpi_module); int i; for(i=0; i #include "eztrace_convert.h" #include "mpi_eztrace.h" /* Different kinds of MPI messages */ enum MPI_MSG_TYPE { mpi_msg_type_p2p, mpi_msg_type_coll, }; enum comm_type_t { comm_type_incoming = 0, /* pending recv */ comm_type_outgoing = 1, /* pending send */ comm_type_collective = 2, /* pending collective */ comm_type_max = 3, }; struct mpi_process_info_t; struct ezt_mpi_comm { struct ezt_list_token_t token; app_ptr comm_id; int comm_size; /* number of participants in this communicator */ int *ranks; /* global ranks for each participant to this communicator */ int my_rank; /* rank of the process in this communicator */ struct mpi_process_info_t *p_process; }; /* return 1 if comm1==comm2 */ static __attribute__ ((unused)) int __ezt_mpi_communicator_are_equal(struct ezt_mpi_comm *comm1, struct ezt_mpi_comm *comm2){ if(comm1 == comm2) return 1; if(comm1->comm_size != comm2->comm_size) return 0; /* compare each rank */ int i; for(i=0; icomm_size; i++) { if(comm1->ranks[i] != comm2->ranks[i]) { return 0; } } /* the communicators have the same size and the ranks match */ return 1; } typedef enum { MPI_SEND_ID , MPI_RECV_ID , MPI_BSEND_ID , MPI_SSEND_ID , MPI_RSEND_ID , MPI_ISEND_ID , MPI_IBSEND_ID , MPI_ISSEND_ID , MPI_IRSEND_ID , MPI_IRECV_ID , MPI_SENDRECV_ID , MPI_SENDRECV_REPLACE_ID , MPI_START_ID , MPI_STARTALL_ID , MPI_WAIT_ID , MPI_TEST_ID , MPI_WAITANY_ID , MPI_TESTANY_ID , MPI_WAITALL_ID , MPI_TESTALL_ID , MPI_WAITSOME_ID , MPI_TESTSOME_ID , MPI_PROBE_ID , MPI_IPROBE_ID , MPI_BARRIER_ID , MPI_BCAST_ID , MPI_GATHER_ID , MPI_GATHERV_ID , MPI_SCATTER_ID , MPI_SCATTERV_ID , MPI_ALLGATHER_ID , MPI_ALLGATHERV_ID , MPI_ALLTOALL_ID , MPI_ALLTOALLV_ID , MPI_REDUCE_ID , MPI_ALLREDUCE_ID , MPI_REDUCE_SCATTER_ID , MPI_SCAN_ID , MPI_IBARRIER_ID , MPI_IBCAST_ID , MPI_IGATHER_ID , MPI_IGATHERV_ID , MPI_ISCATTER_ID , MPI_ISCATTERV_ID , MPI_IALLGATHER_ID , MPI_IALLGATHERV_ID , MPI_IALLTOALL_ID , MPI_IALLTOALLV_ID , MPI_IREDUCE_ID , MPI_IALLREDUCE_ID , MPI_IREDUCE_SCATTER_ID , MPI_ISCAN_ID , MPI_GET_ID , MPI_PUT_ID , MPI_ID_SIZE } MPI_id_t; /* MPI information on each thread */ struct mpi_thread_info_t { struct thread_info_t *p_thread; unsigned nb_mpi_calls[MPI_ID_SIZE]; double total_time_mpi_calls[MPI_ID_SIZE]; double enter_date_mpi_calls[MPI_ID_SIZE]; /* timestamp when the thread entered an MPI function */ double leave_date_mpi_calls[MPI_ID_SIZE]; /* timestamp when the thread left an MPI function */ }; /* Each process has a list of pending isend/irecv */ struct mpi_process_info_t { struct ezt_list_t pending_comm[comm_type_max]; struct process_info_t *p_process; struct ezt_list_t communicators; struct ezt_list_t deleted_communicators; int __MPI_ANY_SOURCE; /* Value of MPI_ANY_SOURCE */ uint32_t __MPI_ANY_TAG; /* Value of MPI_ANY_TAG */ app_ptr __MPI_REQUEST_NULL; /* value of MPI_REQUEST_NULL */ int __MPI_PROC_NULL; /*Value of MPI_PROC_NULL */ struct ezt_mpi_comm __MPI_COMM_WORLD; /* value of MPI_COMM_WORLD */ struct ezt_mpi_comm __MPI_COMM_SELF; /* value of MPI_COMM_SELF */ }; /* todo: remove this struct */ union mpi_msg { struct { enum { mpi_p2p_msg_send, mpi_p2p_msg_recv } p2p_type; } p2p; struct { enum { mpi_coll_msg_barrier, mpi_coll_msg_bcast /* todo: add other kinds of collective operations */ } coll_type; } coll; }; enum mpi_request_type{ mpi_req_none, mpi_req_send, mpi_req_coll, mpi_req_recv }; enum mpi_request_status { mpi_req_status_none, mpi_req_status_pending }; struct mpi_request { app_ptr ptr; struct eztrace_container_t* container; enum mpi_request_type req_type; struct mpi_p2p_msg_t *msg; struct mpi_coll_msg_t *coll_msg; enum mpi_request_status status; }; enum p2p_time_ids { start_isend = 0, stop_isend = 1, start_swait = 2, stop_send = 3, start_irecv = 4, stop_irecv = 5, start_rwait = 6, stop_recv = 7, P2P_NB_TIMES }; struct mpi_p2p_msg_t { char*id; int src; int dest; int len; uint32_t tag; int unexp; /* set to 1 if the recv is detected before the send */ uint64_t times[P2P_NB_TIMES]; char* link_value; const char* sender_thread_id; const struct mpi_request* sender_request; const char* recver_thread_id; const struct mpi_request* recver_request; }; enum coll_type_t { mpi_coll_barrier, mpi_coll_bcast, mpi_coll_gather, mpi_coll_scatter, mpi_coll_allgather, mpi_coll_alltoall, mpi_coll_reduce, mpi_coll_allreduce, mpi_coll_reduce_scatter, mpi_coll_scan, /* todo: add other kinds of collective operations */ }; enum coll_time_ids { start_coll = 0, stop_coll = 2, COLL_NB_TIMES }; struct mpi_coll_msg_t { enum coll_type_t type; uint64_t** times; int comm_size; int nb_started; struct ezt_mpi_comm **comm; char***link_id; char*** link_value; int unexp; /* todo: useless ? */ char** thread_ids; struct mpi_request **requests; }; /* This structure contains information about a MPI message in the global view (ie. it is valid no matter which process acces it) */ /* todo: cleanup this mess. some fields are only used for p2p messages ! */ struct mpi_msg_t { char* id; enum MPI_MSG_TYPE msg_type; union mpi_msg msg; int src; int dest; int len; int unexp; /* set to 1 if the recv is detected before the send */ uint32_t tag; uint64_t send_time; uint64_t recv_time; uint64_t start_wait_time; char* link_value; char* threadstr; }; /* This structure contains information about a MPI_COMM_SPAWN */ struct mpi_spawn_t { int nb_children; /* number of processes spawned */ uint64_t start_time; /* date at which MPI_COMM_SPAWN was invoked */ int ppid; /* parent process id */ struct trace_t *parent_trace; }; /* This structure contains information on a persistent request */ struct mpi_pers_req_t { int process_id; enum mpi_request_type type; app_ptr buffer; int len; int src; int dest; uint32_t tag; struct mpi_request* mpi_req; }; /* This structure contains informations on a MPI request. * it is only valid for one process (cf the rank field) */ struct __mpi_request_t { struct mpi_msg_t *msg; /* pointer to the message corresponding to this request */ union mpi_msg type; app_ptr req; /* address of the request in the MPI process */ int rank; /* the rank of the MPI process that uses this req */ }; /* This structure contains relevant informations used in the * communication matrix */ struct comm_info { int nb; int src; int dest; uint64_t size; }; struct message_size { int nb; int size; }; /* generate a MPI message id */ #define CREATE_P2P_MSG_ID(msg) \ {int __attribute__((unused)) ret = asprintf(&msg->id, "%d_%d_%20u_%p", msg->src, msg->dest, msg->tag, msg);} /* generate the value of a p2p link */ #define CREATE_P2P_LINK_VALUE(msg) \ { int __attribute__((unused)) ret = asprintf(&(msg)->link_value, "src=%d, dest=%d, len=%d, tag=%x", \ (msg)->src, (msg)->dest, (msg)->len, (msg)->tag);} /* generate the value of a coll link */ #define CREATE_COLL_MSG_ID(_msg_, _src_, _dest_) \ { int __attribute__((unused)) ret = asprintf(&(msg)->link_id[_src_][_dest_], "%d_%d_%p", _src_, _dest_, _msg_); } #define CREATE_COLL_LINK_VALUE(_str_, _src_, _dest_) \ { int __attribute__((unused))ret = asprintf(&(_str_)->link_value[_src_][_dest_], "src=%d, dest=%d", \ _src_, _dest_); } static inline struct comm_info *__create_comm_info(int src, int dest, int size, int nb) { struct comm_info *msg = (struct comm_info*) malloc(sizeof(struct comm_info)); msg->src = src; msg->dest = dest; msg->size = size; msg->nb = nb; return msg; } static inline struct message_size *__create_message_size(int size, int nb) { struct message_size *msg = (struct message_size*) malloc( sizeof(struct message_size)); msg->size = size; msg->nb = nb; return msg; } /* attach process-specific data to a process when it's created */ static struct mpi_process_info_t* __register_process_hook( struct process_info_t* p_process) { struct mpi_process_info_t *p_info = (struct mpi_process_info_t*) malloc( sizeof(struct mpi_process_info_t)); p_info->p_process = p_process; int i; for (i = 0; i < comm_type_max; i++) ezt_list_new(&p_info->pending_comm[i]); p_info->__MPI_ANY_SOURCE = -1; /* Value of MPI_ANY_SOURCE */ p_info->__MPI_ANY_TAG = -1; /* Value of MPI_ANY_TAG */ p_info->__MPI_REQUEST_NULL = (app_ptr) -1; /* value of MPI_REQUEST_NULL */ p_info->__MPI_COMM_WORLD.comm_id = (app_ptr) -1; /* value of MPI_COMM_WORLD */ p_info->__MPI_COMM_SELF.comm_id = (app_ptr) -1; /* value of MPI_COMM_SELF */ /* add the hook in the thread info structure */ ezt_hook_list_add(&p_info->p_process->hooks, p_info, (uint8_t) EZTRACE_MPI_EVENTS_ID); return p_info; } /* attach thread-specific data to a thread when it's created */ static struct mpi_thread_info_t* __register_thread_hook( struct thread_info_t* p_thread) { struct mpi_thread_info_t *p_info = (struct mpi_thread_info_t*) malloc( sizeof(struct mpi_thread_info_t)); p_info->p_thread = p_thread; int i; for(i=0; inb_mpi_calls[i] = 0; p_info->total_time_mpi_calls[i] = 0; p_info->enter_date_mpi_calls[i] = 0; p_info->leave_date_mpi_calls[i] = 0; } /* add the hook in the thread info structure */ ezt_hook_list_add(&p_info->p_thread->hooks, p_info, (uint8_t) EZTRACE_MPI_EVENTS_ID); return p_info; } #define INIT_MPI_PROCESS_INFO(p_process, var) \ struct mpi_process_info_t *var = (struct mpi_process_info_t*) \ ezt_hook_list_retrieve_data(&p_process->hooks, (uint8_t)EZTRACE_MPI_EVENTS_ID); \ if(!(var)) { \ var = __register_process_hook(p_process); \ } #define INIT_MPI_THREAD_INFO(p_thread, var) \ struct mpi_thread_info_t *var = (struct mpi_thread_info_t*) \ ezt_hook_list_retrieve_data(&p_thread->hooks, (uint8_t)EZTRACE_MPI_EVENTS_ID); \ if(!(var)) { \ var = __register_thread_hook(p_thread); \ } static inline int ezt_get_global_rank_generic(int trace_id, app_ptr comm, int local_rank) { INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(trace_id), p_info); if (p_info->__MPI_COMM_WORLD.comm_id == comm) return local_rank; if (p_info->__MPI_COMM_SELF.comm_id == comm) return trace_id; /* the communicator in use isn't MPI_COMM_WORLD, * let's browse the list */ struct ezt_list_token_t *token; ezt_list_foreach(&p_info->communicators, token) { struct ezt_mpi_comm* p_comm = (struct ezt_mpi_comm*) token->data; assert(p_comm); if (p_comm->comm_id == comm) { /* we found the communicator ! */ assert(p_comm->comm_size > local_rank); return p_comm->ranks[local_rank]; } } return -1; } static inline int ezt_get_global_rank(struct ezt_mpi_comm *comm, int local_rank) { return ezt_get_global_rank_generic( comm->p_process->p_process->container->p_trace->id, comm->comm_id, local_rank); } extern int *rank_to_trace_id; #define EZT_RANK_TO_TRACE_ID(rank) (rank_to_trace_id[rank]) int is_comm_mine(int global_rank, struct ezt_mpi_comm*comm); #endif /* EZTRACE_CONVERT_MPI_H */ eztrace-1.1-2/src/modules/mpi/eztrace_convert_mpi_coll.c000066400000000000000000000232441265506773700234410ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE /* See feature_test_macros(7) */ #include #include #include "mpi_ev_codes.h" #include "eztrace_convert.h" #include "eztrace_convert_mpi.h" #include "eztrace_hierarchical_array.h" #include "eztrace_convert_mpi_coll.h" void init_mpi_coll_messages() { } void print_coll_stats(); void __print_coll_message(FILE*stream, struct mpi_coll_msg_t *msg) { fprintf(stream, "[%p]\ttype %d\n", msg, msg->type); int i; for (i = 0; i < msg->comm_size; i++) { fprintf(stream, "\t"); fprintf(stream, "[%s] enter %lu\tleave: %lu\n", msg->thread_ids[i], msg->times[i][start_coll], msg->times[i][stop_coll]); } fprintf(stream, "\n"); } void __print_coll_messages_recurse(FILE*stream, unsigned depth, p_eztrace_container p_cont); void __print_coll_messages(FILE*stream) { int trace_index; struct ezt_list_token_t *token; for(trace_index=0; trace_indexpending_comm[comm_type_collective], token) { struct mpi_pending_coll_comm* p_comm = (struct mpi_pending_coll_comm*) token->data; struct mpi_coll_msg_t* msg = p_comm->msg; __print_coll_message(stream, msg); } } } /* create a new collective message */ static struct mpi_coll_msg_t* __new_coll_message(enum coll_type_t type, struct ezt_mpi_comm *comm) { struct mpi_coll_msg_t *msg = malloc(sizeof(struct mpi_coll_msg_t)); int comm_size = comm->comm_size; msg->type = type; msg->comm_size = comm_size; msg->comm = malloc(sizeof(struct ezt_mpi_comm*) * comm_size); int i; msg->times = malloc(sizeof(uint64_t*) * comm_size); msg->thread_ids = malloc(sizeof(char*) * comm_size); msg->link_value = malloc(sizeof(char**) * comm_size); msg->link_id = malloc(sizeof(char**) * comm_size); msg->requests = malloc(sizeof(struct mpi_request *) * comm_size); msg->nb_started = 0; for (i = 0; i < comm_size; i++) { int j; msg->comm[i] = NULL; msg->thread_ids[i] = NULL; msg->link_value[i] = malloc(sizeof(char*) * comm_size); msg->link_id[i] = malloc(sizeof(char*) * comm_size); msg->requests[i] = NULL; for (j = 0; j < comm_size; j++) { CREATE_COLL_LINK_VALUE(msg, i, j); CREATE_COLL_MSG_ID(msg, i, j); } msg->times[i] = malloc(sizeof(uint64_t) * COLL_NB_TIMES); for (j = 0; j < COLL_NB_TIMES; j++) msg->times[i][j] = 0; } return msg; } /* add a new pending collective communicaton */ static struct mpi_pending_coll_comm* __create_new_pending_collective_comm(int trace_index, struct mpi_coll_msg_t* msg) { INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(trace_index), process_info); struct mpi_pending_coll_comm* p_comm = malloc(sizeof(struct mpi_pending_coll_comm)); p_comm->msg = msg; p_comm->token.data = p_comm; ezt_list_add(&process_info->pending_comm[comm_type_collective], &p_comm->token); return p_comm; } /* check if a message matches a collective communication * return 1 if the message matches or 0 otherwise */ static int __mpi_coll_msg_match(struct mpi_coll_msg_t* msg, enum coll_type_t type, struct ezt_mpi_comm *comm, struct mpi_request *req, int time_id) { int my_rank = comm->my_rank; if ((msg->type == type) && (msg->comm_size == comm->comm_size) && ((!msg->requests[my_rank]) || (msg->requests[my_rank] == req)) && (time_id < 0 || !msg->times[my_rank][time_id])) { /* It looks like this message matches. * We need to check wether the communicator for this message is comm or * if it matches comm */ int not_this_one = 0; int i; for (i = 0; i < msg->comm_size; i++) { if (msg->comm[i]) { /* the ith communicator is not empty */ if(! __ezt_mpi_communicator_are_equal(msg->comm[i], comm)) { /* the communicator doesn't match. we need to find anothe rmessahe */ not_this_one = 1; } else { /* the communicator matches */ return 1; } } } if (!not_this_one) { /* all the processes in this collective belong to comm */ return 1; } } return 0; } /* search for a message in the list of pending collective messages */ static __attribute__ ((unused)) struct mpi_pending_coll_comm * __mpi_find_pending_coll_message(struct mpi_process_info_t*p_info, enum coll_type_t type, struct ezt_mpi_comm *comm, struct mpi_request *req, int time_id) { struct ezt_list_token_t *token; ezt_list_foreach(&p_info->pending_comm[comm_type_collective], token) { struct mpi_pending_coll_comm* p_comm = (struct mpi_pending_coll_comm*) token->data; struct mpi_coll_msg_t* msg = p_comm->msg; if( __mpi_coll_msg_match(msg, type, comm, req, time_id)) { return p_comm; } } return NULL; } /* search for a message in the list of pending collective messages * the returned message has already been matched by the current thread */ static struct mpi_pending_coll_comm * __mpi_find_matched_coll_message(struct mpi_process_info_t*p_info, enum coll_type_t type, struct ezt_mpi_comm *comm, struct mpi_request *req, int time_id) { struct ezt_list_token_t *token; ezt_list_foreach(&p_info->pending_comm[comm_type_collective], token) { struct mpi_pending_coll_comm* p_comm = (struct mpi_pending_coll_comm*) token->data; struct mpi_coll_msg_t* msg = p_comm->msg; if( __mpi_coll_msg_match(msg, type, comm, req, time_id)) { if(msg->comm[comm->my_rank] == comm) { return p_comm; } } } return NULL; } /* search for a collective communication message message that matches */ struct mpi_coll_msg_t * __mpi_find_coll_message(enum coll_type_t type, struct ezt_mpi_comm *comm, struct mpi_request *req, int time_id) { int rank; struct ezt_list_token_t *token; for(rank=0; rank comm_size; rank++) { /* search for a matching collective message in the processes that belong to * the communicator */ INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(comm->ranks[rank]), p_info); ezt_list_foreach(&p_info->pending_comm[comm_type_collective], token) { struct mpi_pending_coll_comm* p_comm = (struct mpi_pending_coll_comm*) token->data; struct mpi_coll_msg_t* msg = p_comm->msg; /* browse the list of pending collective communications in this process */ if( __mpi_coll_msg_match(msg, type, comm, req, time_id)) { return msg; } } } /* cannot find a matching collective */ return NULL; } static int __get_local_rank(int global_rank, struct mpi_coll_msg_t *msg) { int i; for(i=0; icomm_size; i++) { struct ezt_mpi_comm*comm = msg->comm[i]; if(is_comm_mine(global_rank, comm)) return comm->my_rank; } } struct mpi_coll_msg_t* __mpi_find_coll_message_by_mpi_req(int rank, struct mpi_request *mpi_req) { struct ezt_list_token_t *token; INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(rank), p_info); ezt_list_foreach(&p_info->pending_comm[comm_type_collective], token) { struct mpi_pending_coll_comm* p_comm = (struct mpi_pending_coll_comm*) token->data; struct mpi_coll_msg_t* msg = p_comm->msg; /* browse the list of pending collective communications in this process */ int local_rank = __get_local_rank(rank, msg); if(mpi_req == msg->requests[local_rank]) return msg; } return NULL; } struct mpi_coll_msg_t* __enter_coll(uint64_t time, enum coll_type_t type, struct ezt_mpi_comm *comm, int __attribute__((unused)) my_rank, struct mpi_request* req, char* thread_id) { struct mpi_coll_msg_t* msg = __mpi_find_coll_message(type, comm, NULL, start_coll); if ( !msg) { /* We are the first process to arrive in this collective communication. * create a new collective message structure */ msg = __new_coll_message(type, comm); } /* add this message in the list of the process pending communications */ __create_new_pending_collective_comm(comm->ranks[my_rank], msg); assert(msg->comm[comm->my_rank] == NULL); /* todo: record_event(time, type, msg) */ msg->nb_started++; msg->comm[comm->my_rank] = comm; assert(msg->comm[comm->my_rank] == comm); msg->times[comm->my_rank][start_coll] = time; msg->thread_ids[comm->my_rank] = thread_id; if (req) { msg->requests[comm->my_rank] = req; req->coll_msg = msg; req->status = mpi_req_status_pending; } return msg; } struct mpi_coll_msg_t* __leave_coll(uint64_t time, enum coll_type_t type, struct ezt_mpi_comm *comm, int __attribute__((unused)) my_rank, struct mpi_request* req, char* thread_id) { INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(comm->ranks[comm->my_rank]), p_info); struct mpi_pending_coll_comm *pending_comm = __mpi_find_matched_coll_message(p_info, type, comm, req, stop_coll); assert(pending_comm); struct mpi_coll_msg_t* msg = pending_comm->msg; assert(msg->comm[comm->my_rank] == comm); /* todo: record_event(time, type, msg) */ msg->times[comm->my_rank][stop_coll] = time; assert(msg); assert(msg->thread_ids[comm->my_rank] == thread_id); assert(msg->requests[comm->my_rank] == req); assert(msg->comm[comm->my_rank] == comm); if(msg->nb_started != comm->comm_size) { msg->times[comm->my_rank][stop_coll] = 0; /* some process did not reach the start of the collective. We need to wait * for them */ return NULL; } ezt_list_remove(&pending_comm->token); free(pending_comm); /* remove the collective from the list of pending collectives */ return msg; } eztrace-1.1-2/src/modules/mpi/eztrace_convert_mpi_coll.h000066400000000000000000000026111265506773700234410ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_CONVERT_MPI_COLL_H #define EZTRACE_CONVERT_MPI_COLL_H #include #include "mpi_ev_codes.h" #include "eztrace_convert.h" #include "eztrace_convert_mpi.h" #include "eztrace_hierarchical_array.h" struct mpi_pending_coll_comm { struct ezt_list_token_t token; struct mpi_coll_msg_t *msg; }; #define EZTRACE_MPI_COLL_ID (EZTRACE_MPI_PREFIX | 0x1001) #define EZTRACE_MPI_COLL_ENTER_ID (EZTRACE_MPI_PREFIX | 0x1010) #define EZTRACE_MPI_COLL_LEAVE_ID (EZTRACE_MPI_PREFIX | 0x1011) #define MPI_STATS_COLL_ID (MPI_PREFIX | 0x1100) void init_mpi_coll_messages(); void print_coll_stats(); void __print_coll_message(FILE*stream, struct mpi_coll_msg_t *msg); void __print_coll_messages_recurse(FILE*stream, unsigned depth, p_eztrace_container p_cont); void __print_coll_messages(FILE*stream); struct mpi_coll_msg_t* __enter_coll(uint64_t time, enum coll_type_t type, struct ezt_mpi_comm *comm, int my_rank, struct mpi_request *req, char* thread_id); struct mpi_coll_msg_t* __leave_coll(uint64_t time, enum coll_type_t type, struct ezt_mpi_comm *comm, int my_rank, struct mpi_request *req, char* thread_id); #endif /* EZTRACE_CONVERT_MPI_COLL_H */ eztrace-1.1-2/src/modules/mpi/eztrace_convert_mpi_p2p.c000066400000000000000000000466661265506773700232260ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE /* See feature_test_macros(7) */ #include #include #include "mpi_ev_codes.h" #include "eztrace_convert_mpi_p2p.h" #include "eztrace_list.h" #include "eztrace_array.h" #include "eztrace_convert.h" #include "eztrace_convert_mpi.h" #include "eztrace_hierarchical_array.h" #if 0 /* Value of MPI_ANY_SOURCE */ extern int __MPI_ANY_SOURCE; /* Value of MPI_ANY_TAG */ extern uint32_t __MPI_ANY_TAG; #endif enum pending_comm_status_t { NONE_DONE = 1, IRECV_DONE = 2, ISEND_DONE = 4, RWAIT_DONE = 8, SWAIT_DONE = 16, }; struct mpi_pending_comm { struct ezt_list_token_t token; struct mpi_p2p_msg_t *msg; enum pending_comm_status_t status; }; void init_mpi_p2p_messages() { hierarchical_array_attach(EZTRACE_MPI_P2P_ID, sizeof(struct mpi_p2p_msg_t)); hierarchical_array_attach(EZTRACE_MPI_P2P_ISEND_ID, sizeof(struct p2p_msg_event)); hierarchical_array_attach(EZTRACE_MPI_P2P_IRECV_ID, sizeof(struct p2p_msg_event)); hierarchical_array_attach(EZTRACE_MPI_P2P_SWAIT_ID, sizeof(struct p2p_msg_event)); hierarchical_array_attach(EZTRACE_MPI_P2P_RWAIT_ID, sizeof(struct p2p_msg_event)); hierarchical_array_attach(MPI_REQUEST_ID, sizeof(struct mpi_request)); } void __print_mpi_req(struct mpi_request *req) { printf("req %p(ptr %p, type %d): msg %p(src=%d, dest=%d, len=%d)\n", req, (void *) req->ptr, req->req_type, req->msg, req->msg->src, req->msg->dest, req->msg->len); } void __print_mpi_requests_recurse(unsigned depth, p_eztrace_container p_cont) { unsigned i; int index; struct hierarchical_array* array = hierarchical_array_find(MPI_REQUEST_ID, p_cont); assert(array); for (index = (array->nb_items) - 1; index >= 0; index--) { struct mpi_request *req = NULL; req = ITH_ITEM(index, array); assert(req); for (i = 0; i < depth; i++) printf(" "); __print_mpi_req(req); } for (i = 0; i < p_cont->nb_children; i++) { __print_mpi_requests_recurse(depth + 1, p_cont->children[i]); } } void __print_mpi_requests() { int i; for (i = 0; i < NB_TRACES; i++) { p_eztrace_container p_cont = GET_PROCESS_CONTAINER(i); __print_mpi_requests_recurse(0, p_cont); } } void __print_p2p_message_header(FILE *stream) { fprintf(stream, "# src\tdest\tlen\ttag"); fprintf(stream, "\tStart_Isend_tick\tStop_Isend_tick\tSWait_tick\tWait_done_tick"); fprintf(stream, "\tStart_Irecv_tick\tStop_Irecv_tick\tRWait_tick\tWait_done_tick"); fprintf(stream, "\tSender_request\tReceiver_request"); fprintf(stream, "\n"); } void __print_p2p_message(FILE *stream, struct mpi_p2p_msg_t *msg) { fprintf(stream, "%d\t%d\t%d\t%x", msg->src, msg->dest, msg->len, msg->tag); int i; for (i = 0; i < P2P_NB_TIMES; i++) fprintf(stream, "\t%lu", msg->times[i]); fprintf(stream, "\t%p\t%p", msg->sender_request, msg->recver_request); fprintf(stream, "\n"); } void __print_p2p_messages_recurse(FILE *stream, unsigned depth, p_eztrace_container p_cont) { unsigned i; int index; struct hierarchical_array* array = hierarchical_array_find(EZTRACE_MPI_P2P_ID, p_cont); assert(array); for (index = (array->nb_items) - 1; index >= 0; index--) { struct mpi_p2p_msg_t *msg = NULL; msg = ITH_ITEM(index, array); assert(msg); for (i = 0; i < depth; i++) printf(" "); __print_p2p_message(stream, msg); } for (i = 0; i < p_cont->nb_children; i++) { __print_p2p_messages_recurse(stream, depth + 1, p_cont->children[i]); } } void __print_p2p_messages(FILE*stream) { int i; __print_p2p_message_header(stream); for (i = 0; i < NB_TRACES; i++) { /* reduce each trace counter */ p_eztrace_container p_cont = GET_PROCESS_CONTAINER(i); __print_p2p_messages_recurse(stream, 0, p_cont); } } void __record_event(uint64_t time, p_eztrace_container p_cont, int event_type, struct mpi_p2p_msg_t *p_msg) { struct p2p_msg_event* msg = hierarchical_array_new_item(p_cont, event_type); msg->time = time; msg->msg = p_msg; } /* create a new p2p message and store it. */ struct mpi_p2p_msg_t* __new_p2p_message( char* id, int src, int dest, int len, uint32_t tag, int unexp, char* link_value, const char* sender_thread_id, const struct mpi_request* sender_request, const char* recver_thread_id, const struct mpi_request* recver_request) { struct mpi_p2p_msg_t* msg = hierarchical_array_new_item( GET_PROCESS_CONTAINER(dest), EZTRACE_MPI_P2P_ID); assert(msg); assert(dest >= 0); msg->id = id; msg->src = src; msg->dest = dest; msg->len = len; msg->tag = tag; msg->unexp = unexp; /* set to 1 if the recv is detected before the send */ int i; for (i = 0; i < P2P_NB_TIMES; i++) msg->times[i] = 0; msg->link_value = link_value; msg->sender_thread_id = sender_thread_id; msg->recver_thread_id = recver_thread_id; msg->sender_request = sender_request; msg->recver_request = recver_request; return msg; } /* create a new mpi request and store it. */ struct mpi_request* __mpi_new_mpi_request(int rank, app_ptr mpi_req, enum mpi_request_type req_type) { struct eztrace_container_t* container = GET_PROCESS_CONTAINER(rank_to_trace_id[rank]); struct mpi_request* req = hierarchical_array_new_item(container, MPI_REQUEST_ID); assert(req); req->container = container; req->ptr = mpi_req; req->req_type = req_type; req->msg = NULL; req->status = mpi_req_status_none; return req; } /* find an mpi request */ struct mpi_request* __mpi_find_mpi_req(int rank, app_ptr mpi_req, enum mpi_request_type req_type) { struct hierarchical_array *array = hierarchical_array_find( MPI_REQUEST_ID, GET_PROCESS_CONTAINER(rank_to_trace_id[rank])); assert(array); int index; struct mpi_request* req = NULL; for (index = (array->nb_items) - 1; index >= 0; index--) { req = ITH_ITEM(index, array); if ((req->ptr == mpi_req) && ((req_type == mpi_req_none) || (req->req_type == req_type))) { return req; } } return NULL; } struct mpi_request* __mpi_find_pending_mpi_req(int rank, app_ptr mpi_req, enum mpi_request_type req_type) { struct mpi_request* req = NULL; req = __mpi_find_mpi_req(rank, mpi_req, req_type); if (req != NULL && req->status != mpi_req_status_none) return req; return NULL; } /* find the p2p message that corresponds to an mpi request */ struct mpi_p2p_msg_t* __mpi_find_p2p_message_by_mpi_req(int rank, const struct mpi_request* request) { assert(request); assert(request->req_type != mpi_req_none); if (request->msg) return request->msg; struct hierarchical_array* array = NULL; array = hierarchical_array_find(EZTRACE_MPI_P2P_ID, request->container); assert(array); struct mpi_p2p_msg_t* msg = NULL; int index; /* fixme: * if request->msg is not set, we may be unable to find the message. * Since messages are stored in the receiver container, if the request is * an isend message, then we don't know who is the receiver. * * However, this should never happen (well, I hope so, we should check). */ for (index = (array->nb_items) - 1; index >= 0; index--) { msg = ITH_ITEM(index, array); if (request->req_type == mpi_req_send) { if (request && (msg->src == rank) && (msg->sender_request == request)) { assert(msg->dest < NB_TRACES); return msg; } } else { if (request && (msg->dest == rank) && (msg->recver_request == request)) { assert(msg->src < NB_TRACES); return msg; } } } return NULL; } /* find a p2p message. * warning: this can be quite expensive since this function browse the whole message list! */ struct mpi_p2p_msg_t* __mpi_find_p2p_message(int src __attribute__((unused)), int dest, int len __attribute__((unused)), uint32_t tag, int time_id) { INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(dest), p_info); struct hierarchical_array* array = hierarchical_array_find( EZTRACE_MPI_P2P_ID, GET_PROCESS_CONTAINER(dest)); struct mpi_p2p_msg_t* msg = NULL; int index; /* browse the message list, starting from the end */ for (index = (array->nb_items) - 1; index >= 0; index--) { msg = ITH_ITEM(index, array); if (((msg->src == src) || (msg->src == p_info->__MPI_ANY_SOURCE)) && (msg->dest == dest) && ((msg->tag == tag) || (msg->tag == p_info->__MPI_ANY_TAG)) && (time_id < 0 || !msg->times[time_id])) { return msg; } } return NULL; } /* find a pending comm that matches(src, dest, len, tag) in the list * corresponding to type. Only consider pending comms that match the mask_ok * and doesn't match mask_not_ok */ struct mpi_pending_comm* __mpi_p2p_find_pending_comm(int src, int dest, int len __attribute__((unused)), uint32_t tag, enum comm_type_t type, uint32_t mask_ok, uint32_t mask_not_ok) { struct mpi_process_info_t * process_info = NULL; INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(dest), p_info); switch (type) { case comm_type_outgoing: { INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(src), p_info_src); process_info = p_info_src; } break; case comm_type_incoming: { process_info = p_info; } break; default: assert(1); } struct mpi_p2p_msg_t* msg = NULL; struct ezt_list_token_t *token; /* for each pending comm in the dest process, check if the message matches */ ezt_list_foreach(&process_info->pending_comm[type], token) { struct mpi_pending_comm* p_comm = (struct mpi_pending_comm*) token->data; assert(p_comm->msg); msg = p_comm->msg; if ((msg->dest == dest) && ((msg->src == src) || (msg->src == p_info->__MPI_ANY_SOURCE) || (src == p_info->__MPI_ANY_SOURCE)) && ((msg->tag == tag) || (msg->tag == p_info->__MPI_ANY_TAG) || (tag == p_info->__MPI_ANY_TAG)) && (p_comm->status & mask_ok) && (!(p_comm->status & mask_not_ok))) { return p_comm; } } /* message not found */ return NULL; } /* find a pending irecv */ struct mpi_pending_comm* __mpi_p2p_find_pending_irecv(int src __attribute__((unused)), int dest, int len __attribute__((unused)), uint32_t tag, uint32_t mask_ok, uint32_t mask_not_ok) { return __mpi_p2p_find_pending_comm(src, dest, len, tag, comm_type_incoming, mask_ok, mask_not_ok); } /* find a pending isend */ struct mpi_pending_comm* __mpi_p2p_find_pending_isend(int src, int dest, int len, uint32_t tag, uint32_t mask_ok, uint32_t mask_not_ok) { INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(dest), p_info); if (src == p_info->__MPI_ANY_SOURCE) { /* In case of any_source, we don't know where to search for the isend, * so we need to find the message first */ struct mpi_pending_comm* ret = NULL; int rank; int nb_traces = *get_nb_traces(); /* search for a pending isend that match in all the processes */ for (rank = 0; rank < nb_traces; rank++) { ret = __mpi_p2p_find_pending_comm(rank, dest, len, tag, comm_type_outgoing, mask_ok, mask_not_ok); if (ret) goto out; } out: return ret; } return __mpi_p2p_find_pending_comm(src, dest, len, tag, comm_type_outgoing, mask_ok, mask_not_ok); } /* search for a message in a list of pending communication and remove it */ static void __remove_message_from_pending_comm(struct mpi_p2p_msg_t* msg, int cont, enum comm_type_t comm_type) { INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(cont), process_info); struct ezt_list_token_t *token, *next; ezt_list_foreach_safe(&process_info->pending_comm[comm_type], token, next) { struct mpi_pending_comm* p_comm = (struct mpi_pending_comm*) token->data; if ((p_comm->msg == msg) && (p_comm->status == (NONE_DONE | IRECV_DONE | ISEND_DONE | RWAIT_DONE | SWAIT_DONE))) { ezt_list_remove(token); free(p_comm); } } } /* check for the completion of a message (ie. both send and recv ended) * and remove the message from the lists of pending communications */ static void __message_set_completed(struct mpi_p2p_msg_t* msg) { int i; /* check wether the message is complete */ for (i = 0; i < P2P_NB_TIMES; i++) { if (!msg->times[i]) return; } /* message is complete (ie. send and recv ended) */ /* remove the message from the lists of pending sends */ __remove_message_from_pending_comm(msg, msg->src, comm_type_outgoing); /* remove the message from the lists of pending receives */ __remove_message_from_pending_comm(msg, msg->dest, comm_type_incoming); } static struct mpi_pending_comm* __create_new_pending_comm( int process_id, struct mpi_p2p_msg_t* msg, enum comm_type_t type) { INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(process_id), process_info); /* todo: use a block malloc instead (improved performance) */ struct mpi_pending_comm* p_comm = malloc(sizeof(struct mpi_pending_comm)); p_comm->status = NONE_DONE; p_comm->msg = msg; p_comm->token.data = p_comm; ezt_list_add(&process_info->pending_comm[type], &p_comm->token); return p_comm; } struct mpi_p2p_msg_t* __start_recv_message(uint64_t start_time, int src, int dest, int len, uint32_t tag, const char* thread_id, struct mpi_request* mpi_req) { /* is there a corresponding isend ? */ struct mpi_pending_comm* pending_comm = __mpi_p2p_find_pending_isend( src, dest, len, tag, NONE_DONE, IRECV_DONE); struct mpi_p2p_msg_t* msg = NULL; struct mpi_pending_comm* new_comm = NULL; if (!pending_comm) { /* no isend found. Create the message and register a irecv */ msg = __new_p2p_message(NULL, src, dest, len, tag, 1, NULL, NULL, NULL, thread_id, mpi_req); pending_comm = __create_new_pending_comm(dest, msg, comm_type_incoming); pending_comm->status |= IRECV_DONE; } else { /* isend found, update its status */ pending_comm->status |= IRECV_DONE; msg = pending_comm->msg; /* create a recv pending comm*/ new_comm = __create_new_pending_comm(dest, msg, comm_type_incoming); new_comm->status |= pending_comm->status; } assert(msg); __record_event(start_time, GET_PROCESS_CONTAINER(dest), EZTRACE_MPI_P2P_IRECV_ID, msg); msg->recver_thread_id = thread_id; msg->recver_request = mpi_req; msg->times[start_irecv] = start_time; if (mpi_req) { mpi_req->status = mpi_req_status_pending; mpi_req->msg = msg; } return msg; } struct mpi_p2p_msg_t* __stop_recv_message(uint64_t stop_time, int src, int dest, int len, uint32_t tag, const char* thread_id __attribute__((unused)), struct mpi_request* mpi_req) { /* retrieve the corresponding pending incoming comm */ struct mpi_pending_comm* pending_comm = __mpi_p2p_find_pending_irecv( src, dest, len, tag, IRECV_DONE, RWAIT_DONE); struct mpi_p2p_msg_t* msg = NULL; struct mpi_pending_comm* pending_comm_outgoing = NULL; assert(pending_comm); if (!(pending_comm->status & ISEND_DONE)) { /* the matching isend has not happened yet. This means there's a synchronisation problem * between the traces. */ return NULL; } /* update the status of the pending incoming comm */ pending_comm->status |= RWAIT_DONE; msg = pending_comm->msg; /* update the outgoing pending comm status */ pending_comm_outgoing = __mpi_p2p_find_pending_isend(src, dest, len, tag, NONE_DONE, RWAIT_DONE); if (pending_comm_outgoing) pending_comm_outgoing->status |= RWAIT_DONE; assert(msg); __record_event(stop_time, GET_PROCESS_CONTAINER(dest), EZTRACE_MPI_P2P_RWAIT_ID, msg); if (!msg->times[start_rwait]) msg->times[start_rwait] = stop_time; msg->times[stop_recv] = stop_time; if (mpi_req) { mpi_req->msg = NULL; mpi_req->status = mpi_req_status_none; } if ((!msg->id) && msg->sender_thread_id && msg->recver_thread_id) { CREATE_P2P_MSG_ID(msg); } if ((!msg->link_value) && msg->sender_thread_id && msg->recver_thread_id) { CREATE_P2P_LINK_VALUE(msg); } __message_set_completed(msg); return msg; } struct mpi_p2p_msg_t* __start_send_message(uint64_t start_time, int src, int dest, int len, uint32_t tag, const char* thread_id, struct mpi_request* mpi_req) { /* did the matching irecv already happened ? */ struct mpi_pending_comm* pending_comm = __mpi_p2p_find_pending_irecv( src, dest, len, tag, NONE_DONE, ISEND_DONE); struct mpi_p2p_msg_t* msg = NULL; struct mpi_pending_comm* new_comm = NULL; if (!pending_comm) { /* no irecv found. Create the message and register a isend */ msg = __new_p2p_message(NULL, src, dest, len, tag, 0, NULL, thread_id, mpi_req, NULL, NULL); pending_comm = __create_new_pending_comm(src, msg, comm_type_outgoing); pending_comm->status |= ISEND_DONE; } else { /* irecv found, update its status */ pending_comm->status |= ISEND_DONE; msg = pending_comm->msg; /* create a send pending comm*/ new_comm = __create_new_pending_comm(src, msg, comm_type_outgoing); new_comm->status |= pending_comm->status; } assert(msg); __record_event(start_time, GET_PROCESS_CONTAINER(dest), EZTRACE_MPI_P2P_ISEND_ID, msg); INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(dest), p_info); msg->sender_thread_id = thread_id; msg->sender_request = mpi_req; msg->times[start_isend] = start_time; if (mpi_req) { mpi_req->msg = msg; mpi_req->status = mpi_req_status_pending; } if (msg->src == p_info->__MPI_ANY_SOURCE) msg->src = src; if (msg->tag == p_info->__MPI_ANY_TAG) msg->tag = tag; if ((!msg->id) && msg->sender_thread_id && msg->recver_thread_id) { CREATE_P2P_MSG_ID(msg); } if ((!msg->link_value) && msg->sender_thread_id && msg->recver_thread_id) { CREATE_P2P_LINK_VALUE(msg); } return msg; } struct mpi_p2p_msg_t* __stop_send_message(uint64_t stop_time, int src, int dest, int len, uint32_t tag, const char* thread_id __attribute__((unused)), struct mpi_request* mpi_req) { /* retrieve the corresponding pending outgoing comm */ struct mpi_pending_comm* pending_comm = __mpi_p2p_find_pending_isend( src, dest, len, tag, ISEND_DONE, SWAIT_DONE); struct mpi_p2p_msg_t* msg = NULL; assert(pending_comm); struct mpi_pending_comm* pending_comm_incoming = NULL; /* update the status of the outgoing comm*/ pending_comm->status |= SWAIT_DONE; msg = pending_comm->msg; /* update the incoming pending comm status */ pending_comm_incoming = __mpi_p2p_find_pending_irecv(src, dest, len, tag, NONE_DONE, SWAIT_DONE); if (pending_comm_incoming) { pending_comm_incoming->status |= SWAIT_DONE; } assert(msg); __record_event(stop_time, GET_PROCESS_CONTAINER(dest), EZTRACE_MPI_P2P_SWAIT_ID, msg); INIT_MPI_PROCESS_INFO(GET_PROCESS_INFO(dest), p_info); if (msg->src == p_info->__MPI_ANY_SOURCE) msg->src = src; if (msg->tag == p_info->__MPI_ANY_TAG) msg->tag = tag; if (!msg->times[start_swait]) msg->times[start_swait] = stop_time; msg->times[stop_send] = stop_time; if (mpi_req) { mpi_req->msg = NULL; mpi_req->status = mpi_req_status_none; } if ((!msg->id) && msg->sender_thread_id && msg->recver_thread_id) { CREATE_P2P_MSG_ID(msg); } if ((!msg->link_value) && msg->sender_thread_id && msg->recver_thread_id) { CREATE_P2P_LINK_VALUE(msg); } __message_set_completed(msg); return msg; } eztrace-1.1-2/src/modules/mpi/eztrace_convert_mpi_p2p.h000066400000000000000000000053721265506773700232200ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_CONVERT_MPI_P2P_H #define EZTRACE_CONVERT_MPI_P2P_H #include #include "mpi_ev_codes.h" #include "eztrace_convert.h" #include "eztrace_convert_mpi.h" #include "eztrace_hierarchical_array.h" struct p2p_msg_event { uint64_t time; struct mpi_p2p_msg_t *msg; }; #define EZTRACE_MPI_P2P_ID (EZTRACE_MPI_PREFIX | 0x0001) #define EZTRACE_MPI_P2P_ISEND_ID (EZTRACE_MPI_PREFIX | 0x0010) #define EZTRACE_MPI_P2P_SWAIT_ID (EZTRACE_MPI_PREFIX | 0x0011) #define EZTRACE_MPI_P2P_IRECV_ID (EZTRACE_MPI_PREFIX | 0x0012) #define EZTRACE_MPI_P2P_RWAIT_ID (EZTRACE_MPI_PREFIX | 0x0013) #define EZTRACE_MPI_STATS_P2P_ID (EZTRACE_MPI_PREFIX | 0x0100) #define MPI_REQUEST_ID (EZTRACE_MPI_PREFIX | 0x0020) void init_mpi_p2p_messages(); void print_p2p_stats(); void __print_freq(); void __print_p2p_message(FILE*stream, struct mpi_p2p_msg_t *msg); void __print_p2p_messages_recurse(FILE*stream, unsigned depth, p_eztrace_container p_cont); void __print_p2p_messages(FILE*stream); struct mpi_p2p_msg_t* __new_p2p_message( char* id, int src, int dest, int len, uint32_t tag, int unexp, char* link_value, const char* sender_thread_id, const struct mpi_request* sender_request, const char* recver_thread_id, const struct mpi_request* recver_request); struct mpi_request* __mpi_new_mpi_request(int rank, app_ptr mpi_req, enum mpi_request_type req_type); struct mpi_request* __mpi_find_mpi_req(int rank, app_ptr mpi_req, enum mpi_request_type req_type); struct mpi_request* __mpi_find_pending_mpi_req(int rank, app_ptr mpi_req, enum mpi_request_type req_type); struct mpi_p2p_msg_t* __mpi_find_p2p_message_by_mpi_req(int rank, const struct mpi_request* request); struct mpi_p2p_msg_t* __mpi_find_p2p_message(int src __attribute__((unused)), int dest, int len __attribute__((unused)), uint32_t tag, int time_id); struct mpi_p2p_msg_t* __start_recv_message(uint64_t start_time, int src, int dest, int len, uint32_t tag, const char* thread_id, struct mpi_request* mpi_req); struct mpi_p2p_msg_t* __stop_recv_message(uint64_t stop_time, int src, int dest, int len, uint32_t tag, const char* thread_id __attribute__((unused)), struct mpi_request* mpi_req); struct mpi_p2p_msg_t* __start_send_message(uint64_t start_time, int src, int dest, int len, uint32_t tag, const char* thread_id, struct mpi_request* mpi_req); struct mpi_p2p_msg_t* __stop_send_message(uint64_t stop_time, int src, int dest, int len, uint32_t tag, const char* thread_id __attribute__((unused)), struct mpi_request* mpi_req); #endif /* EZTRACE_CONVERT_MPI_P2P_H */ eztrace-1.1-2/src/modules/mpi/eztrace_convert_mpi_pers.c000066400000000000000000000055171265506773700234640ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telcom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include #include "mpi_ev_codes.h" #include "eztrace_convert.h" #include "eztrace_convert_mpi.h" #include "eztrace_hierarchical_array.h" #include "eztrace_convert_mpi_p2p.h" #include "eztrace_convert_mpi_pers.h" void init_mpi_pers_messages() { hierarchical_array_attach(MPI_PERS_ID, sizeof(struct mpi_coll_msg_t)); } void print_pers_stats(); void __print_pers_req(FILE __attribute__((unused)) *stream, struct mpi_pers_req_t __attribute__((unused)) *msg) { } void __print_pers_req_recurse(FILE*stream, unsigned depth, p_eztrace_container p_cont); void __print_all_pers_req(FILE*stream) { struct hierarchical_array* array = hierarchical_array_find(MPI_PERS_ID, NULL); struct mpi_pers_req_t* msg = NULL; unsigned index; for (index = 0; index < (array->nb_items); index++) { msg = ITH_ITEM(index, array); __print_pers_req(stream, msg); } } struct mpi_pers_req_t* __new_pers_req(enum mpi_request_type type, app_ptr buffer, int src, int dest, int len, int tag, app_ptr mpi_req) { struct mpi_pers_req_t* req = NULL; if (type == mpi_req_recv) { req = hierarchical_array_new_item(GET_PROCESS_CONTAINER(dest), MPI_PERS_ID); req->mpi_req = __mpi_new_mpi_request(dest, mpi_req, type); } else { req = hierarchical_array_new_item(GET_PROCESS_CONTAINER(src), MPI_PERS_ID); req->mpi_req = __mpi_new_mpi_request(src, mpi_req, type); } req->type = type; req->buffer = buffer; req->len = len; req->src = src; req->dest = dest; req->tag = tag; return req; } struct mpi_pers_req_t* __pers_init(uint64_t __attribute__((unused)) time, enum mpi_request_type type, app_ptr buffer, int src, int dest, int len, int tag, app_ptr mpi_req) { return __new_pers_req(type, buffer, src, dest, len, tag, mpi_req); } struct mpi_pers_req_t* __mpi_find_pers_req(p_eztrace_container p_cont, struct mpi_request* mpi_req) { struct hierarchical_array* array = hierarchical_array_find(MPI_PERS_ID, p_cont); struct mpi_pers_req_t* msg = NULL; int index; for (index = (array->nb_items) - 1; index >= 0; index--) { msg = ITH_ITEM(index, array); if (msg->mpi_req == mpi_req) { return msg; } } return NULL; } struct mpi_pers_req_t* __pers_start(uint64_t __attribute__((unused)) time, int rank, app_ptr mpi_req) { /* todo: record something ? (->number of messages sent with a pers_req ?) */ struct mpi_request* req = __mpi_find_mpi_req(rank, mpi_req, mpi_req_none); return __mpi_find_pers_req(GET_PROCESS_CONTAINER(rank), req); } eztrace-1.1-2/src/modules/mpi/eztrace_convert_mpi_pers.h000066400000000000000000000024611265506773700234640ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_CONVERT_MPI_PERS_H #define EZTRACE_CONVERT_MPI_PERS_H #include #include "mpi_ev_codes.h" #include "eztrace_convert.h" #include "eztrace_convert_mpi.h" #include "eztrace_hierarchical_array.h" struct pers_msg_event { uint64_t time; struct mpi_coll_msg_t *msg; }; #define MPI_PERS_ID (EZTRACE_MPI_PREFIX | 0x2001) #define MPI_STATS_PERS_ID (EZTRACE_MPI_PREFIX | 0x2100) void init_mpi_pers_messages(); void print_pers_stats(); void __print_pers_req(FILE*stream, struct mpi_pers_req_t *req); void __print_pers_req_recurse(FILE*stream, unsigned depth, p_eztrace_container p_cont); void __print_all_pers_req(FILE*stream); struct mpi_pers_req_t* __new_pers_req(enum mpi_request_type type, app_ptr buffer, int src, int dest, int len, int tag, app_ptr mpi_req); struct mpi_pers_req_t* __pers_init(uint64_t time, enum mpi_request_type type, app_ptr buffer, int src, int dest, int len, int tag, app_ptr mpi_req); struct mpi_pers_req_t* __pers_start(uint64_t time, int rank, app_ptr mpi_req); #endif /* EZTRACE_CONVERT_MPI_PERS_H */ eztrace-1.1-2/src/modules/mpi/eztrace_stats_mpi.c000066400000000000000000000356671265506773700221220ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include #include #include #include "eztrace_stats_core.h" #include "eztrace_stats_mpi.h" #include "mpi_ev_codes.h" #include "eztrace_list.h" #include "eztrace_convert.h" #include "eztrace_convert_mpi.h" #include "eztrace_convert_mpi_p2p.h" #include "eztrace_hierarchical_array.h" #include "eztrace_array.h" struct mpi_p2p_stat_t { int nb_messages; /* size of sent messages */ struct stat_uint64_t_counter_t size; /* time spent sending messages */ struct stat_double_counter_t scomm_duration; /* time spent computing while sending messages */ struct stat_double_counter_t soverlap_duration; /* time spent in MPI_Send or waiting for a Isend to complete */ struct stat_double_counter_t swait_duration; /* time spent receiving messages */ struct stat_double_counter_t rcomm_duration; /* time spending computing while waiting for an incoming message */ struct stat_double_counter_t roverlap_duration; /* time spent in MPI_Recv or waiting for a Irecv to complete */ struct stat_double_counter_t rwait_duration; }; struct __mpi_stats_matrix_item { uint64_t total_len; int nb_messages; }; struct __mpi_stats_freq_item { int len; int nb_occur; }; struct eztrace_array_t __mpi_stats_freq; struct __mpi_stats_matrix_item **__mpi_stats_comm_matrix = NULL; /* find a len in the frequency table */ static struct __mpi_stats_freq_item* __find_freq_item(int len) { struct __mpi_stats_freq_item* ret = NULL; unsigned i; for (i = 0; i < __mpi_stats_freq.nb_items; i++) { ret = ITH_VALUE(i, &__mpi_stats_freq); if (ret->len == len) return ret; } /* can't find the specified len, allocate a new item */ ret = eztrace_array_new_value(&__mpi_stats_freq); ret->len = len; ret->nb_occur = 0; return ret; } /* update the communication matrix and the frequency table for p2p messages */ static void __update_p2p_message_stats(int src, int dest, int len, int __attribute__((unused)) tag) { __mpi_stats_comm_matrix[src][dest].nb_messages++; __mpi_stats_comm_matrix[src][dest].total_len += len; struct __mpi_stats_freq_item* freq_item = __find_freq_item(len); assert(freq_item->len == len); freq_item->nb_occur++; } static void __print_stat_double_counter(struct stat_double_counter_t *counter, int count) { printf("\tmin: %lf", counter->min); printf("\tmax: %lf", counter->max); printf("\taverage: %lf", counter->sum / count); printf("\ttotal: %lf", counter->sum); } static void __print_stat_int_counter(struct stat_uint64_t_counter_t *counter, int count) { printf("\tmin: %lu", counter->min); printf("\tmax: %lu", counter->max); printf("\taverage: %lu", counter->sum / count); printf("\ttotal: %lu", counter->sum); } static void __init_mpi_p2p_stat_t(struct mpi_p2p_stat_t* counter) { counter->nb_messages = 0; __init_stat_counter(uint64_t, &counter->size); __init_stat_counter(double, &counter->scomm_duration); __init_stat_counter(double, &counter->soverlap_duration); __init_stat_counter(double, &counter->swait_duration); __init_stat_counter(double, &counter->rcomm_duration); __init_stat_counter(double, &counter->roverlap_duration); __init_stat_counter(double, &counter->rwait_duration); } static void __p2p_stats_reduce_recurse(unsigned depth, int rank, p_eztrace_container p_cont) { assert(p_cont); struct mpi_p2p_stat_t* counter = hierarchical_array_new_item( p_cont, EZTRACE_MPI_STATS_P2P_ID); assert(counter); __init_mpi_p2p_stat_t(counter); unsigned i; /* compute the children stats */ for (i = 0; i < p_cont->nb_children; i++) { /* call recursively the function */ __p2p_stats_reduce_recurse(depth + 1, rank, p_cont->children[i]); struct hierarchical_array* child_array = hierarchical_array_find( EZTRACE_MPI_STATS_P2P_ID, p_cont->children[i]); assert(child_array); assert(child_array->nb_items); /* add the children stats to the container stats */ struct mpi_p2p_stat_t*child_counter = ITH_ITEM(0, child_array); counter->nb_messages += child_counter->nb_messages; __reduce_stat_counter(uint64_t, &counter->size, &child_counter->size); __reduce_stat_counter(double, &counter->scomm_duration, &child_counter->scomm_duration); __reduce_stat_counter(double, &counter->soverlap_duration, &child_counter->soverlap_duration); __reduce_stat_counter(double, &counter->swait_duration, &child_counter->swait_duration); __reduce_stat_counter(double, &counter->rcomm_duration, &child_counter->rcomm_duration); __reduce_stat_counter(double, &counter->roverlap_duration, &child_counter->roverlap_duration); __reduce_stat_counter(double, &counter->rwait_duration, &child_counter->rwait_duration); } /* compute statistics for the current container */ unsigned index; /* sent messages */ struct hierarchical_array* array = hierarchical_array_find( EZTRACE_MPI_P2P_ISEND_ID, p_cont); assert(array); for (index = 0; index < array->nb_items; index++) { struct p2p_msg_event *msg = NULL; msg = ITH_ITEM(index, array); assert(msg); counter->nb_messages++; __update_stat_counter(uint64_t, &counter->size, (uint64_t )msg->msg->len); __update_p2p_message_stats(msg->msg->src, msg->msg->dest, msg->msg->len, msg->msg->tag); /* compute communication durations */ __update_stat_counter( double, &counter->scomm_duration, (double ) (msg->msg->times[stop_send] - msg->msg->times[start_isend]) / 1000000); __update_stat_counter( double, &counter->soverlap_duration, (double ) (msg->msg->times[start_swait] - msg->msg->times[stop_isend]) / 1000000); __update_stat_counter( double, &counter->swait_duration, (double ) (msg->msg->times[stop_send] - msg->msg->times[start_swait]) / 1000000); } /* received messages */ array = hierarchical_array_find(EZTRACE_MPI_P2P_IRECV_ID, p_cont); assert(array); for (index = 0; index < array->nb_items; index++) { struct p2p_msg_event *msg = NULL; msg = ITH_ITEM(index, array); assert(msg); /* compute communication durations */ __update_stat_counter( double, &counter->rcomm_duration, (double ) (msg->msg->times[stop_recv] - msg->msg->times[start_irecv]) / 1000000); __update_stat_counter( double, &counter->roverlap_duration, (double ) (msg->msg->times[start_rwait] - msg->msg->times[stop_irecv]) / 1000000); __update_stat_counter( double, &counter->rwait_duration, (double ) (msg->msg->times[stop_recv] - msg->msg->times[start_rwait]) / 1000000); } } static void __p2p_stats_print_recurse(unsigned depth, p_eztrace_container p_cont) { assert(p_cont); struct hierarchical_array* array = hierarchical_array_find( EZTRACE_MPI_STATS_P2P_ID, p_cont); assert(array); struct mpi_p2p_stat_t* counter = ITH_ITEM(0, array); assert(counter); unsigned i; if (counter->nb_messages) { double mpi_time = 0; /* time spent in MPI */ /* Print the current container stats */ printf("\n"); for (i = 0; i < depth; i++) printf(" "); printf("%s -- \t%d messages sent\n", p_cont->name, counter->nb_messages); for (i = 0; i < depth; i++) printf(" "); printf("\tSize of messages (byte):"); __print_stat_int_counter(&counter->size, counter->nb_messages); printf("\n"); /* sent messages */ for (i = 0; i < depth; i++) printf(" "); printf("\tTime spent sending messages (ms):"); __print_stat_double_counter(&counter->scomm_duration, counter->nb_messages); printf("\n"); for (i = 0; i < depth; i++) printf(" "); printf("\tTime spent computing while sending messages (ms):"); __print_stat_double_counter(&counter->soverlap_duration, counter->nb_messages); printf("\n"); for (i = 0; i < depth; i++) printf(" "); printf("\tTime spent in MPI_Send or waiting for a Isend to complete (ms):"); mpi_time += counter->swait_duration.sum; __print_stat_double_counter(&counter->swait_duration, counter->nb_messages); printf("\n"); /* received messages */ for (i = 0; i < depth; i++) printf(" "); printf("\tTime spent receiving messages (ms):"); __print_stat_double_counter(&counter->rcomm_duration, counter->nb_messages); printf("\n"); for (i = 0; i < depth; i++) printf(" "); printf("\tTime spent computing while receiving messages (ms):"); __print_stat_double_counter(&counter->roverlap_duration, counter->nb_messages); printf("\n"); for (i = 0; i < depth; i++) printf(" "); printf("\tTime spent in MPI_Recv or waiting for a Irecv to complete (ms):"); mpi_time += counter->rwait_duration.sum; __print_stat_double_counter(&counter->rwait_duration, counter->nb_messages); printf("\n"); /* call the container children so that they print their values */ for (i = 0; i < p_cont->nb_children; i++) { __p2p_stats_print_recurse(depth + 1, p_cont->children[i]); } } } /* compute point to point messages statistics */ static void __p2p_stats_reduce() { int rank; eztrace_array_create(&__mpi_stats_freq, sizeof(struct __mpi_stats_freq_item), 32); __mpi_stats_comm_matrix = malloc( sizeof(struct __mpi_stats_matrix_item*) * NB_TRACES); for (rank = 0; rank < NB_TRACES; rank++) { __mpi_stats_comm_matrix[rank] = malloc( sizeof(struct __mpi_stats_matrix_item) * NB_TRACES); int i; for (i = 0; i < NB_TRACES; i++) { __mpi_stats_comm_matrix[rank][i].total_len = 0; __mpi_stats_comm_matrix[rank][i].nb_messages = 0; } } for (rank = 0; rank < NB_TRACES; rank++) { p_eztrace_container p_cont = GET_PROCESS_CONTAINER(rank); __p2p_stats_reduce_recurse(0, rank, p_cont); } } /* print point to point messages statistics */ static void __p2p_stats_print() { int rank; for (rank = 0; rank < NB_TRACES; rank++) { p_eztrace_container p_cont = GET_PROCESS_CONTAINER(rank); __p2p_stats_print_recurse(0, p_cont); } } int dump_comm_matrix_nb_msg = 0; int dump_comm_matrix_msg_size = 0; static void __p2p_create_comm_matrix_gnuplot(const char* data_prefix) { char* path; asprintf(&path, "%s.gp", data_prefix); FILE *out = fopen(path, "w+"); fprintf(out, "set terminal png\n"); fprintf(out, "set output \"%s.png\"\n", data_prefix); fprintf(out, "set xtics 1\n"); fprintf(out, "set ytics 1\n"); fprintf(out, "set xrange [ -0.5 : %d.5]\n", NB_TRACES-1); fprintf(out, "set yrange [ -0.5 : %d.5]\n", NB_TRACES-1); fprintf(out, "plot \"%s.dat\" matrix with image\n", data_prefix); fclose(out); free(path); } static void __p2p_print_communication_matrix_nb_messages() { int src, dest; if (dump_comm_matrix_nb_msg) { char* prefix; asprintf(&prefix, "%s/communication_matrix.nb_messages", eztrace_stats_get_output_dir()); char* path; asprintf(&path, "%s.dat", prefix); FILE *out = fopen(path, "w+"); for (src = 0; src < NB_TRACES; src++) { for (dest = 0; dest < NB_TRACES; dest++) { fprintf(out, "%d ", __mpi_stats_comm_matrix[src][dest].nb_messages); } fprintf(out, "\n"); } fclose(out); printf("\tThe communication matrix (number of message) has been dumped in %s\n", path); __p2p_create_comm_matrix_gnuplot(prefix); free(prefix); free(path); } } static void __p2p_print_communication_matrix_message_size() { int src, dest; if (dump_comm_matrix_msg_size) { char* prefix; asprintf(&prefix, "%s/communication_matrix.message_size", eztrace_stats_get_output_dir()); char* path; asprintf(&path, "%s.dat", prefix); FILE *out = fopen(path, "w+"); for (src = 0; src < NB_TRACES; src++) { for (dest = 0; dest < NB_TRACES; dest++) { fprintf(out, "%ld ", __mpi_stats_comm_matrix[src][dest].total_len); } fprintf(out, "\n"); } fclose(out); printf("\tThe communication matrix (message size) has been dumped in %s\n", path); __p2p_create_comm_matrix_gnuplot(prefix); free(path); free(prefix); } } /* compute point to point messages statistics and print them */ void print_p2p_stats() { __p2p_stats_reduce(); __p2p_stats_print(); dump_comm_matrix_nb_msg = 1; dump_comm_matrix_msg_size = 1; mpi_stats_dump(); printf("\n"); __p2p_print_communication_matrix_message_size(); __p2p_print_communication_matrix_nb_messages(); } /* initialize MPI statistics module */ void init_mpi_stats() { hierarchical_array_attach(EZTRACE_MPI_STATS_P2P_ID, sizeof(struct mpi_p2p_stat_t)); /* todo: do the same for collective */ } /* dump to disk the list of messages */ void mpi_stats_dump() { char* env_str = getenv("EZTRACE_MPI_DUMP_MESSAGES"); if (env_str) { char* path; int res __attribute__ ((__unused__)); res = asprintf(&path, "%s/%s_eztrace_message_dump", eztrace_stats_get_output_dir(), getenv("USER")); FILE *f = fopen(path, "w"); if (!f) perror("Error while dumping messages"); __print_p2p_messages(f); int ret = fclose(f); if (ret) perror("Error while dumping messages (fclose)"); printf("\n\tMPI messages dumped in %s\n", path); free(path); } } void mpi_stats_plot_message_size() { char* data_path; char* gp_path; int res __attribute__ ((__unused__)); res = asprintf(&data_path, "%s/message_size.dat", eztrace_stats_get_output_dir()); FILE *out = fopen(data_path, "w+"); struct __mpi_stats_freq_item* ret = NULL; unsigned i; fprintf(out, "#Message_length #Number_of_messages\n"); for (i = 0; i < __mpi_stats_freq.nb_items; i++) { ret = ITH_VALUE(i, &__mpi_stats_freq); fprintf(out, "%d\t%d\n", ret->len, ret->nb_occur); } fclose(out); res = asprintf(&data_path, "%s/message_size.dat", eztrace_stats_get_output_dir()); res = asprintf(&gp_path, "%s/message_size.gp", eztrace_stats_get_output_dir()); out = fopen(gp_path, "w+"); fprintf(out, "set terminal png\n"); fprintf(out, "set output \"%s/message_size.png\"\n", eztrace_stats_get_output_dir()); fprintf(out, "set xlabel \"message size (B)\"\n"); fprintf(out, "set ylabel \"number of messages\"\n"); fprintf(out, "plot \"%s\" with linespoints\n", data_path); fclose(out); printf("\tThe distribution of message sizes has been dumped in %s\n", data_path); free(data_path); free(gp_path); } eztrace-1.1-2/src/modules/mpi/eztrace_stats_mpi.h000066400000000000000000000013001265506773700221000ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef EZTRACE_STATS_MPI_H #define EZTRACE_STATS_MPI_H #include #include "mpi_ev_codes.h" #include "eztrace_list.h" #include "eztrace_convert.h" #include "eztrace_convert_mpi.h" #include "eztrace_convert_mpi_p2p.h" #include "eztrace_hierarchical_array.h" /* compute point to point messages statistics and print them */ void print_p2p_stats(); /* initialize MPI statistics module */ void init_mpi_stats(); /* dump to disk the list of messages */ void mpi_stats_dump(); void mpi_stats_plot_message_size(); #endif /* EZTRACE_STATS_MPI_H */ eztrace-1.1-2/src/modules/mpi/fortran_utils.f90000066400000000000000000000004751265506773700214360ustar00rootroot00000000000000! Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis ! See COPYING in top-level directory. integer function ezt_mpi_is_in_place( i ) include 'mpif.h' integer i ezt_mpi_is_in_place = 0 if( loc(i) .eq. loc(mpi_in_place) ) ezt_mpi_is_in_place = 1 return end function ezt_mpi_is_in_place eztrace-1.1-2/src/modules/mpi/mpi.c000066400000000000000000001071621265506773700171550ustar00rootroot00000000000000/* -*- C-File-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include #include "pptrace.h" #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" /* pointers to actual MPI functions (C version) */ int (*libMPI_Init)(int *, char ***); int (*libMPI_Init_thread)(int *, char ***, int, int*); int (*libMPI_Comm_size)( MPI_Comm, int *); int (*libMPI_Comm_rank)( MPI_Comm, int *); int (*libMPI_Comm_get_parent)(MPI_Comm *parent) = NULL; int (*libMPI_Finalize)(void); int (*libMPI_Initialized)(int *); int (*libMPI_Abort)( MPI_Comm, int); int (*libMPI_Type_size)(MPI_Datatype datatype, int *size); int (*libMPI_Cancel)( MPI_Request*); int (*libMPI_Comm_disconnect)(MPI_Comm * comm); int (*libMPI_Comm_free)(MPI_Comm *comm); int (*libMPI_Comm_create)(MPI_Comm comm, MPI_Group group, MPI_Comm *newcomm); int (*libMPI_Comm_create_group)(MPI_Comm comm, MPI_Group group, int tag, MPI_Comm * newcomm); int (*libMPI_Comm_split)(MPI_Comm comm, int color, int key, MPI_Comm *newcomm); int (*libMPI_Comm_dup)(MPI_Comm comm, MPI_Comm *newcomm); int (*libMPI_Comm_dup_with_info)(MPI_Comm comm, MPI_Info info, MPI_Comm * newcomm); int (*libMPI_Comm_split_type)(MPI_Comm comm, int split_type, int key, MPI_Info info, MPI_Comm * newcomm); int (*libMPI_Intercomm_create)(MPI_Comm local_comm, int local_leader, MPI_Comm peer_comm, int remote_leader, int tag, MPI_Comm *newintercomm); int (*libMPI_Intercomm_merge)(MPI_Comm intercomm, int high, MPI_Comm *newintracomm); int (*libMPI_Cart_sub)(MPI_Comm old_comm, CONST int *belongs, MPI_Comm *new_comm); int (*libMPI_Cart_create)(MPI_Comm comm_old, int ndims, CONST int *dims, CONST int *periods, int reorder, MPI_Comm *comm_cart); int (*libMPI_Graph_create)(MPI_Comm comm_old, int nnodes, CONST int *index, CONST int *edges, int reorder, MPI_Comm *comm_graph); int (*libMPI_Dist_graph_create_adjacent)(MPI_Comm comm_old, int indegree, CONST int sources[], CONST int sourceweights[], int outdegree, CONST int destinations[], CONST int destweights[], MPI_Info info, int reorder, MPI_Comm *comm_dist_graph); int (*libMPI_Dist_graph_create)(MPI_Comm comm_old, int n, CONST int sources[], CONST int degrees[], CONST int destinations[], CONST int weights[], MPI_Info info, int reorder, MPI_Comm *comm_dist_graph); int (*libMPI_Send)(CONST void *buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm); int (*libMPI_Recv)(void *buf, int count, MPI_Datatype datatype, int source, int tag, MPI_Comm comm, MPI_Status *status); int (*libMPI_Bsend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm); int (*libMPI_Ssend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm); int (*libMPI_Rsend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm); int (*libMPI_Isend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); int (*libMPI_Ibsend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); int (*libMPI_Issend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); int (*libMPI_Irsend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); int (*libMPI_Irecv)(void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); int (*libMPI_Sendrecv)(CONST void *, int, MPI_Datatype, int, int, void *, int, MPI_Datatype, int, int, MPI_Comm, MPI_Status *); int (*libMPI_Sendrecv_replace)(void*, int, MPI_Datatype, int, int, int, int, MPI_Comm, MPI_Status *); int (*libMPI_Send_init)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); int (*libMPI_Bsend_init)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); int (*libMPI_Ssend_init)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); int (*libMPI_Rsend_init)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); int (*libMPI_Recv_init)(void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); int (*libMPI_Start)(MPI_Request *); int (*libMPI_Startall)(int, MPI_Request *); int (*libMPI_Wait)(MPI_Request *, MPI_Status *); int (*libMPI_Test)(MPI_Request *, int *, MPI_Status *); int (*libMPI_Waitany)(int, MPI_Request *, int *, MPI_Status *); int (*libMPI_Testany)(int, MPI_Request *, int *, int *, MPI_Status *); int (*libMPI_Waitall)(int, MPI_Request *, MPI_Status *); int (*libMPI_Testall)(int, MPI_Request *, int *, MPI_Status *); int (*libMPI_Waitsome)(int, MPI_Request *, int *, int *, MPI_Status *); int (*libMPI_Testsome)(int, MPI_Request *, int *, int *, MPI_Status *); int (*libMPI_Probe)(int source, int tag, MPI_Comm comm, MPI_Status *status); int (*libMPI_Iprobe)(int source, int tag, MPI_Comm comm, int *flag, MPI_Status *status); int (*libMPI_Barrier)( MPI_Comm); int (*libMPI_Bcast)(void*, int, MPI_Datatype, int, MPI_Comm); int (*libMPI_Gather)(CONST void*, int, MPI_Datatype, void*, int, MPI_Datatype, int, MPI_Comm); int (*libMPI_Gatherv)(CONST void*, int, MPI_Datatype, void*, CONST int *, CONST int *, MPI_Datatype, int, MPI_Comm); int (*libMPI_Scatter)(CONST void*, int, MPI_Datatype, void*, int, MPI_Datatype, int, MPI_Comm); int (*libMPI_Scatterv)(CONST void*, CONST int *, CONST int *, MPI_Datatype, void*, int, MPI_Datatype, int, MPI_Comm); int (*libMPI_Allgather)(CONST void*, int, MPI_Datatype, void*, int, MPI_Datatype, MPI_Comm); int (*libMPI_Allgatherv)(CONST void*, int, MPI_Datatype, void*, CONST int *, CONST int *, MPI_Datatype, MPI_Comm); int (*libMPI_Alltoall)(CONST void*, int, MPI_Datatype, void*, int, MPI_Datatype, MPI_Comm); int (*libMPI_Alltoallv)(CONST void*, CONST int *, CONST int *, MPI_Datatype, void*, CONST int *, CONST int *, MPI_Datatype, MPI_Comm); int (*libMPI_Reduce)(CONST void*, void*, int, MPI_Datatype, MPI_Op, int, MPI_Comm); int (*libMPI_Allreduce)(CONST void*, void*, int, MPI_Datatype, MPI_Op, MPI_Comm); int (*libMPI_Reduce_scatter)(CONST void*, void*, CONST int *, MPI_Datatype, MPI_Op, MPI_Comm); int (*libMPI_Scan)(CONST void*, void*, int, MPI_Datatype, MPI_Op, MPI_Comm); /* non-blocking collective (available since MPI 3.0) */ #ifdef USE_MPI3 int ( *libMPI_Ibarrier)(MPI_Comm, MPI_Request*); int ( *libMPI_Ibcast)(void*, int, MPI_Datatype, int, MPI_Comm, MPI_Request*); int ( *libMPI_Igather) (const void*, int, MPI_Datatype, void*, int, MPI_Datatype, int, MPI_Comm, MPI_Request*); int ( *libMPI_Igatherv) (const void*, int, MPI_Datatype, void*, const int *, const int *, MPI_Datatype, int, MPI_Comm, MPI_Request*); int ( *libMPI_Iscatter) (const void*, int, MPI_Datatype, void*, int, MPI_Datatype, int, MPI_Comm, MPI_Request*); int ( *libMPI_Iscatterv) (const void*, const int *, const int *, MPI_Datatype, void*, int, MPI_Datatype, int, MPI_Comm, MPI_Request*); int ( *libMPI_Iallgather) (const void*, int, MPI_Datatype, void*, int, MPI_Datatype, MPI_Comm, MPI_Request*); int ( *libMPI_Iallgatherv) (const void*, int, MPI_Datatype, void*, const int *, const int *, MPI_Datatype, MPI_Comm, MPI_Request*); int ( *libMPI_Ialltoall) (const void*, int, MPI_Datatype, void*, int, MPI_Datatype, MPI_Comm, MPI_Request*); int ( *libMPI_Ialltoallv) (const void*, const int *, const int *, MPI_Datatype, void*, const int *, const int *, MPI_Datatype, MPI_Comm, MPI_Request*); int ( *libMPI_Ireduce) (const void* , void*, int, MPI_Datatype, MPI_Op, int, MPI_Comm, MPI_Request*); int ( *libMPI_Iallreduce) (const void*, void*, int, MPI_Datatype, MPI_Op, MPI_Comm, MPI_Request*); int ( *libMPI_Ireduce_scatter) (const void*, void*, const int *, MPI_Datatype, MPI_Op, MPI_Comm, MPI_Request*); int ( *libMPI_Iscan) (const void*, void*, int, MPI_Datatype, MPI_Op, MPI_Comm, MPI_Request*); #endif int ( *libMPI_Get) (void *, int, MPI_Datatype, int, MPI_Aint, int, MPI_Datatype, MPI_Win); int ( *libMPI_Put) (CONST void *, int, MPI_Datatype, int, MPI_Aint, int, MPI_Datatype, MPI_Win); int (*libMPI_Get)(void *, int, MPI_Datatype, int, MPI_Aint, int, MPI_Datatype, MPI_Win); int (*libMPI_Put)(CONST void *, int, MPI_Datatype, int, MPI_Aint, int, MPI_Datatype, MPI_Win); int (*libMPI_Comm_spawn)(CONST char *command, char *argv[], int maxprocs, MPI_Info info, int root, MPI_Comm comm, MPI_Comm *intercomm, int array_of_errcodes[]); /* fortran bindings */ void (*libmpi_init_)(int*e); void (*libmpi_init_thread_)(int*, int*, int*); void (*libmpi_finalize_)(int*); void (*libmpi_barrier_)(MPI_Comm*, int*); void (*libmpi_comm_size_)(MPI_Comm*, int*, int*); void (*libmpi_comm_rank_)(MPI_Comm*, int*, int*); void (*libmpi_comm_get_parent_)(MPI_Comm *, int*); void (*libmpi_type_size_)(MPI_Datatype *, int *, int*); void (*libmpi_cancel_)(MPI_Request*, int*); int (*libmpi_comm_create_)(int*, int*, int*, int*); int (*libmpi_comm_create_group_)(int*, int*, int*, int*, int*); int (*libmpi_comm_split_)(int*, int*, int*, int*, int*); int (*libmpi_comm_dup_)(int*, int*, int*); int (*libmpi_comm_dup_with_info_)(int*, int*, int*, int*); int (*libmpi_comm_split_type_)(int*, int*, int*, int*, int*); int (*libmpi_intercomm_create_)(int*, int*, int*, int*, int*, int*, int*); int (*libmpi_intercomm_merge_)(int*, int*, int*, int*); int (*libmpi_cart_sub_)(int*, int*, int*, int*); int (*libmpi_cart_create_)(int*, int*, int*, int*, int*, int*, int*); int (*libmpi_graph_create_)(int*, int*, int*, int*, int*, int*, int*); int (*libmpi_dist_graph_create_adjacent_)(int*, int*, int*, int*, int*, int*, int*, int*, int*, int*, int*); int (*libmpi_dist_graph_create_)(int*, int*, int*,int*, int*, int*,int*, int*, int*, int*); void (*libmpi_send_)(void*, int*, MPI_Datatype*, int*, int*, int*); void (*libmpi_recv_)(void*, int*, MPI_Datatype*, int*, int *, MPI_Status *, int*); void (*libmpi_sendrecv_)(void *, int, MPI_Datatype, int, int, void *, int, MPI_Datatype, int, int, MPI_Comm, MPI_Status *, int*); void (*libmpi_sendrecv_replace_)(void*, int, MPI_Datatype, int, int, int, int, MPI_Comm, MPI_Status *, int*); void (*libmpi_bsend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, int*); void (*libmpi_ssend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, int*); void (*libmpi_rsend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, int*); void (*libmpi_isend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request*, int*); void (*libmpi_ibsend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request*, int*); void (*libmpi_issend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); void (*libmpi_irsend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); void (*libmpi_irecv_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); void (*libmpi_wait_)(MPI_Request*, MPI_Status*, int*); void (*libmpi_test_)(MPI_Request*, int*, MPI_Status*, int*); void (*libmpi_waitany_)(int*, MPI_Request *, int *, MPI_Status *, int*); void (*libmpi_testany_)(int*, MPI_Request *, int *, int *, MPI_Status *, int*); void (*libmpi_waitall_)(int*, MPI_Request *, MPI_Status *, int*); void (*libmpi_testall_)(int*, MPI_Request *, int *, MPI_Status *, int*); void (*libmpi_waitsome_)(int*, MPI_Request *, int *, int *, MPI_Status *, int*); void (*libmpi_testsome_)(int*, MPI_Request *, int *, int *, MPI_Status *, int*); void (*libmpi_probe_)(int* source, int* tag, MPI_Comm* comm, MPI_Status *status, int* err); void (*libmpi_iprobe_)(int* source, int* tag, MPI_Comm* comm, int *flag, MPI_Status *status, int* err); void (*libmpi_get_)(void *, int*, MPI_Datatype*, int*, MPI_Aint*, int*, MPI_Datatype*, MPI_Win*, int*); void (*libmpi_put_)(void *, int*, MPI_Datatype*, int*, MPI_Aint*, int*, MPI_Datatype*, MPI_Win*, int*); void (*libmpi_bcast_)(void*, int*, MPI_Datatype*, int*, MPI_Comm*, int*); void (*libmpi_gather_)(void*, int*, MPI_Datatype*, void*, int*, MPI_Datatype*, int*, MPI_Comm*, int*); void (*libmpi_gatherv_)(void*, int*, MPI_Datatype*, void*, int*, int*, MPI_Datatype*, int*, MPI_Comm*); void (*libmpi_scatter_)(void*, int*, MPI_Datatype*, void*, int*, MPI_Datatype*, int*, MPI_Comm*, int*); void (*libmpi_scatterv_)(void*, int*, int*, MPI_Datatype*, void*, int*, MPI_Datatype*, int*, MPI_Comm*, int*); void (*libmpi_allgather_)(void*, int*, MPI_Datatype*, void*, int*, MPI_Datatype*, MPI_Comm*, int*); void (*libmpi_allgatherv_)(void*, int*, MPI_Datatype*, void*, int*, int*, MPI_Datatype*, MPI_Comm*); void (*libmpi_alltoall_)(void*, int*, MPI_Datatype*, void*, int*, MPI_Datatype*, MPI_Comm*, int*); void (*libmpi_alltoallv_)(void*, int*, int*, MPI_Datatype*, void*, int*, int*, MPI_Datatype*, MPI_Comm*, int*); void (*libmpi_reduce_)(void*, void*, int*, MPI_Datatype*, MPI_Op*, int*, MPI_Comm*, int*); void (*libmpi_allreduce_)(void*, void*, int*, MPI_Datatype*, MPI_Op*, MPI_Comm*, int*); void (*libmpi_reduce_scatter_)(void*, void*, int*, MPI_Datatype*, MPI_Op*, MPI_Comm*, int*); void (*libmpi_scan_)(void*, void*, int*, MPI_Datatype*, MPI_Op*, MPI_Comm*, int*); #ifdef USE_MPI3 /* non-blocking collective (available since MPI 3.0) */ void (*libmpi_ibarrier_)(MPI_Fint*, MPI_Fint*, int*); void (*libmpi_ibcast_)(void*, int*, MPI_Fint*, int*, MPI_Fint*, MPI_Fint*, int*); void (*libmpi_igather_)(const void*, int*, MPI_Fint*, void*, int*, MPI_Fint*, int*, MPI_Fint*, MPI_Fint*, int*); void (*libmpi_igatherv_)(const void*, int*, MPI_Fint*, void*, const int *, const int *, MPI_Fint*, int*, MPI_Fint*, MPI_Fint*, int*); void (*libmpi_iscatter_)(const void*, int*, MPI_Fint*, void*, int*, MPI_Fint*, int*, MPI_Fint*, MPI_Fint*, int*); void (*libmpi_iscatterv_)(const void*, const int *, const int *, MPI_Fint*, void*, int*, MPI_Fint*, int*, MPI_Fint*, MPI_Fint*, int*); void (*libmpi_iallgather_)(const void*, int*, MPI_Fint*, void*, int*, MPI_Fint*, MPI_Fint*, MPI_Fint*, int*); void (*libmpi_iallgatherv_)(const void*, int*, MPI_Fint*, void*, const int *, const int *, MPI_Fint*, MPI_Fint*, MPI_Fint*, int*); void (*libmpi_ialltoall_)(const void*, int*, MPI_Fint*, void*, int*, MPI_Fint*, MPI_Fint*, MPI_Fint*, int*); void (*libmpi_ialltoallv_)(const void*, const int *, const int *, MPI_Fint*, void*, const int *, const int *, MPI_Fint*, MPI_Fint*, MPI_Fint*, int*); void (*libmpi_ireduce_)(const void* , void*, int*, MPI_Fint*, MPI_Op, int*, MPI_Fint*, MPI_Fint*, int*); void (*libmpi_iallreduce_)(const void*, void*, int*, MPI_Fint*, MPI_Op, MPI_Fint*, MPI_Fint*, int*); void (*libmpi_ireduce_scatter_)(const void*, void*, const int *, MPI_Fint*, MPI_Op, MPI_Fint*, MPI_Fint*, int*); void (*libmpi_iscan_)(const void*, void*, int*, MPI_Fint*, MPI_Op, MPI_Fint*, MPI_Fint*, int*); #endif void (*libmpi_comm_spawn_)(char *command, char **argv, int *maxprocs, MPI_Info *info, int *root, MPI_Comm *comm, MPI_Comm *intercomm, int *array_of_errcodes, int*error); void (*libmpi_send_init_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); void (*libmpi_bsend_init_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); void (*libmpi_ssend_init_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); void (*libmpi_rsend_init_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); void (*libmpi_recv_init_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); void (*libmpi_start_)(MPI_Request *, int*); void (*libmpi_startall_)(int*, MPI_Request *, int*); struct __ezt_mpi_info { int rank; int size; int mpi_any_source; int mpi_any_tag; app_ptr mpi_request_null; int mpi_proc_null; app_ptr mpi_comm_world; app_ptr mpi_comm_self; int ppid; /* Process identifier. * It corresponds to the global MPI rank unless the process was spawned. * In that case, the identifier is the concatenation of the parent process id * and the global rank. * For example process id 0_1_3 has a global rank of 3 and is has been spawned by process 0_1 * Process 0_1 has a global rank of 1 and was spawned by process 0 */ char* proc_id; }; static int __mpi_init_called = 0; static struct __ezt_mpi_info mpi_infos; /* Functions that intercept MPI calls * Basically each function create an event this the arguments * passed to the function. * It then call the actual MPI function (using the appropriate * callback) with the same args */ int MPI_Comm_spawn(CONST char *command, char *argv[], int maxprocs, MPI_Info info, int root, MPI_Comm comm, MPI_Comm *intercomm, int array_of_errcodes[]) { /* Instead of running command argv, we have to run 'env LD_PRELOAD=xxx command argv' Thus, we have to provide a new argv array */ /* retrieve LD_PRELOAD command set by EZTrace */ char* ld_preload = getenv(LD_PRELOAD_NAME); char* ld_preload_str = NULL; int ret __attribute__ ((__unused__)); ret = asprintf(&ld_preload_str, "%s=%s", LD_PRELOAD_NAME, ld_preload); /* count the number of args */ int argc = 0; if (argv != MPI_ARGV_NULL) for (argc = 0; argv[argc] != NULL; argc++) { } /* create a new argv array */ int new_argc = argc + 3; char **new_argv = (char**) malloc(sizeof(char*) * new_argc); new_argv[0] = ld_preload_str; ret = asprintf(&new_argv[1], "%s", command); int i; for (i = 0; i < argc; i++) new_argv[i + 2] = argv[i]; new_argv[i + 2] = NULL; ret = libMPI_Comm_spawn("env", new_argv, maxprocs, info, root, comm, intercomm, array_of_errcodes); /* Now that the processes are launched, tell them our proc_id so that the filenames are not messed up */ int f_size; /* number of children actually created */ int proc_id_len = strlen(mpi_infos.proc_id) + 1; int my_pid = getpid(); MPI_Comm_remote_size(*intercomm, &f_size); EZTRACE_EVENT_FORCE_RECORD_PACKED_2(EZTRACE_MPI_SPAWN, my_pid, f_size); for (i = 0; i < f_size; i++) { MPI_Send(&proc_id_len, 1, MPI_INTEGER, i, 0, *intercomm); MPI_Send(mpi_infos.proc_id, proc_id_len, MPI_CHAR, i, 0, *intercomm); MPI_Send(&my_pid, 1, MPI_INTEGER, i, 0, *intercomm); } /* Here, we shall not free ld_preload, since it may modify the environment of the process ! (man getenv) */ free(new_argv); free(ld_preload_str); FUNCTION_ENTRY; return ret; } int MPI_Comm_get_parent(MPI_Comm *parent) { if (!libMPI_Comm_get_parent) { /* MPI_Comm_get_parent was not found. Let's assume the application doesn't use it. */ *parent = MPI_COMM_NULL; return MPI_SUCCESS; } return libMPI_Comm_get_parent(parent); } int MPI_Comm_size(MPI_Comm c, int *s) { return libMPI_Comm_size(c, s); } int MPI_Comm_rank(MPI_Comm c, int *r) { return libMPI_Comm_rank(c, r); } int MPI_Type_size(MPI_Datatype datatype, int *size) { return libMPI_Type_size(datatype, size); } int MPI_Finalize() { FUNCTION_ENTRY; return libMPI_Finalize(); } void ezt_mpi_initialize_trace(); /* internal function * This function is used by the various MPI_Init* functions (C * and Fortran versions) * This function add informations to the trace (rank, etc.) * and set the trace filename. */ void __mpi_init_generic() { int ret __attribute__ ((__unused__)); MPI_Comm parentcomm; MPI_Comm_get_parent(&parentcomm); libMPI_Comm_size(MPI_COMM_WORLD, &mpi_infos.size); libMPI_Comm_rank(MPI_COMM_WORLD, &mpi_infos.rank); if (parentcomm == MPI_COMM_NULL) { /* This process is a 'normal' process (ie. it wasn't spawned) */ ret = asprintf(&mpi_infos.proc_id, "%d", mpi_infos.rank); mpi_infos.ppid = -1; } else { /* This process was spawned. * We have to get the parent process information */ char *father_proc_id; int father_proc_id_len = -1; /* Get the parent process id */ libMPI_Recv(&father_proc_id_len, 1, MPI_INTEGER, 0, 0, parentcomm, MPI_STATUS_IGNORE); father_proc_id = (char*) malloc(sizeof(char) * father_proc_id_len); libMPI_Recv(father_proc_id, father_proc_id_len, MPI_CHAR, 0, 0, parentcomm, MPI_STATUS_IGNORE); libMPI_Recv(&mpi_infos.ppid, 1, MPI_INTEGER, 0, 0, parentcomm, MPI_STATUS_IGNORE); ret = asprintf(&mpi_infos.proc_id, "%s_%d", father_proc_id, mpi_infos.rank); free(father_proc_id); } libMPI_Barrier(MPI_COMM_WORLD); mpi_infos.mpi_any_source=MPI_ANY_SOURCE; mpi_infos.mpi_any_tag = MPI_ANY_TAG; mpi_infos.mpi_proc_null = MPI_PROC_NULL; mpi_infos.mpi_request_null = (app_ptr)MPI_REQUEST_NULL; mpi_infos.mpi_comm_world = (app_ptr)MPI_COMM_WORLD; mpi_infos.mpi_comm_self = (app_ptr)MPI_COMM_SELF; __mpi_init_called = 1; ezt_mpi_initialize_trace(); } /* This function record initialization events. It is called during mpi_init if * autostart is enabled or when eztrace_start is reached */ void ezt_mpi_initialize_trace() { static int mpi_trace_initialized = 0; if(__ezt_trace.status == ezt_trace_status_running || __ezt_trace.status == ezt_trace_status_paused) { if (!mpi_trace_initialized) { assert(__mpi_init_called); mpi_trace_initialized = 1; if (mpi_infos.ppid>=0) EZTRACE_EVENT_FORCE_RECORD_PACKED_2(EZTRACE_MPI_SPAWNED, mpi_infos.ppid, mpi_infos.rank); char *filename= NULL; asprintf(&filename, "eztrace_log_rank_%s", mpi_infos.proc_id); eztrace_set_filename(filename); EZTRACE_EVENT_FORCE_RECORD_PACKED_6(EZTRACE_MPI_INIT, mpi_infos.rank, mpi_infos.size, mpi_infos.mpi_any_source, mpi_infos.mpi_any_tag, (app_ptr)mpi_infos.mpi_request_null, mpi_infos.mpi_proc_null); EZTRACE_EVENT_FORCE_RECORD_PACKED_2(EZTRACE_MPI_INIT_Info, (app_ptr)mpi_infos.mpi_comm_world, (app_ptr)mpi_infos.mpi_comm_self); } } } int MPI_Init_thread(int *argc, char ***argv, int required, int *provided) { int ret = libMPI_Init_thread(argc, argv, required, provided); __mpi_init_generic(); FUNCTION_ENTRY; return ret; } int MPI_Init(int * argc, char***argv) { int ret = libMPI_Init(argc, argv); __mpi_init_generic(); FUNCTION_ENTRY; return ret; } static void __ezt_new_mpi_comm(MPI_Comm comm) { MPI_Group world_group, group; int gsize; /* size of the group */ FUNCTION_ENTRY; if(comm == MPI_COMM_NULL) return ; MPI_Comm_group(MPI_COMM_WORLD, &world_group); MPI_Comm_group(comm, &group); MPI_Group_size(group, &gsize); int *local_ranks = malloc(sizeof(int) * gsize); int *global_ranks = malloc(sizeof(int) * gsize); int i; for (i = 0; i < gsize; i++) local_ranks[i] = i; /* translate the ranks of the local group into rank of the world group */ MPI_Group_translate_ranks(group, gsize, local_ranks, world_group, global_ranks); /* record the information we need to use the communicator */ EZTRACE_EVENT_FORCE_RECORD_PACKED_2(EZTRACE_MPI_NEW_COMM, (app_ptr)comm, gsize); for (i = 0; i < gsize; i++) { EZTRACE_EVENT_FORCE_RECORD_PACKED_1(EZTRACE_MPI_NEW_COMM_Info, global_ranks[i]); } } #ifdef DEBUG #define CHECK_COMMUNICATOR(newcomm, comm) \ do { \ if((newcomm) == MPI_COMM_NULL) { \ int rank, size; \ MPI_Comm_rank(MPI_COMM_WORLD, &rank); \ MPI_Comm_size(MPI_COMM_WORLD, &size); \ fprintf(stderr, "Warning: new communicator (%x) is NULL ! This communicator was created from communicator %x using %s\n", \ (void*)(newcomm), (void*)(comm), __FUNCTION__); \ } \ } while(0) #else #define CHECK_COMMUNICATOR(newcomm, comm) (void)(0) #endif #define __EZT_NEW_COMM(new_comm, old_comm) \ do { \ if (ret == MPI_SUCCESS) { \ CHECK_COMMUNICATOR(new_comm, old_comm); \ __ezt_new_mpi_comm(new_comm); \ } else { \ fprintf(stderr, "Warning: %s returned %d\n", __FUNCTION__, ret); \ } \ } while(0) int MPI_Comm_disconnect(MPI_Comm * comm) { FUNCTION_ENTRY; if (comm) EZTRACE_EVENT_FORCE_RECORD_PACKED_1(EZTRACE_MPI_DELETE_COMM, (app_ptr)*comm); return libMPI_Comm_disconnect(comm); } int MPI_Comm_free(MPI_Comm *comm) { FUNCTION_ENTRY; if (comm) EZTRACE_EVENT_FORCE_RECORD_PACKED_1(EZTRACE_MPI_DELETE_COMM, (app_ptr)*comm); return libMPI_Comm_free(comm); } int MPI_Comm_create(MPI_Comm comm, MPI_Group group, MPI_Comm *newcomm) { FUNCTION_ENTRY; int ret = libMPI_Comm_create(comm, group, newcomm); __EZT_NEW_COMM(*newcomm, comm); return ret; } int MPI_Comm_create_group(MPI_Comm comm, MPI_Group group, int tag, MPI_Comm * newcomm){ FUNCTION_ENTRY; int ret = libMPI_Comm_create_group(comm, group, tag, newcomm); __EZT_NEW_COMM(*newcomm, comm); return ret; } int MPI_Comm_split(MPI_Comm comm, int color, int key, MPI_Comm *newcomm) { FUNCTION_ENTRY; int ret = libMPI_Comm_split(comm, color, key, newcomm); __EZT_NEW_COMM(*newcomm, comm); return ret; } int MPI_Comm_dup(MPI_Comm comm, MPI_Comm *newcomm) { FUNCTION_ENTRY; int ret = libMPI_Comm_dup(comm, newcomm); __EZT_NEW_COMM(*newcomm, comm); return ret; } int MPI_Comm_dup_with_info(MPI_Comm comm, MPI_Info info, MPI_Comm * newcomm) { FUNCTION_ENTRY; int ret = libMPI_Comm_dup_with_info(comm, info, newcomm); __EZT_NEW_COMM(*newcomm, comm); return ret; } int MPI_Comm_split_type(MPI_Comm comm, int split_type, int key, MPI_Info info, MPI_Comm * newcomm) { FUNCTION_ENTRY; int ret = libMPI_Comm_split_type(comm, split_type, key, info, newcomm); __EZT_NEW_COMM(*newcomm, comm); return ret; } int MPI_Intercomm_create(MPI_Comm local_comm, int local_leader, MPI_Comm peer_comm, int remote_leader, int tag, MPI_Comm *newintercomm) { FUNCTION_ENTRY; int ret = libMPI_Intercomm_create(local_comm, local_leader, peer_comm, remote_leader, tag, newintercomm); __EZT_NEW_COMM(*newintercomm, local_comm); return ret; } int MPI_Intercomm_merge(MPI_Comm intercomm, int high, MPI_Comm *newintracomm) { FUNCTION_ENTRY; int ret = libMPI_Intercomm_merge(intercomm, high, newintracomm); __EZT_NEW_COMM(*newintracomm, intercomm); return ret; } int MPI_Cart_sub(MPI_Comm old_comm, CONST int *belongs, MPI_Comm *new_comm) { FUNCTION_ENTRY; int ret = libMPI_Cart_sub(old_comm, belongs, new_comm); __EZT_NEW_COMM(*new_comm, old_comm); return ret; } int MPI_Cart_create(MPI_Comm comm_old, int ndims, CONST int *dims, CONST int *periods, int reorder, MPI_Comm *comm_cart) { FUNCTION_ENTRY; int ret = libMPI_Cart_create(comm_old, ndims, dims, periods, reorder, comm_cart); __EZT_NEW_COMM(*comm_cart, old_comm); return ret; } int MPI_Graph_create(MPI_Comm comm_old, int nnodes, CONST int *index, CONST int *edges, int reorder, MPI_Comm *comm_graph) { FUNCTION_ENTRY; int ret = libMPI_Graph_create(comm_old, nnodes, index, edges, reorder, comm_graph); __EZT_NEW_COMM(*comm_graph, old_comm); return ret; } int MPI_Dist_graph_create(MPI_Comm comm_old, int n, CONST int sources[], CONST int degrees[], CONST int destinations[], CONST int weights[], MPI_Info info, int reorder, MPI_Comm *comm_dist_graph) { FUNCTION_ENTRY; int ret = libMPI_Dist_graph_create(comm_old, n, sources, degrees, destinations, weights, info, reorder, comm_dist_graph); __EZT_NEW_COMM(*comm_dist_graph, comm_old); return ret; } int MPI_Dist_graph_create_adjacent(MPI_Comm comm_old, int indegree, CONST int sources[], CONST int sourceweights[], int outdegree, CONST int destinations[], CONST int destweights[], MPI_Info info, int reorder, MPI_Comm *comm_dist_graph) { FUNCTION_ENTRY; int ret = libMPI_Dist_graph_create_adjacent(comm_old, indegree, sources, sourceweights, outdegree, destinations, destweights, info, reorder, comm_dist_graph); __EZT_NEW_COMM(*comm_dist_graph, comm_old); return ret; } START_INTERCEPT_MODULE(mpi) INTERCEPT2("MPI_Init_thread", libMPI_Init_thread) INTERCEPT2("MPI_Init", libMPI_Init) INTERCEPT2("MPI_Finalize", libMPI_Finalize) INTERCEPT2("MPI_Barrier", libMPI_Barrier) INTERCEPT2("MPI_Comm_size", libMPI_Comm_size) INTERCEPT2("MPI_Comm_rank", libMPI_Comm_rank) INTERCEPT2("MPI_Comm_get_parent", libMPI_Comm_get_parent) INTERCEPT2("MPI_Type_size", libMPI_Type_size) INTERCEPT2("MPI_Cancel", libMPI_Cancel) INTERCEPT2("MPI_Comm_disconnect", libMPI_Comm_disconnect) INTERCEPT2("MPI_Comm_free", libMPI_Comm_free) INTERCEPT2("MPI_Comm_create", libMPI_Comm_create) INTERCEPT2("MPI_Comm_create_group", libMPI_Comm_create_group) INTERCEPT2("MPI_Comm_split", libMPI_Comm_split) INTERCEPT2("MPI_Comm_dup", libMPI_Comm_dup) INTERCEPT2("MPI_Comm_dup_with_info", libMPI_Comm_dup_with_info) INTERCEPT2("MPI_Comm_split_type", libMPI_Comm_split_type) INTERCEPT2("MPI_Intercomm_create", libMPI_Intercomm_create) INTERCEPT2("MPI_Intercomm_merge", libMPI_Intercomm_merge) INTERCEPT2("MPI_Cart_sub", libMPI_Cart_sub) INTERCEPT2("MPI_Cart_create", libMPI_Cart_create) INTERCEPT2("MPI_Graph_create", libMPI_Graph_create) INTERCEPT2("MPI_Dist_graph_create", libMPI_Dist_graph_create) INTERCEPT2("MPI_Dist_graph_create_adjacent", libMPI_Dist_graph_create_adjacent) INTERCEPT2("MPI_Send", libMPI_Send) INTERCEPT2("MPI_Recv", libMPI_Recv) INTERCEPT2("MPI_Sendrecv", libMPI_Sendrecv) INTERCEPT2("MPI_Sendrecv_replace", libMPI_Sendrecv_replace) INTERCEPT2("MPI_Bsend", libMPI_Bsend) INTERCEPT2("MPI_Ssend", libMPI_Ssend) INTERCEPT2("MPI_Rsend", libMPI_Rsend) INTERCEPT2("MPI_Isend", libMPI_Isend) INTERCEPT2("MPI_Ibsend", libMPI_Ibsend) INTERCEPT2("MPI_Issend", libMPI_Issend) INTERCEPT2("MPI_Irsend", libMPI_Irsend) INTERCEPT2("MPI_Irecv", libMPI_Irecv) INTERCEPT2("MPI_Wait", libMPI_Wait) INTERCEPT2("MPI_Waitall", libMPI_Waitall) INTERCEPT2("MPI_Waitany", libMPI_Waitany) INTERCEPT2("MPI_Waitsome", libMPI_Waitsome) INTERCEPT2("MPI_Test", libMPI_Test) INTERCEPT2("MPI_Testall", libMPI_Testall) INTERCEPT2("MPI_Testany", libMPI_Testany) INTERCEPT2("MPI_Testsome", libMPI_Testsome) INTERCEPT2("MPI_Iprobe", libMPI_Iprobe) INTERCEPT2("MPI_Probe", libMPI_Probe) INTERCEPT2("MPI_Get", libMPI_Get) INTERCEPT2("MPI_Put", libMPI_Put) INTERCEPT2("MPI_Bcast", libMPI_Bcast) INTERCEPT2("MPI_Gather", libMPI_Gather) INTERCEPT2("MPI_Gatherv", libMPI_Gatherv) INTERCEPT2("MPI_Scatter", libMPI_Scatter) INTERCEPT2("MPI_Scatterv", libMPI_Scatterv) INTERCEPT2("MPI_Allgather", libMPI_Allgather) INTERCEPT2("MPI_Allgatherv", libMPI_Allgatherv) INTERCEPT2("MPI_Alltoall", libMPI_Alltoall) INTERCEPT2("MPI_Alltoallv", libMPI_Alltoallv) INTERCEPT2("MPI_Reduce", libMPI_Reduce) INTERCEPT2("MPI_Allreduce", libMPI_Allreduce) INTERCEPT2("MPI_Reduce_scatter", libMPI_Reduce_scatter) INTERCEPT2("MPI_Scan", libMPI_Scan) #ifdef USE_MPI3 INTERCEPT2("MPI_Ibarrier", libMPI_Ibarrier) INTERCEPT2("MPI_Ibcast", libMPI_Ibcast) INTERCEPT2("MPI_Igather", libMPI_Igather) INTERCEPT2("MPI_Igatherv", libMPI_Igatherv) INTERCEPT2("MPI_Iscatter", libMPI_Iscatter) INTERCEPT2("MPI_Iscatterv", libMPI_Iscatterv) INTERCEPT2("MPI_Iallgather", libMPI_Iallgather) INTERCEPT2("MPI_Iallgatherv", libMPI_Iallgatherv) INTERCEPT2("MPI_Ialltoall", libMPI_Ialltoall) INTERCEPT2("MPI_Ialltoallv", libMPI_Ialltoallv) INTERCEPT2("MPI_Ireduce", libMPI_Ireduce) INTERCEPT2("MPI_Iallreduce", libMPI_Iallreduce) INTERCEPT2("MPI_Ireduce_scatter", libMPI_Ireduce_scatter) INTERCEPT2("MPI_Iscan", libMPI_Iscan) #endif INTERCEPT2("MPI_Comm_spawn", libMPI_Comm_spawn) INTERCEPT2("MPI_Send_init", libMPI_Send_init) INTERCEPT2("MPI_Bsend_init", libMPI_Bsend_init) INTERCEPT2("MPI_Ssend_init", libMPI_Ssend_init) INTERCEPT2("MPI_Rsend_init", libMPI_Rsend_init) INTERCEPT2("MPI_Recv_init", libMPI_Recv_init) INTERCEPT2("MPI_Start", libMPI_Start) INTERCEPT2("MPI_Startall", libMPI_Startall) /* fortran binding */ INTERCEPT2("mpi_init_", libmpi_init_) INTERCEPT2("mpi_init_thread_", libmpi_init_thread_) INTERCEPT2("mpi_init_", libmpi_init_) INTERCEPT2("mpi_finalize_", libmpi_finalize_) INTERCEPT2("mpi_barrier_", libmpi_barrier_) INTERCEPT2("mpi_comm_size_", libmpi_comm_size_) INTERCEPT2("mpi_comm_rank_", libmpi_comm_rank_) INTERCEPT2("mpi_comm_get_parent_", libmpi_comm_get_parent_) INTERCEPT2("mpi_type_size_", libmpi_type_size_) INTERCEPT2("mpi_cancel_", libmpi_cancel_) INTERCEPT2("mpi_comm_create_", libmpi_comm_create_) INTERCEPT2("mpi_comm_create_group_", libmpi_comm_create_group_) INTERCEPT2("mpi_comm_split_", libmpi_comm_split_) INTERCEPT2("mpi_comm_dup_", libmpi_comm_dup_) INTERCEPT2("mpi_comm_dup_with_info_", libmpi_comm_dup_with_info_) INTERCEPT2("mpi_comm_split_type_", libmpi_comm_split_type_) INTERCEPT2("mpi_intercomm_create_", libmpi_intercomm_create_) INTERCEPT2("mpi_intercomm_merge_", libmpi_intercomm_merge_) INTERCEPT2("mpi_cart_sub_", libmpi_cart_sub_) INTERCEPT2("mpi_cart_create_", libmpi_cart_create_) INTERCEPT2("mpi_graph_create_", libmpi_graph_create_) INTERCEPT2("mpi_dist_graph_create_", libmpi_dist_graph_create_) INTERCEPT2("mpi_dist_graph_create_adjacent_", libmpi_dist_graph_create_adjacent_) INTERCEPT2("mpi_send_", libmpi_send_) INTERCEPT2("mpi_recv_", libmpi_recv_) INTERCEPT2("mpi_sendrecv_", libmpi_sendrecv_) INTERCEPT2("mpi_sendrecv_replace_", libmpi_sendrecv_replace_) INTERCEPT2("mpi_bsend_", libmpi_bsend_) INTERCEPT2("mpi_ssend_", libmpi_ssend_) INTERCEPT2("mpi_rsend_", libmpi_rsend_) INTERCEPT2("mpi_isend_", libmpi_isend_) INTERCEPT2("mpi_ibsend_", libmpi_ibsend_) INTERCEPT2("mpi_issend_", libmpi_issend_) INTERCEPT2("mpi_irsend_", libmpi_irsend_) INTERCEPT2("mpi_irecv_", libmpi_irecv_) INTERCEPT2("mpi_wait_", libmpi_wait_) INTERCEPT2("mpi_waitall_", libmpi_waitall_) INTERCEPT2("mpi_waitany_", libmpi_waitany_) INTERCEPT2("mpi_waitsome_", libmpi_waitsome_) INTERCEPT2("mpi_test_", libmpi_test_) INTERCEPT2("mpi_testall_", libmpi_testall_) INTERCEPT2("mpi_testany_", libmpi_testany_) INTERCEPT2("mpi_testsome_", libmpi_testsome_) INTERCEPT2("mpi_probe_", libmpi_probe_) INTERCEPT2("mpi_iprobe_", libmpi_iprobe_) INTERCEPT2("mpi_get_", libmpi_get_) INTERCEPT2("mpi_put_", libmpi_put_) INTERCEPT2("mpi_bcast_", libmpi_bcast_) INTERCEPT2("mpi_gather_", libmpi_gather_) INTERCEPT2("mpi_gatherv_", libmpi_gatherv_) INTERCEPT2("mpi_scatter_", libmpi_scatter_) INTERCEPT2("mpi_scatterv_", libmpi_scatterv_) INTERCEPT2("mpi_allgather_", libmpi_allgather_) INTERCEPT2("mpi_allgatherv_", libmpi_allgatherv_) INTERCEPT2("mpi_alltoall_", libmpi_alltoall_) INTERCEPT2("mpi_alltoallv_", libmpi_alltoallv_) INTERCEPT2("mpi_reduce_", libmpi_reduce_) INTERCEPT2("mpi_allreduce_", libmpi_allreduce_) INTERCEPT2("mpi_reduce_scatter_", libmpi_reduce_scatter_) INTERCEPT2("mpi_scan_", libmpi_scan_) #ifdef USE_MPI3 INTERCEPT2("mpi_ibarrier_", libmpi_ibarrier_) INTERCEPT2("mpi_ibarrier_", libmpi_ibarrier_) INTERCEPT2("mpi_ibcast_", libmpi_ibcast_) INTERCEPT2("mpi_igather_", libmpi_igather_) INTERCEPT2("mpi_igatherv_", libmpi_igatherv_) INTERCEPT2("mpi_iscatter_", libmpi_iscatter_) INTERCEPT2("mpi_iscatterv_", libmpi_iscatterv_) INTERCEPT2("mpi_iallgather_", libmpi_iallgather_) INTERCEPT2("mpi_iallgatherv_", libmpi_iallgatherv_) INTERCEPT2("mpi_ialltoall_", libmpi_ialltoall_) INTERCEPT2("mpi_ialltoallv_", libmpi_ialltoallv_) INTERCEPT2("mpi_ireduce_", libmpi_ireduce_) INTERCEPT2("mpi_iallreduce_", libmpi_iallreduce_) INTERCEPT2("mpi_ireduce_scatter_", libmpi_ireduce_scatter_) INTERCEPT2("mpi_iscan_", libmpi_iscan_) #endif INTERCEPT2("mpi_comm_spawn_", libmpi_comm_spawn_) INTERCEPT2("mpi_send_init_", libmpi_send_init_) INTERCEPT2("mpi_bsend_init_", libmpi_bsend_init_) INTERCEPT2("mpi_ssend_init_", libmpi_ssend_init_) INTERCEPT2("mpi_rsend_init_", libmpi_rsend_init_) INTERCEPT2("mpi_recv_init_", libmpi_recv_init_) INTERCEPT2("mpi_start_", libmpi_start_) INTERCEPT2("mpi_startall_", libmpi_startall_) END_INTERCEPT_MODULE(mpi) void libinit(void) __attribute__ ((constructor)); void libinit(void) { DYNAMIC_INTERCEPT_ALL_MODULE(mpi); #ifdef EZTRACE_AUTOSTART eztrace_start (); #else /* when the application calls eztrace_start(), * we need to execute ezt_mpi_initialize_trace */ eztrace_register_init_routine(&ezt_mpi_initialize_trace); #endif } void libfinalize(void) __attribute__ ((destructor)); void libfinalize(void) { eztrace_stop(); free(mpi_infos.proc_id); } eztrace-1.1-2/src/modules/mpi/mpi3_f.f90000066400000000000000000000040041265506773700177100ustar00rootroot00000000000000! These routines are specific to MPI3 subroutine MPI_IBarrier(COMM, REQ, IERROR) call MPIF_IBarrier(COMM, REQ, IERROR) return end subroutine MPI_IBCast(BUFFER, COUNT, DATATYPE, ROOT, COMM, REQ, IERROR) call MPIF_IBCast(BUFFER, COUNT, DATATYPE, ROOT, COMM, REQ, IERROR) return end subroutine MPI_IGather(SBUF,SCNT,STYPE,RBUF,RCNT, RTYPE, R, C, REQ, E) call MPIF_IGather(SBUF, SCNT, STYPE, RBUF, RCNT, RTYPE, R, C, REQ, E) return end subroutine MPI_IGatherv(SBUF,SCNT,STYPE,RBUF,RCNT,DSP,RTYPE,R,C,REQ,E) call MPIF_IGatherv(SBUF,SCNT,STYPE,RBUF,RCNT,DSP,RTYPE,R,C,REQ,E) return end subroutine MPI_IScatter(SBUF,SCNT,STYPE,RBUF,RCNT,RTYPE,R,C,REQ,E) call MPIF_IScatter(SBUF, SCNT, STYPE, RBUF, RCNT, RTYPE, R, C,REQ, E) return end subroutine MPI_IScatterv(SBUF,SCNT,DSP,SDTYP,RBUF,RCNT,RTYP,R,C,REQ,E) call MPIF_IScatterv(SBUF,SCNT,DSP,SDTYP,RBUF, RCNT, RTYP, R, C, REQ,E) return end subroutine MPI_IAllgather(SBUF, SCNT, STYP, RBUF, RCNT, RTYP, C, REQ, E) call MPIF_IAllgather(SBUF, SCNT, STYP, RBUF, RCNT, RTYP, C, REQ, E) return end subroutine MPI_IAllgatherv(SB, SC, ST, RB, RC, D, RT, C, REQ,IERROR) call MPIF_IAllgatherv(SB, SC, ST, RB, RC, D, RT, C, REQ,IERROR) return end subroutine MPI_IAlltoall(SB, SC, ST, RB, RC, RT, COMM, REQ,IERROR) call MPIF_IAlltoall(SB, SC, ST, RB, RC, RT, COMM, REQ,IERROR) return end subroutine MPI_IAlltoallv(SB, SC, SD, ST, RB, RC, RD, RT, C, REQ,ERROR) call MPIF_IAlltoallv(SB, SC, SD, ST, RB, RC, RD, RT, C, REQ,ERROR) return end subroutine MPI_IReduce(SBUF, RBUF, CNT, D, OP, ROOT, COMM, REQ,IERROR) call MPIF_IReduce(SBUF, RBUF, CNT, D, OP, ROOT, COMM, REQ,IERROR) return end subroutine MPI_IAllreduce(SBUF, RBUF, CNT, D, OP, COMM, REQ,IERROR) call MPIF_IAllreduce(SBUF, RBUF, CNT, D, OP, COMM, REQ,IERROR) return end subroutine MPI_IReduce_scatter(SBUF, RBUF, RCNT, D, OP, C, REQ,IERROR) call MPIF_IReduce_scatter(SBUF, RBUF, RCNT, D, OP, C, REQ,IERROR) return end subroutine MPI_IScan(SBUF, RBUF, CNT, D, OP, COMM, REQ,IERROR) call MPIF_IScan(SBUF, RBUF, CNT, D, OP, COMM, REQ,IERROR) return end eztrace-1.1-2/src/modules/mpi/mpi_ev_codes.h000066400000000000000000000177511265506773700210350ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef __MPI_EV_CODES_H__ #define __MPI_EV_CODES_H__ #include "ev_codes.h" #ifndef MPI_EVENT_ID #define MPI_EVENT_ID 0x04 #endif #define EZTRACE_MPI_EVENTS_ID SYSTEM_MODULE_ID(MPI_EVENT_ID) #define EZTRACE_MPI_PREFIX GENERATE_SYSTEM_MODULE_PREFIX(EZTRACE_MPI_EVENTS_ID) #define EZTRACE_MPI_INIT (EZTRACE_MPI_PREFIX | 0x0010) #define EZTRACE_MPI_INIT_Info (EZTRACE_MPI_PREFIX | 0x0011) #define EZTRACE_MPI_NEW_COMM (EZTRACE_MPI_PREFIX | 0x0012) #define EZTRACE_MPI_NEW_COMM_Info (EZTRACE_MPI_PREFIX | 0x0013) #define EZTRACE_MPI_DELETE_COMM (EZTRACE_MPI_PREFIX | 0x0014) #define EZTRACE_MPI_START_SEND (EZTRACE_MPI_PREFIX | 0x0001) #define EZTRACE_MPI_STOP_SEND (EZTRACE_MPI_PREFIX | 0x0002) #define EZTRACE_MPI_START_BSEND (EZTRACE_MPI_PREFIX | 0x0003) #define EZTRACE_MPI_STOP_BSEND (EZTRACE_MPI_PREFIX | 0x0004) #define EZTRACE_MPI_START_SSEND (EZTRACE_MPI_PREFIX | 0x0005) #define EZTRACE_MPI_STOP_SSEND (EZTRACE_MPI_PREFIX | 0x0006) #define EZTRACE_MPI_START_RSEND (EZTRACE_MPI_PREFIX | 0x0007) #define EZTRACE_MPI_STOP_RSEND (EZTRACE_MPI_PREFIX | 0x0008) #define EZTRACE_MPI_START_SENDRECV (EZTRACE_MPI_PREFIX | 0x000a) #define EZTRACE_MPI_STOP_SENDRECV (EZTRACE_MPI_PREFIX | 0x000b) #define EZTRACE_MPI_START_SENDRECV_REPLACE (EZTRACE_MPI_PREFIX | 0x000c) #define EZTRACE_MPI_STOP_SENDRECV_REPLACE (EZTRACE_MPI_PREFIX | 0x000d) #define EZTRACE_MPI_ISEND (EZTRACE_MPI_PREFIX | 0x0101) #define EZTRACE_MPI_IBSEND (EZTRACE_MPI_PREFIX | 0x0103) #define EZTRACE_MPI_ISSEND (EZTRACE_MPI_PREFIX | 0x0105) #define EZTRACE_MPI_IRSEND (EZTRACE_MPI_PREFIX | 0x0107) #define EZTRACE_MPI_START_PUT (EZTRACE_MPI_PREFIX | 0x0201) #define EZTRACE_MPI_STOP_PUT (EZTRACE_MPI_PREFIX | 0x0202) #define EZTRACE_MPI_START_GET (EZTRACE_MPI_PREFIX | 0x0203) #define EZTRACE_MPI_STOP_GET (EZTRACE_MPI_PREFIX | 0x0204) #define EZTRACE_MPI_STOP_ISEND (EZTRACE_MPI_PREFIX | 0x0111) #define EZTRACE_MPI_STOP_IBSEND (EZTRACE_MPI_PREFIX | 0x0113) #define EZTRACE_MPI_STOP_ISSEND (EZTRACE_MPI_PREFIX | 0x0115) #define EZTRACE_MPI_STOP_IRSEND (EZTRACE_MPI_PREFIX | 0x0117) #define EZTRACE_MPI_START_RECV (EZTRACE_MPI_PREFIX | 0x1003) #define EZTRACE_MPI_STOP_RECV (EZTRACE_MPI_PREFIX | 0x1004) #define EZTRACE_MPI_IRECV (EZTRACE_MPI_PREFIX | 0x1005) #define EZTRACE_MPI_STOP_IRECV (EZTRACE_MPI_PREFIX | 0x1006) #define EZTRACE_MPI_START_WAIT (EZTRACE_MPI_PREFIX | 0x2001) #define EZTRACE_MPI_STOP_WAIT (EZTRACE_MPI_PREFIX | 0x2002) #define EZTRACE_MPI_TEST_SUCCESS (EZTRACE_MPI_PREFIX | 0x2003) #define EZTRACE_MPI_START_PROBE (EZTRACE_MPI_PREFIX | 0x2004) #define EZTRACE_MPI_STOP_PROBE (EZTRACE_MPI_PREFIX | 0x2005) #define EZTRACE_MPI_IPROBE_SUCCESS (EZTRACE_MPI_PREFIX | 0x2006) #define EZTRACE_MPI_IPROBE_FAILED (EZTRACE_MPI_PREFIX | 0x2007) #define EZTRACE_MPI_START_WAITANY (EZTRACE_MPI_PREFIX | 0x2008) #define EZTRACE_MPI_STOP_WAITANY (EZTRACE_MPI_PREFIX | 0x2009) #define EZTRACE_MPI_START_WAITALL (EZTRACE_MPI_PREFIX | 0x200a) #define EZTRACE_MPI_STOP_WAITALL (EZTRACE_MPI_PREFIX | 0x200b) #define EZTRACE_MPI_STOP_WAIT_FAILED (EZTRACE_MPI_PREFIX | 0x200c) #define EZTRACE_MPI_BCast_info (EZTRACE_MPI_PREFIX | 0x3101) #define EZTRACE_MPI_START_BCast (EZTRACE_MPI_PREFIX | 0x3001) #define EZTRACE_MPI_START_Gather (EZTRACE_MPI_PREFIX | 0x3002) #define EZTRACE_MPI_START_Gatherv (EZTRACE_MPI_PREFIX | 0x3003) #define EZTRACE_MPI_START_Scatter (EZTRACE_MPI_PREFIX | 0x3004) #define EZTRACE_MPI_START_Scatterv (EZTRACE_MPI_PREFIX | 0x3005) #define EZTRACE_MPI_START_Allgather (EZTRACE_MPI_PREFIX | 0x3006) #define EZTRACE_MPI_START_Allgatherv (EZTRACE_MPI_PREFIX | 0x3007) #define EZTRACE_MPI_START_Alltoall (EZTRACE_MPI_PREFIX | 0x3008) #define EZTRACE_MPI_START_Alltoallv (EZTRACE_MPI_PREFIX | 0x3009) #define EZTRACE_MPI_START_Reduce (EZTRACE_MPI_PREFIX | 0x300a) #define EZTRACE_MPI_START_Allreduce (EZTRACE_MPI_PREFIX | 0x300b) #define EZTRACE_MPI_START_Reduce_scatter (EZTRACE_MPI_PREFIX | 0x300c) #define EZTRACE_MPI_START_Scan (EZTRACE_MPI_PREFIX | 0x300d) #define EZTRACE_MPI_START_BARRIER (EZTRACE_MPI_PREFIX | 0x300e) #define EZTRACE_MPI_STOP_BCast (EZTRACE_MPI_PREFIX | 0x3011) #define EZTRACE_MPI_STOP_Gather (EZTRACE_MPI_PREFIX | 0x3012) #define EZTRACE_MPI_STOP_Gatherv (EZTRACE_MPI_PREFIX | 0x3013) #define EZTRACE_MPI_STOP_Scatter (EZTRACE_MPI_PREFIX | 0x3014) #define EZTRACE_MPI_STOP_Scatterv (EZTRACE_MPI_PREFIX | 0x3015) #define EZTRACE_MPI_STOP_Allgather (EZTRACE_MPI_PREFIX | 0x3016) #define EZTRACE_MPI_STOP_Allgatherv (EZTRACE_MPI_PREFIX | 0x3017) #define EZTRACE_MPI_STOP_Alltoall (EZTRACE_MPI_PREFIX | 0x3018) #define EZTRACE_MPI_STOP_Alltoallv (EZTRACE_MPI_PREFIX | 0x3019) #define EZTRACE_MPI_STOP_Reduce (EZTRACE_MPI_PREFIX | 0x301a) #define EZTRACE_MPI_STOP_Allreduce (EZTRACE_MPI_PREFIX | 0x301b) #define EZTRACE_MPI_STOP_Reduce_scatter (EZTRACE_MPI_PREFIX | 0x301c) #define EZTRACE_MPI_STOP_Scan (EZTRACE_MPI_PREFIX | 0x301d) #define EZTRACE_MPI_STOP_BARRIER (EZTRACE_MPI_PREFIX | 0x301e) #define EZTRACE_MPI_IBCAST (EZTRACE_MPI_PREFIX | 0x3021) #define EZTRACE_MPI_IGATHER (EZTRACE_MPI_PREFIX | 0x3022) #define EZTRACE_MPI_IGATHERV (EZTRACE_MPI_PREFIX | 0x3023) #define EZTRACE_MPI_ISCATTER (EZTRACE_MPI_PREFIX | 0x3024) #define EZTRACE_MPI_ISCATTERV (EZTRACE_MPI_PREFIX | 0x3025) #define EZTRACE_MPI_IALLGATHER (EZTRACE_MPI_PREFIX | 0x3026) #define EZTRACE_MPI_IALLGATHERV (EZTRACE_MPI_PREFIX | 0x3027) #define EZTRACE_MPI_IALLTOALL (EZTRACE_MPI_PREFIX | 0x3028) #define EZTRACE_MPI_IALLTOALLV (EZTRACE_MPI_PREFIX | 0x3029) #define EZTRACE_MPI_IREDUCE (EZTRACE_MPI_PREFIX | 0x302a) #define EZTRACE_MPI_IALLREDUCE (EZTRACE_MPI_PREFIX | 0x302b) #define EZTRACE_MPI_IREDUCE_SCATTER (EZTRACE_MPI_PREFIX | 0x302c) #define EZTRACE_MPI_ISCAN (EZTRACE_MPI_PREFIX | 0x302d) #define EZTRACE_MPI_IBARRIER (EZTRACE_MPI_PREFIX | 0x302e) #define EZTRACE_MPI_STOP_IBCAST (EZTRACE_MPI_PREFIX | 0x3121) #define EZTRACE_MPI_STOP_IGATHER (EZTRACE_MPI_PREFIX | 0x3122) #define EZTRACE_MPI_STOP_IGATHERV (EZTRACE_MPI_PREFIX | 0x3123) #define EZTRACE_MPI_STOP_ISCATTER (EZTRACE_MPI_PREFIX | 0x3124) #define EZTRACE_MPI_STOP_ISCATTERV (EZTRACE_MPI_PREFIX | 0x3125) #define EZTRACE_MPI_STOP_IALLGATHER (EZTRACE_MPI_PREFIX | 0x3126) #define EZTRACE_MPI_STOP_IALLGATHERV (EZTRACE_MPI_PREFIX | 0x3127) #define EZTRACE_MPI_STOP_IALLTOALL (EZTRACE_MPI_PREFIX | 0x3128) #define EZTRACE_MPI_STOP_IALLTOALLV (EZTRACE_MPI_PREFIX | 0x3129) #define EZTRACE_MPI_STOP_IREDUCE (EZTRACE_MPI_PREFIX | 0x312a) #define EZTRACE_MPI_STOP_IALLREDUCE (EZTRACE_MPI_PREFIX | 0x312b) #define EZTRACE_MPI_STOP_IREDUCE_SCATTER (EZTRACE_MPI_PREFIX | 0x312c) #define EZTRACE_MPI_STOP_ISCAN (EZTRACE_MPI_PREFIX | 0x312d) #define EZTRACE_MPI_STOP_IBARRIER (EZTRACE_MPI_PREFIX | 0x312e) #define EZTRACE_MPI_SPAWN (EZTRACE_MPI_PREFIX | 0x4001) #define EZTRACE_MPI_SPAWNED (EZTRACE_MPI_PREFIX | 0x4002) #define EZTRACE_MPI_SEND_INIT (EZTRACE_MPI_PREFIX | 0x5001) #define EZTRACE_MPI_BSEND_INIT (EZTRACE_MPI_PREFIX | 0x5002) #define EZTRACE_MPI_RSEND_INIT (EZTRACE_MPI_PREFIX | 0x5003) #define EZTRACE_MPI_SSEND_INIT (EZTRACE_MPI_PREFIX | 0x5004) #define EZTRACE_MPI_RECV_INIT (EZTRACE_MPI_PREFIX | 0x5010) #define EZTRACE_MPI_START (EZTRACE_MPI_PREFIX | 0x5100) #define EZTRACE_MPI_CANCEL (EZTRACE_MPI_PREFIX | 0x6001) #define EZTRACE_MPI_Info (EZTRACE_MPI_PREFIX | 0x9999) #endif /* __MPI_EV_CODES_H__ */ eztrace-1.1-2/src/modules/mpi/mpi_eztrace.h000066400000000000000000000357541265506773700207060ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef MPI_EZTRACE_H #define MPI_EZTRACE_H #include #include #include "mpi.h" #if MPI_VERSION >= 3 /* Use MPI 3 */ /* In MPI3, the prototype of some MPI functions have change. * For instance, in MPI2.X, the prototype of MPI_Send was: * int MPI_Send(void* buffer, [...]); * In MPI3, MPI_Send is defined as: * int MPI_Send(const void* buffer, [...]); * In order to fix this prototype issue, let's define a CONST macro */ #define CONST const #ifndef USE_MPI3 #define USE_MPI3 #endif #else /* This is MPI 2.X */ #define CONST #ifdef USE_MPI3 #undef USE_MPI3 #endif #endif /* maximum number of items to be allocated statically * if the application need more than this, a dynamic array * is allocated using malloc() */ #define MAX_REQS 128 /* allocate a number of elements using a static array if possible * if not possible (ie. count>MAX_REQS) use a dynamic array (ie. malloc) */ #define ALLOCATE_ITEMS(type, count, static_var, dyn_var) \ type static_var[MAX_REQS]; \ type *dyn_var = static_var; \ if((count) > MAX_REQS) \ dyn_var = (type*) malloc(sizeof(type)*(count)) /* Free an array created by ALLOCATE_ITEMS */ #define FREE_ITEMS(count, dyn_var) \ if((count) > MAX_REQS) \ free(dyn_var) /* convert a C request (ie. a pointer to a MPI_Request structure) * to an integer */ //#define EZTRACE_REQ(r) MPI_Request_c2f(*(r)) /* pointers to actual MPI functions (C version) */ extern int (*libMPI_Init)(int *, char ***); extern int (*libMPI_Init_thread)(int *, char ***, int, int*); extern int (*libMPI_Comm_size)(MPI_Comm, int *); extern int (*libMPI_Comm_rank)(MPI_Comm, int *); extern int (*libMPI_Finalize)(void); extern int (*libMPI_Initialized)(int *); extern int (*libMPI_Abort)(MPI_Comm, int); extern int (*libMPI_Cancel)( MPI_Request*); extern int (*libMPI_Send)(CONST void *buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm); extern int (*libMPI_Recv)(void *buf, int count, MPI_Datatype datatype, int source, int tag, MPI_Comm comm, MPI_Status *status); extern int (*libMPI_Bsend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm); extern int (*libMPI_Ssend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm); extern int (*libMPI_Rsend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm); extern int (*libMPI_Isend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); extern int (*libMPI_Ibsend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); extern int (*libMPI_Issend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); extern int (*libMPI_Irsend)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); extern int (*libMPI_Irecv)(void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); extern int (*libMPI_Sendrecv)(CONST void *, int, MPI_Datatype, int, int, void *, int, MPI_Datatype, int, int, MPI_Comm, MPI_Status *); extern int (*libMPI_Sendrecv_replace)(void*, int, MPI_Datatype, int, int, int, int, MPI_Comm, MPI_Status *); extern int (*libMPI_Send_init)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); extern int (*libMPI_Bsend_init)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); extern int (*libMPI_Ssend_init)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); extern int (*libMPI_Rsend_init)(CONST void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); extern int (*libMPI_Recv_init)(void*, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); extern int (*libMPI_Start)(MPI_Request *); extern int (*libMPI_Startall)(int, MPI_Request *); extern int (*libMPI_Wait)(MPI_Request *, MPI_Status *); extern int (*libMPI_Test)(MPI_Request *, int *, MPI_Status *); extern int (*libMPI_Waitany)(int, MPI_Request *, int *, MPI_Status *); extern int (*libMPI_Testany)(int, MPI_Request *, int *, int *, MPI_Status *); extern int (*libMPI_Waitall)(int, MPI_Request *, MPI_Status *); extern int (*libMPI_Testall)(int, MPI_Request *, int *, MPI_Status *); extern int (*libMPI_Waitsome)(int, MPI_Request *, int *, int *, MPI_Status *); extern int (*libMPI_Testsome)(int, MPI_Request *, int *, int *, MPI_Status *); extern int (*libMPI_Probe)(int source, int tag, MPI_Comm comm, MPI_Status *status); extern int (*libMPI_Iprobe)(int source, int tag, MPI_Comm comm, int *flag, MPI_Status *status); extern int (*libMPI_Barrier)(MPI_Comm); extern int (*libMPI_Bcast)(void*, int, MPI_Datatype, int, MPI_Comm); extern int (*libMPI_Gather)(CONST void*, int, MPI_Datatype, void*, int, MPI_Datatype, int, MPI_Comm); extern int (*libMPI_Gatherv)(CONST void*, int, MPI_Datatype, void*, CONST int *, CONST int *, MPI_Datatype, int, MPI_Comm); extern int (*libMPI_Scatter)(CONST void*, int, MPI_Datatype, void*, int, MPI_Datatype, int, MPI_Comm); extern int (*libMPI_Scatterv)(CONST void*, CONST int *, CONST int *, MPI_Datatype, void*, int, MPI_Datatype, int, MPI_Comm); extern int (*libMPI_Allgather)(CONST void*, int, MPI_Datatype, void*, int, MPI_Datatype, MPI_Comm); extern int (*libMPI_Allgatherv)(CONST void*, int, MPI_Datatype, void*, CONST int *, CONST int *, MPI_Datatype, MPI_Comm); extern int (*libMPI_Alltoall)(CONST void*, int, MPI_Datatype, void*, int, MPI_Datatype, MPI_Comm); extern int (*libMPI_Alltoallv)(CONST void*, CONST int *, CONST int *, MPI_Datatype, void*, CONST int *, CONST int *, MPI_Datatype, MPI_Comm); extern int (*libMPI_Reduce)(CONST void*, void*, int, MPI_Datatype, MPI_Op, int, MPI_Comm); extern int (*libMPI_Allreduce)(CONST void*, void*, int, MPI_Datatype, MPI_Op, MPI_Comm); extern int (*libMPI_Reduce_scatter)(CONST void*, void*, CONST int *, MPI_Datatype, MPI_Op, MPI_Comm); extern int (*libMPI_Scan)(CONST void*, void*, int, MPI_Datatype, MPI_Op, MPI_Comm); #ifdef USE_MPI3 extern int ( *libMPI_Ibarrier)(MPI_Comm, MPI_Request*); extern int ( *libMPI_Ibcast)(void*, int, MPI_Datatype, int, MPI_Comm, MPI_Request*); extern int ( *libMPI_Igather) (const void*, int, MPI_Datatype, void*, int, MPI_Datatype, int, MPI_Comm, MPI_Request*); extern int ( *libMPI_Igatherv) (const void*, int, MPI_Datatype, void*, const int *, const int *, MPI_Datatype, int, MPI_Comm, MPI_Request*); extern int ( *libMPI_Iscatter) (const void*, int, MPI_Datatype, void*, int, MPI_Datatype, int, MPI_Comm, MPI_Request*); extern int ( *libMPI_Iscatterv) (const void*, const int *, const int *, MPI_Datatype, void*, int, MPI_Datatype, int, MPI_Comm, MPI_Request*); extern int ( *libMPI_Iallgather) (const void*, int, MPI_Datatype, void*, int, MPI_Datatype, MPI_Comm, MPI_Request*); extern int ( *libMPI_Iallgatherv) (const void*, int, MPI_Datatype, void*, const int *, const int *, MPI_Datatype, MPI_Comm, MPI_Request*); extern int ( *libMPI_Ialltoall) (const void*, int, MPI_Datatype, void*, int, MPI_Datatype, MPI_Comm, MPI_Request*); extern int ( *libMPI_Ialltoallv) (const void*, const int *, const int *, MPI_Datatype, void*, const int *, const int *, MPI_Datatype, MPI_Comm, MPI_Request*); extern int ( *libMPI_Ireduce) (const void* , void*, int, MPI_Datatype, MPI_Op, int, MPI_Comm, MPI_Request*); extern int ( *libMPI_Iallreduce) (const void*, void*, int, MPI_Datatype, MPI_Op, MPI_Comm, MPI_Request*); extern int ( *libMPI_Ireduce_scatter) (const void*, void*, const int *, MPI_Datatype, MPI_Op, MPI_Comm, MPI_Request*); extern int ( *libMPI_Iscan) (const void*, void*, int, MPI_Datatype, MPI_Op, MPI_Comm, MPI_Request*); #endif extern int (*libMPI_Get)(void *, int, MPI_Datatype, int, MPI_Aint, int, MPI_Datatype, MPI_Win); extern int (*libMPI_Put)(CONST void *, int, MPI_Datatype, int, MPI_Aint, int, MPI_Datatype, MPI_Win); extern int (*libMPI_Comm_spawn)(CONST char *command, char *argv[], int maxprocs, MPI_Info info, int root, MPI_Comm comm, MPI_Comm *intercomm, int array_of_errcodes[]); /* fortran bindings */ extern void (*libmpi_init_)(int*e); extern void (*libmpi_init_thread_)(int*, int*, int*); extern void (*libmpi_finalize_)(int*); extern void (*libmpi_barrier_)(MPI_Comm*, int*); extern void (*libmpi_comm_size_)(MPI_Comm*, int*, int*); extern void (*libmpi_comm_rank_)(MPI_Comm*, int*, int*); extern void (*libmpi_cancel_)(MPI_Request*, int*); extern void (*libmpi_send_)(void*, int*, MPI_Datatype*, int*, int*, int*); extern void (*libmpi_recv_)(void*, int*, MPI_Datatype*, int*, int *, MPI_Status *, int*); extern void (*libmpi_sendrecv_)(void *, int, MPI_Datatype, int, int, void *, int, MPI_Datatype, int, int, MPI_Comm, MPI_Status *, int*); extern void (*libmpi_sendrecv_replace_)(void*, int, MPI_Datatype, int, int, int, int, MPI_Comm, MPI_Status *, int*); extern void (*libmpi_bsend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, int*); extern void (*libmpi_ssend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, int*); extern void (*libmpi_rsend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, int*); extern void (*libmpi_isend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request*, int*); extern void (*libmpi_ibsend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request*, int*); extern void (*libmpi_issend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); extern void (*libmpi_irsend_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); extern void (*libmpi_irecv_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); extern void (*libmpi_wait_)(MPI_Request*, MPI_Status*, int*); extern void (*libmpi_test_)(MPI_Request*, int*, MPI_Status*, int*); extern void (*libmpi_waitany_)(int*, MPI_Request *, int *, MPI_Status *, int*); extern void (*libmpi_testany_)(int*, MPI_Request *, int *, int *, MPI_Status *, int*); extern void (*libmpi_waitall_)(int*, MPI_Request *, MPI_Status *, int*); extern void (*libmpi_testall_)(int*, MPI_Request *, int *, MPI_Status *, int*); extern void (*libmpi_waitsome_)(int*, MPI_Request *, int *, int *, MPI_Status *, int*); extern void (*libmpi_testsome_)(int*, MPI_Request *, int *, int *, MPI_Status *, int*); extern void (*libmpi_probe_)(int* source, int* tag, MPI_Comm* comm, MPI_Status *status, int* err); extern void (*libmpi_iprobe_)(int* source, int* tag, MPI_Comm* comm, int *flag, MPI_Status *status, int* err); extern void (*libmpi_get_)(void *, int*, MPI_Datatype*, int*, MPI_Aint*, int*, MPI_Datatype*, MPI_Win*, int*); extern void (*libmpi_put_)(void *, int*, MPI_Datatype*, int*, MPI_Aint*, int*, MPI_Datatype*, MPI_Win*, int*); extern void (*libmpi_bcast_)(void*, int*, MPI_Datatype*, int*, MPI_Comm*, int*); extern void (*libmpi_gather_)(void*, int*, MPI_Datatype*, void*, int*, MPI_Datatype*, int*, MPI_Comm*, int*); extern void (*libmpi_gatherv_)(void*, int*, MPI_Datatype*, void*, int*, int*, MPI_Datatype*, int*, MPI_Comm*); extern void (*libmpi_scatter_)(void*, int*, MPI_Datatype*, void*, int*, MPI_Datatype*, int*, MPI_Comm*, int*); extern void (*libmpi_scatterv_)(void*, int*, int*, MPI_Datatype*, void*, int*, MPI_Datatype*, int*, MPI_Comm*, int*); extern void (*libmpi_allgather_)(void*, int*, MPI_Datatype*, void*, int*, MPI_Datatype*, MPI_Comm*, int*); extern void (*libmpi_allgatherv_)(void*, int*, MPI_Datatype*, void*, int*, int*, MPI_Datatype*, MPI_Comm*); extern void (*libmpi_alltoall_)(void*, int*, MPI_Datatype*, void*, int*, MPI_Datatype*, MPI_Comm*, int*); extern void (*libmpi_alltoallv_)(void*, int*, int*, MPI_Datatype*, void*, int*, int*, MPI_Datatype*, MPI_Comm*, int*); extern void (*libmpi_reduce_)(void*, void*, int*, MPI_Datatype*, MPI_Op*, int*, MPI_Comm*, int*); extern void (*libmpi_allreduce_)(void*, void*, int*, MPI_Datatype*, MPI_Op*, MPI_Comm*, int*); extern void (*libmpi_reduce_scatter_)(void*, void*, int*, MPI_Datatype*, MPI_Op*, MPI_Comm*, int*); extern void (*libmpi_scan_)(void*, void*, int*, MPI_Datatype*, MPI_Op*, MPI_Comm*, int*); extern void (*libmpi_comm_spawn_)(char *command, char **argv, int *maxprocs, MPI_Info *info, int *root, MPI_Comm *comm, MPI_Comm *intercomm, int *array_of_errcodes, int*error); extern void (*libmpi_send_init_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); extern void (*libmpi_bsend_init_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); extern void (*libmpi_ssend_init_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); extern void (*libmpi_rsend_init_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); extern void (*libmpi_recv_init_)(void*, int*, MPI_Datatype*, int*, int*, MPI_Comm*, MPI_Request *, int*); extern void (*libmpi_start_)(MPI_Request *, int*); extern void (*libmpi_startall_)(int*, MPI_Request *, int*); /* return 1 if buf corresponds to the Fotran MPI_IN_PLACE * return 0 otherwise */ int ezt_mpi_is_in_place_(void* buf ); /* check the value of a Fortran pointer and return MPI_IN_PLACE or p */ #define CHECK_MPI_IN_PLACE(p) (ezt_mpi_is_in_place_(p)?MPI_IN_PLACE:(p)) #endif /* MPI_EZTRACE_H */ eztrace-1.1-2/src/modules/mpi/mpi_f.f90000066400000000000000000000175141265506773700176370ustar00rootroot00000000000000! Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis ! See COPYING in top-level directory. subroutine MPI_COMM_SPAWN(CMD, ARGV, M, I, R, C, INTERCOMM, A, E) call MPIF_COMM_SPAWN(CMD, ARGV, M, I, R, C, INTERCOMM, A, E) return end subroutine MPI_INIT(error) call MPIF_INIT(error) return end subroutine MPI_Init_thread(REQUIRED, PROVIDED, IERROR) call MPIF_Init_thread(REQUIRED, PROVIDED, IERROR) return end subroutine MPI_Finalize(IERROR) call MPIF_Finalize(IERROR) return end subroutine MPI_Barrier(COMM, IERROR) call MPIF_Barrier(COMM, IERROR) return end subroutine MPI_Comm_size(COMM, SIZE, IERROR) call MPIF_Comm_size(COMM, SIZE, IERROR) return end subroutine MPI_Comm_rank(COMM, RANK, IERROR) call MPIF_Comm_rank(COMM, RANK, IERROR) return end subroutine MPI_Comm_create(COMM, GROUP, NEWCOMM, IERROR) call MPIF_Comm_create(COMM, GROUP, NEWCOMM, IERROR) return end subroutine MPI_Comm_create_group(COMM, GROUP, TAG, NEWCOMM, IERROR) call MPIF_Comm_create_group(COMM, GROUP, TAG, NEWCOMM, IERROR) return end subroutine MPI_Comm_split(COMM, COLOR, KEY, NEWCOMM, IERROR) call MPIF_Comm_split(COMM, COLOR, KEY, NEWCOMM, IERROR) return end subroutine MPI_Comm_dup(COMM, NEWCOMM, IERROR) call MPIF_Comm_dup(COMM, NEWCOMM, IERROR) return end subroutine MPI_Comm_dup_with_info(COMM, info, NEWCOMM, IERROR) call MPIF_Comm_dup_with_info(COMM, info, NEWCOMM, IERROR) return end subroutine MPI_COMM_SPLIT_TYPE(COMM, SPLIT_TYPE, KEY, INFO, NEWCOMM, IERROR) call MPIF_COMM_SPLIT_TYPE(COMM, SPLIT_TYPE, KEY, INFO, NEWCOMM, IERROR) return end subroutine MPI_Intercomm_create(LOCAL_COMM, LOCAL_LEADER, PEER_COMM, REMOTE_LEADER, TAG, NEWINTERCOMM, IERROR) call MPIF_Intercomm_create(LOCAL_COMM, LOCAL_LEADER, PEER_COMM, REMOTE_LEADER, TAG, NEWINTERCOMM, IERROR) return end subroutine MPI_INTERCOMM_MERGE(INTERCOMM, HIGH, NEWINTRACOMM, IERROR) call MPIF_INTERCOMM_MERGE(INTERCOMM, HIGH, NEWINTRACOMM, IERROR) return end subroutine MPI_CART_SUB(COMM, REMAIN_DIMS, COMM_NEW, IERROR) call MPIF_CART_SUB(COMM, REMAIN_DIMS, COMM_NEW, IERROR) return end subroutine MPI_CART_CREATE(COMM_OLD, NDIMS, DIMS, PERIODS, REORDER, COMM_CART, IERROR) call MPIF_CART_CREATE(COMM_OLD, NDIMS, DIMS, PERIODS, REORDER, COMM_CART, IERROR) return end subroutine MPI_GRAPH_CREATE(COMM_OLD, NNODES, INDEX, EDGES, REORDER, COMM_GRAPH, IERROR) call MPIF_GRAPH_CREATE(COMM_OLD, NNODES, INDEX, EDGES, REORDER, COMM_GRAPH, IERROR) return end subroutine MPI_DIST_GRAPH_CREATE(COMM_OLD, N, SOURCES, DEGREES, DESTINATIONS, WEIGHTS,& INFO, REORDER, COMM_DIST_GRAPH, IERROR) call MPIF_DIST_GRAPH_CREATE(COMM_OLD, N, SOURCES, DEGREES, DESTINATIONS, WEIGHTS,& INFO, REORDER, COMM_DIST_GRAPH, IERROR) return end subroutine MPI_DIST_GRAPH_CREATE_ADJACENT(COMM_OLD, INDEGREE, SOURCES, SOURCEWEIGHTS, & OUTDEGREE, DESTINATIONS, DESTWEIGHTS, INFO, REORDER, COMM_DIST_GRAPH, IERROR) call MPIF_DIST_GRAPH_CREATE_ADJACENT(COMM_OLD, INDEGREE, SOURCES, SOURCEWEIGHTS, & OUTDEGREE, DESTINATIONS, DESTWEIGHTS, INFO, REORDER, COMM_DIST_GRAPH, IERROR) return end subroutine MPI_Send(BUF, COUNT, DATATYPE, DEST, TAG, COMM, IERROR) call MPIF_Send(BUF, COUNT, DATATYPE, DEST, TAG, COMM, IERROR) return end subroutine MPI_Recv(BUF, COUNT, D, SRC, TAG, COMM, STATUS, IERROR) call MPIF_Recv(BUF, COUNT, D, SRC, TAG, COMM, STATUS, IERROR) return end subroutine MPI_Sendecv(SBUF, SCOUNT, STYPE, DST, STAG, RBUF, RCOUNT, RTYPE, SRC, RTAG, COMM, STATUS, ERROR) call MPIF_Sendrecv(SBUF, SCOUNT, STYPE, DST, STAG, RBUF, RCOUNT, RTYPE, SRC, RTAG, COMM, STATUS, ERROR) return end subroutine MPI_Sendecv_replace(BUF, COUNT, TYPE, DST, STAG, SRC, RTAG, COMM, STATUS, ERROR) call MPIF_Sendrecv_replace(BUF, COUNT, TYPE, DST, STAG, SRC, RTAG, COMM, STATUS, ERROR) return end subroutine MPI_Bsend(BUF, COUNT,DATATYPE, DEST, TAG, COMM, IERROR) call MPIF_Bsend(BUF, COUNT,DATATYPE, DEST, TAG, COMM, IERROR) return end subroutine MPI_Ssend(BUF, COUNT, D, DEST, TAG, COMM, IERROR) call MPIF_Ssend(BUF, COUNT, D, DEST, TAG, COMM, IERROR) return end subroutine MPI_Rsend(BUF, COUNT, D, DEST, TAG, COMM, IERROR) call MPIF_Rsend(BUF, COUNT, D, DEST, TAG, COMM, IERROR) return end subroutine MPI_Isend(BUF, COUNT, D, DST, TAG, COMM, REQ, IERROR) call MPIF_Isend(BUF, COUNT, D, DST, TAG, COMM, REQ, IERROR) return end subroutine MPI_Ibsend(BUF, COUNT, D, DST, TAG, COMM, REQ, IERROR) call MPIF_Ibsend(BUF, COUNT, D, DST, TAG, COMM, REQ, IERROR) return end subroutine MPI_Issend(BUF, COUNT, D, DST, TAG, COMM, REQ, IERROR) call MPIF_Issend(BUF, COUNT, D, DST, TAG, COMM, REQ, IERROR) return end subroutine MPI_Irsend(BUF, COUNT, D, DST, TAG, COMM, REQ, IERROR) call MPIF_Irsend(BUF, COUNT, D, DST, TAG, COMM, REQ, IERROR) return end subroutine MPI_Irecv(B, CNT, D, SRC, TAG, COMM, REQ, IERROR) call MPIF_Irecv(B, CNT, D, SRC, TAG, COMM, REQ, IERROR) return end subroutine MPI_Wait(REQUEST, STATUS, IERROR) call MPIF_Wait(REQUEST, STATUS, IERROR) return end subroutine MPI_WAITALL(COUNT, R, S, IERROR) call MPIF_Waitall(COUNT, R, S, IERROR) return end subroutine MPI_WAITANY(COUNT, R, S, INDEX, IERROR) call MPIF_Waitany(COUNT, R, S, INDEX, IERROR) return end subroutine MPI_WAITSOME(IC, R, OC, INDEX, S, IERROR) call MPIF_Waitsome(IC, R, OC, INDEX, S, IERROR) return end subroutine MPI_TESTSOME(IC, R, OC, INDEX, S, IERROR) call MPIF_Testsome(IC, R, OC, INDEX, S, IERROR) return end subroutine MPI_PROBE(S, T, C, STAT, IERROR) call MPIF_PROBE(S, T, C, STAT, IERROR) return end subroutine MPI_IPROBE(S, T, C, FLAG, STAT, IERROR) call MPIF_IPROBE(S, T, C, FLAG, STAT, IERROR) return end subroutine MPI_Test(REQUEST, FLAG, STATUS, IERROR) call MPIF_Test(REQUEST, FLAG, STATUS, IERROR) return end subroutine MPI_Testall(C, REQUEST, INDEX, STATUS, IERROR) call MPIF_Testall(C, REQUEST, INDEX, STATUS, IERROR) return end subroutine MPI_Testany(C, REQUEST, INDEX, F, STATUS, IERROR) call MPIF_Testany(C, REQUEST, INDEX, F, STATUS, IERROR) return end subroutine MPI_Get(O_A, O_C, O_D, T_R, T_DS, T_C, T_D, W, ERROR) call MPIF_Get(O_A, O_C, O_D, T_R, T_DS, T_C, T_D, W, ERROR) return end subroutine MPI_Put(O_A, O_C, O_D, T_R, T_DS, T_C, T_D, W, ERROR) call MPIF_Put(O_A, O_C, O_D, T_R, T_DS, T_C, T_D, W, ERROR) return end subroutine MPI_BCast(BUFFER, COUNT, DATATYPE, ROOT, COMM, IERROR) call MPIF_BCast(BUFFER, COUNT, DATATYPE, ROOT, COMM, IERROR) return end subroutine MPI_Gather(SBUF,SCNT,STYPE,RBUF,RCNT, RTYPE, R, C, E) call MPIF_Gather(SBUF, SCNT, STYPE, RBUF, RCNT, RTYPE, R, C, E) return end subroutine MPI_Gatherv(SBUF,SCNT,STYPE,RBUF,RCNT,DSP,RTYPE,R,C,E) call MPIF_Gatherv(SBUF,SCNT,STYPE,RBUF,RCNT,DSP,RTYPE,R,C,E) return end subroutine MPI_Scatter(SBUF,SCNT,STYPE,RBUF,RCNT,RTYPE,R,C,E) call MPIF_Scatter(SBUF, SCNT, STYPE, RBUF, RCNT, RTYPE, R, C, E) return end subroutine MPI_Scatterv(SBUF,SCNT,DSP,SDTYP,RBUF,RCNT,RTYP,R,C,E) call MPIF_Scatterv(SBUF,SCNT,DSP,SDTYP,RBUF, RCNT, RTYP, R, C, E) return end subroutine MPI_Allgather(SBUF, SCNT, STYP, RBUF, RCNT, RTYP, C, E) call MPIF_Allgather(SBUF, SCNT, STYP, RBUF, RCNT, RTYP, C, E) return end subroutine MPI_Allgatherv(SB, SC, ST, RB, RC, D, RT, C, IERROR) call MPIF_Allgatherv(SB, SC, ST, RB, RC, D, RT, C, IERROR) return end subroutine MPI_Alltoall(SB, SC, ST, RB, RC, RT, COMM, IERROR) call MPIF_Alltoall(SB, SC, ST, RB, RC, RT, COMM, IERROR) return end subroutine MPI_Alltoallv(SB, SC, SD, ST, RB, RC, RD, RT, C, ERROR) call MPIF_Alltoallv(SB, SC, SD, ST, RB, RC, RD, RT, C, ERROR) return end subroutine MPI_Reduce(SBUF, RBUF, CNT, D, OP, ROOT, COMM, IERROR) call MPIF_Reduce(SBUF, RBUF, CNT, D, OP, ROOT, COMM, IERROR) return end subroutine MPI_Allreduce(SBUF, RBUF, CNT, D, OP, COMM, IERROR) call MPIF_Allreduce(SBUF, RBUF, CNT, D, OP, COMM, IERROR) return end subroutine MPI_Reduce_scatter(SBUF, RBUF, RCNT, D, OP, C, IERROR) call MPIF_Reduce_scatter(SBUF, RBUF, RCNT, D, OP, C, IERROR) return end subroutine MPI_Scan(SBUF, RBUF, CNT, D, OP, COMM, IERROR) call MPIF_Scan(SBUF, RBUF, CNT, D, OP, COMM, IERROR) return end eztrace-1.1-2/src/modules/mpi/mpi_fortran.c000066400000000000000000000145441265506773700207110ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #include "mpi_eztrace.h" /* For MPI_Init and MPI_Init_thread, we *have* to call the Fortran version * of the function. Once it is done, we can call the __mpi_init_generic function */ void __mpi_init_generic(); void mpif_init_(void *error) { libmpi_init_((int*) error); __mpi_init_generic(); } void mpif_init_thread_(int *r, int *p, int *error) { libmpi_init_thread_(r, p, error); __mpi_init_generic(); } /* For all the remaining Fortran functions, we can just call the C version */ void mpif_finalize_(int *error) { *error = MPI_Finalize(); } void mpif_comm_size_(MPI_Fint *c, int *s, int * error) { MPI_Comm c_comm = MPI_Comm_f2c(*c); *error = MPI_Comm_size(c_comm, s); } void mpif_comm_rank_(MPI_Fint *c, int *r, int *error) { MPI_Comm c_comm = MPI_Comm_f2c(*c); *error = MPI_Comm_rank(c_comm, r); } void mpif_comm_spawn_(char *command, char **argv, int *maxprocs, MPI_Fint *info, int *root, MPI_Fint *comm, MPI_Fint *intercomm, int *array_of_errcodes, int*error) { MPI_Comm c_comm = MPI_Comm_f2c(*comm); MPI_Info c_info = MPI_Info_f2c(*info); ALLOCATE_ITEMS(MPI_Comm, *maxprocs, c_intercomm, p_intercomm); int i; for (i = 0; i < *maxprocs; i++) p_intercomm[i] = MPI_Comm_f2c(intercomm[i]); *error = MPI_Comm_spawn(command, argv, *maxprocs, c_info, *root, c_comm, p_intercomm, array_of_errcodes); for (i = 0; i < *maxprocs; i++) intercomm[i] = MPI_Comm_c2f(p_intercomm[i]); FREE_ITEMS(*maxprocs, p_intercomm); } void mpif_comm_create_(MPI_Fint *comm, MPI_Fint *group, MPI_Fint *newcomm, int *error) { MPI_Comm comm_c = MPI_Comm_f2c(*comm); MPI_Comm newcomm_c; MPI_Group group_c = MPI_Group_f2c(*group); *error = MPI_Comm_create(comm_c, group_c, &newcomm_c); *newcomm = MPI_Comm_c2f(newcomm_c); } void mpif_comm_create_group_(MPI_Fint *comm, MPI_Fint *group, MPI_Fint *tag, MPI_Fint *newcomm, int *error) { MPI_Comm comm_c = MPI_Comm_f2c(*comm); MPI_Comm newcomm_c; MPI_Group group_c = MPI_Group_f2c(*group); *error = MPI_Comm_create_group(comm_c, group_c, *tag, &newcomm_c); *newcomm = MPI_Comm_c2f(newcomm_c); } void mpif_comm_split_(MPI_Fint *comm, int *color, int *key, MPI_Fint *newcomm, int *error) { MPI_Comm comm_c = MPI_Comm_f2c(*comm); MPI_Comm newcomm_c; *error = MPI_Comm_split(comm_c, *color, *key, &newcomm_c); *newcomm = MPI_Comm_c2f(newcomm_c); } void mpif_comm_dup_(MPI_Fint *comm, MPI_Fint *newcomm, int *error) { MPI_Comm comm_c = MPI_Comm_f2c(*comm); MPI_Comm newcomm_c; *error = MPI_Comm_dup(comm_c, &newcomm_c); *newcomm = MPI_Comm_c2f(newcomm_c); } void mpif_comm_dup_with_info_(MPI_Fint *comm, MPI_Fint *info, MPI_Fint *newcomm, int *error) { MPI_Comm comm_c = MPI_Comm_f2c(*comm); MPI_Comm newcomm_c; *error = MPI_Comm_dup_with_info(comm_c, *info, &newcomm_c); *newcomm = MPI_Comm_c2f(newcomm_c); } void mpif_comm_split_type_(MPI_Fint* comm, int* split_type, int* key, int* info, MPI_Fint *newcomm, int*error) { MPI_Comm comm_c = MPI_Comm_f2c(*comm); MPI_Comm newcomm_c; *error = MPI_Comm_split_type(comm_c, *split_type, *key, *info, &newcomm_c); *newcomm = MPI_Comm_c2f(newcomm_c); } void mpif_intercomm_create_(MPI_Fint *local_comm, int *local_leader, MPI_Fint *peer_comm, int *remote_leader, int *tag, MPI_Fint *newintercomm, int *error) { MPI_Comm local_comm_c = MPI_Comm_f2c(*local_comm); MPI_Comm peer_comm_c = MPI_Comm_f2c(*peer_comm); MPI_Comm newintercomm_c; *error = MPI_Intercomm_create(local_comm_c, *local_leader, peer_comm_c, *remote_leader, *tag, &newintercomm_c); *newintercomm = MPI_Comm_c2f(newintercomm_c); } void mpif_intercomm_merge_(MPI_Fint *intercomm, int *high, MPI_Fint *newintracomm, int *error) { MPI_Comm intercomm_c = MPI_Comm_f2c(*intercomm); MPI_Comm newintracomm_c; *error = MPI_Intercomm_merge(intercomm_c, *high, &newintracomm_c); *newintracomm = MPI_Comm_c2f(newintracomm_c); } void mpif_cart_sub_(MPI_Fint *old_comm, int *belongs, MPI_Fint *new_comm, int *error) { MPI_Comm old_comm_c = MPI_Comm_f2c(*old_comm); MPI_Comm new_comm_c; *error = MPI_Cart_sub(old_comm_c, belongs, &new_comm_c); *new_comm = MPI_Comm_c2f(new_comm_c); } void mpif_cart_create_(MPI_Fint *comm_old, int *ndims, int *dims, int *periods, int *reorder, MPI_Fint *comm_cart, int *error) { MPI_Comm comm_old_c = MPI_Comm_f2c(*comm_old); MPI_Comm comm_cart_c; *error = MPI_Cart_create(comm_old_c, *ndims, dims, periods, *reorder, &comm_cart_c); *comm_cart = MPI_Comm_c2f(comm_cart_c); } void mpif_graph_create_(MPI_Fint *comm_old, int *nnodes, int *index, int *edges, int *reorder, MPI_Fint *comm_graph, int *error) { MPI_Comm comm_old_c = MPI_Comm_f2c(*comm_old); MPI_Comm comm_graph_c; *error = MPI_Graph_create(comm_old_c, *nnodes, index, edges, *reorder, &comm_graph_c); *comm_graph = MPI_Comm_c2f(comm_graph_c); } void mpif_dist_graph_create_(MPI_Fint* comm_old, int*n, int *sources, int* degrees, int* destinations, int* weights, int* info, int* reorder, MPI_Fint* comm_dist_graph, int* error) { MPI_Comm comm_old_c = MPI_Comm_f2c(*comm_old); MPI_Comm comm_dist_graph_c; *error = MPI_Dist_graph_create(comm_old_c, *n, sources, degrees, destinations, weights, *info, *reorder, &comm_dist_graph_c); *comm_dist_graph = MPI_Comm_c2f(comm_dist_graph_c); } void mpif_dist_graph_create_adjacent_(MPI_Fint* comm_old, int* indegree, int* sources, int* sourceweights, int* outdegree, int* destinations, int* destweights,int* info, int *reorder, MPI_Fint* comm_dist_graph, int* error) { MPI_Comm comm_old_c = MPI_Comm_f2c(*comm_old); MPI_Comm comm_dist_graph_c; *error = MPI_Dist_graph_create_adjacent(comm_old_c, *indegree, sources, sourceweights, *outdegree, destinations, destweights, *info, *reorder, &comm_dist_graph_c); *comm_dist_graph = MPI_Comm_c2f(comm_dist_graph_c); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/000077500000000000000000000000001265506773700202005ustar00rootroot00000000000000eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_allgather.c000066400000000000000000000061001265506773700231510ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Allgather_prolog(CONST void __attribute__((unused)) *sendbuf, int sendcount, MPI_Datatype sendtype, void __attribute__((unused)) *recvbuf, int __attribute__((unused)) recvcount, MPI_Datatype recvtype, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_Allgather, (app_ptr)comm, size, rank); } static int MPI_Allgather_core(CONST void *sendbuf, int sendcount, MPI_Datatype sendtype, void *recvbuf, int recvcount, MPI_Datatype recvtype, MPI_Comm comm) { return libMPI_Allgather(sendbuf, sendcount, sendtype, recvbuf, recvcount, recvtype, comm); } static void MPI_Allgather_epilog(CONST void __attribute__((unused)) *sendbuf, int sendcount, MPI_Datatype sendtype, void __attribute__((unused)) *recvbuf, int __attribute__((unused)) recvcount, MPI_Datatype recvtype, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_Allgather, (app_ptr)comm, size, rank); } int MPI_Allgather(CONST void *sendbuf, int sendcount, MPI_Datatype sendtype, void *recvbuf, int recvcount, MPI_Datatype recvtype, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Allgather_prolog(sendbuf, sendcount, sendtype, recvbuf, recvcount, recvtype, comm); int ret = MPI_Allgather_core(sendbuf, sendcount, sendtype, recvbuf, recvcount, recvtype, comm); MPI_Allgather_epilog(sendbuf, sendcount, sendtype, recvbuf, recvcount, recvtype, comm); return ret; } void mpif_allgather_(void *sbuf, int *scount, MPI_Fint *sd, void *rbuf, int *rcount, MPI_Fint *rd, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); void *c_sbuf = CHECK_MPI_IN_PLACE(sbuf); void *c_rbuf = CHECK_MPI_IN_PLACE(rbuf); MPI_Allgather_prolog(c_sbuf, *scount, c_stype, c_rbuf, *rcount, c_rtype, c_comm); *error = MPI_Allgather_core(c_sbuf, *scount, c_stype, c_rbuf, *rcount, c_rtype, c_comm); MPI_Allgather_epilog(c_sbuf, *scount, c_stype, c_rbuf, *rcount, c_rtype, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_allgatherv.c000066400000000000000000000064161265506773700233510ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Allgatherv_prolog (CONST void *sendbuf __attribute__((unused)), int sendcount, MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), CONST int *recvcounts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype recvtype, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_Allgatherv, (app_ptr)comm, size, rank); } static int MPI_Allgatherv_core (CONST void *sendbuf __attribute__((unused)), int sendcount, MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), CONST int *recvcounts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype recvtype, MPI_Comm comm) { return libMPI_Allgatherv(sendbuf, sendcount, sendtype, recvbuf, recvcounts, displs, recvtype, comm); } static void MPI_Allgatherv_epilog (CONST void __attribute__((unused)) *sendbuf, int sendcount, MPI_Datatype sendtype, void __attribute__((unused)) *recvbuf, CONST int __attribute__((unused)) *recvcounts, CONST int __attribute__((unused)) *displs, MPI_Datatype recvtype, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_Allgatherv, (app_ptr)comm, size, rank); } int MPI_Allgatherv (CONST void *sendbuf, int sendcount, MPI_Datatype sendtype, void *recvbuf, CONST int *recvcounts, CONST int *displs, MPI_Datatype recvtype, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Allgatherv_prolog(sendbuf, sendcount, sendtype, recvbuf, recvcounts, displs, recvtype, comm); int ret = MPI_Allgatherv_core(sendbuf, sendcount, sendtype, recvbuf, recvcounts, displs, recvtype, comm); MPI_Allgatherv_epilog(sendbuf, sendcount, sendtype, recvbuf, recvcounts, displs, recvtype, comm); return ret; } void mpif_allgatherv_(void *sbuf, int *scount, MPI_Fint *sd, void *rbuf, int *rcount, int *displs, MPI_Fint *rd, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); void *c_sbuf = CHECK_MPI_IN_PLACE(sbuf); void *c_rbuf = CHECK_MPI_IN_PLACE(rbuf); MPI_Allgatherv_prolog(c_sbuf, *scount, c_stype, c_rbuf, rcount, displs, c_rtype, c_comm); *error = MPI_Allgatherv_core(c_sbuf, *scount, c_stype, c_rbuf, rcount, displs, c_rtype, c_comm); MPI_Allgatherv_epilog(c_sbuf, *scount, c_stype, c_rbuf, rcount, displs, c_rtype, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_allreduce.c000066400000000000000000000050661265506773700231600ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Allreduce_prolog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype, MPI_Op op __attribute__((unused)), MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int len; MPI_Type_size(datatype, &len); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_Allreduce, (app_ptr)comm, size, rank); } static int MPI_Allreduce_core(CONST void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm) { return libMPI_Allreduce(sendbuf, recvbuf, count, datatype, op, comm); } static void MPI_Allreduce_epilog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype, MPI_Op op __attribute__((unused)), MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int len; MPI_Type_size(datatype, &len); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_Allreduce, (app_ptr)comm, size, rank); } int MPI_Allreduce (CONST void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Allreduce_prolog(sendbuf, recvbuf, count, datatype, op, comm); int ret = MPI_Allreduce_core(sendbuf, recvbuf, count, datatype, op, comm); MPI_Allreduce_epilog(sendbuf, recvbuf, count, datatype, op, comm); return ret; } void mpif_allreduce_(void *sbuf, void *rbuf, int *count, MPI_Fint *d, MPI_Fint *op, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Op c_op = MPI_Op_f2c(*op); MPI_Comm c_comm = MPI_Comm_f2c(*c); void *c_sbuf = CHECK_MPI_IN_PLACE(sbuf); void *c_rbuf = CHECK_MPI_IN_PLACE(rbuf); MPI_Allreduce_prolog(c_sbuf, c_rbuf, *count, c_type, c_op, c_comm); *error = MPI_Allreduce_core(c_sbuf, c_rbuf, *count, c_type, c_op, c_comm); MPI_Allreduce_epilog(c_sbuf, c_rbuf, *count, c_type, c_op, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_alltoall.c000066400000000000000000000063461265506773700230260ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Alltoall_prolog (CONST void *sendbuf __attribute__((unused)), int sendcount __attribute__((unused)), MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), int recvcnt __attribute__((unused)), MPI_Datatype recvtype, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int ssize=0; int rsize =0; if(sendtype != MPI_DATATYPE_NULL) MPI_Type_size(sendtype, &ssize); if(recvtype != MPI_DATATYPE_NULL) MPI_Type_size(recvtype, &rsize); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_Alltoall, (app_ptr)comm, size, rank); } static int MPI_Alltoall_core(CONST void *sendbuf, int sendcount, MPI_Datatype sendtype, void *recvbuf, int recvcnt, MPI_Datatype recvtype, MPI_Comm comm) { return libMPI_Alltoall(sendbuf, sendcount, sendtype, recvbuf, recvcnt, recvtype, comm); } static void MPI_Alltoall_epilog (CONST void *sendbuf __attribute__((unused)), int sendcount __attribute__((unused)), MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), int recvcnt __attribute__((unused)), MPI_Datatype recvtype, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int ssize=0; int rsize =0; if(sendtype != MPI_DATATYPE_NULL) MPI_Type_size(sendtype, &ssize); if(recvtype != MPI_DATATYPE_NULL) MPI_Type_size(recvtype, &rsize); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_Alltoall, (app_ptr)comm, size, rank); } int MPI_Alltoall(CONST void *sendbuf, int sendcount, MPI_Datatype sendtype, void *recvbuf, int recvcnt, MPI_Datatype recvtype, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Alltoall_prolog(sendbuf, sendcount, sendtype, recvbuf, recvcnt, recvtype, comm); int ret = MPI_Alltoall_core(sendbuf, sendcount, sendtype, recvbuf, recvcnt, recvtype, comm); MPI_Alltoall_epilog(sendbuf, sendcount, sendtype, recvbuf, recvcnt, recvtype, comm); return ret; } void mpif_alltoall_(void *sbuf, int *scount, MPI_Fint *sd, void *rbuf, int *rcount, MPI_Fint *rd, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); void *c_sbuf = CHECK_MPI_IN_PLACE(sbuf); void *c_rbuf = CHECK_MPI_IN_PLACE(rbuf); MPI_Alltoall_prolog(c_sbuf, *scount, c_stype, c_rbuf, *rcount, c_rtype, c_comm); *error = MPI_Alltoall_core(c_sbuf, *scount, c_stype, c_rbuf, *rcount, c_rtype, c_comm); MPI_Alltoall_epilog(c_sbuf, *scount, c_stype, c_rbuf, *rcount, c_rtype, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_alltoallv.c000066400000000000000000000075501265506773700232120ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Alltoallv_prolog (CONST void *sendbuf __attribute__((unused)), CONST int *sendcnts __attribute__((unused)), CONST int *sdispls __attribute__((unused)), MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), CONST int *recvcnts __attribute__((unused)), CONST int *rdispls __attribute__((unused)), MPI_Datatype recvtype, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int ssize=0; int rsize =0; if(sendtype != MPI_DATATYPE_NULL) MPI_Type_size(sendtype, &ssize); if(recvtype != MPI_DATATYPE_NULL) MPI_Type_size(recvtype, &rsize); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_Alltoallv, (app_ptr)comm, size, rank); } static int MPI_Alltoallv_core(CONST void *sendbuf, CONST int *sendcnts, CONST int *sdispls, MPI_Datatype sendtype, void *recvbuf, CONST int *recvcnts, CONST int *rdispls, MPI_Datatype recvtype, MPI_Comm comm) { return libMPI_Alltoallv(sendbuf, sendcnts, sdispls, sendtype, recvbuf, recvcnts, rdispls, recvtype, comm); } static void MPI_Alltoallv_epilog (CONST void *sendbuf __attribute__((unused)), CONST int *sendcnts __attribute__((unused)), CONST int *sdispls __attribute__((unused)), MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), CONST int *recvcnts __attribute__((unused)), CONST int *rdispls __attribute__((unused)), MPI_Datatype recvtype, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int ssize=0; int rsize =0; if(sendtype != MPI_DATATYPE_NULL) MPI_Type_size(sendtype, &ssize); if(recvtype != MPI_DATATYPE_NULL) MPI_Type_size(recvtype, &rsize); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_Alltoallv, (app_ptr)comm, size, rank); } int MPI_Alltoallv(CONST void *sendbuf, CONST int *sendcnts, CONST int *sdispls, MPI_Datatype sendtype, void *recvbuf, CONST int *recvcnts, CONST int *rdispls, MPI_Datatype recvtype, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Alltoallv_prolog(sendbuf, sendcnts, sdispls, sendtype, recvbuf, recvcnts, rdispls, recvtype, comm); int ret = MPI_Alltoallv_core(sendbuf, sendcnts, sdispls, sendtype, recvbuf, recvcnts, rdispls, recvtype, comm); MPI_Alltoallv_epilog(sendbuf, sendcnts, sdispls, sendtype, recvbuf, recvcnts, rdispls, recvtype, comm); return ret; } void mpif_alltoallv_(void *sbuf, int *scount, int *sdispls, MPI_Fint *sd, void *rbuf, int *rcount, int *rdispls, MPI_Fint *rd, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); void *c_sbuf = CHECK_MPI_IN_PLACE(sbuf); void *c_rbuf = CHECK_MPI_IN_PLACE(rbuf); MPI_Alltoallv_prolog(c_sbuf, scount, sdispls, c_stype, c_rbuf, rcount, rdispls, c_rtype, c_comm); *error = MPI_Alltoallv_core(c_sbuf, scount, sdispls, c_stype, c_rbuf, rcount, rdispls, c_rtype, c_comm); MPI_Alltoallv_epilog(c_sbuf, scount, sdispls, c_stype, c_rbuf, rcount, rdispls, c_rtype, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_barrier.c000066400000000000000000000024341265506773700226420ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Barrier_prolog(MPI_Comm c) { int rank = -1; int size = -1; libMPI_Comm_size(c, &size); libMPI_Comm_rank(c, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_BARRIER, (app_ptr)c, rank, size); } static int MPI_Barrier_core(MPI_Comm c) { return libMPI_Barrier(c); } static void MPI_Barrier_epilog(MPI_Comm c) { int rank = -1; int size = -1; libMPI_Comm_size(c, &size); libMPI_Comm_rank(c, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_BARRIER, (app_ptr)c, rank, size); } int MPI_Barrier(MPI_Comm c) { FUNCTION_ENTRY; MPI_Barrier_prolog(c); int ret = MPI_Barrier_core(c); MPI_Barrier_epilog(c); return ret; } void mpif_barrier_(MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Barrier_prolog(c_comm); *error = MPI_Barrier_core(c_comm); MPI_Barrier_epilog(c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_bcast.c000066400000000000000000000040261265506773700223070ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Bcast_prolog(void *buffer __attribute__((unused)), int count, MPI_Datatype datatype, int root, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_START_BCast, (app_ptr)comm, size, rank, root); } static int MPI_Bcast_core(void *buffer, int count, MPI_Datatype datatype, int root, MPI_Comm comm) { return libMPI_Bcast(buffer, count, datatype, root, comm); } static void MPI_Bcast_epilog(void *buffer __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype, int __attribute__((unused)) root, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_BCast, (app_ptr)comm, size, rank); } int MPI_Bcast(void *buffer, int count, MPI_Datatype datatype, int root, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Bcast_prolog(buffer, count, datatype, root, comm); int ret = MPI_Bcast_core(buffer, count, datatype, root, comm); MPI_Bcast_epilog(buffer, count, datatype, root, comm); return ret; } void mpif_bcast_(void *buf, int *count, MPI_Fint *d, int *root, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Bcast_prolog(buf, *count, c_type, *root, c_comm); *error = MPI_Bcast_core(buf, *count, c_type, *root, c_comm); MPI_Bcast_epilog(buf, *count, c_type, *root, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_bsend.c000066400000000000000000000040111265506773700223000ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Bsend_prolog (CONST void* buf __attribute__((unused)), int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { int size; MPI_Type_size(datatype, &size); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_START_BSEND, count*size, dest, tag, (app_ptr)comm); } static int MPI_Bsend_core(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { return libMPI_Bsend(buf, count, datatype, dest, tag, comm); } static void MPI_Bsend_epilog (CONST void* buf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { int size; MPI_Type_size(datatype, &size); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_BSEND, dest, tag, (app_ptr)comm); } int MPI_Bsend(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Bsend_prolog(buf, count, datatype, dest, tag, comm); int ret = MPI_Bsend_core(buf, count, datatype, dest, tag, comm); MPI_Bsend_epilog(buf, count, datatype, dest, tag, comm); return ret; } void mpif_bsend_(void *buf, int *count, MPI_Fint *d, int *dest, int *tag, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Bsend_prolog(buf, *count, c_type, *dest, *tag, c_comm); *error = MPI_Bsend_core(buf, *count, c_type, *dest, *tag, c_comm); MPI_Bsend_epilog(buf, *count, c_type, *dest, *tag, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_bsend_init.c000066400000000000000000000034721265506773700233350ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static int MPI_Bsend_init_core(CONST void* buffer, int count, MPI_Datatype type, int dest, int tag, MPI_Comm comm, MPI_Request *req) { return libMPI_Bsend_init(buffer, count, type, dest, tag, comm, req); } static void MPI_Bsend_init_epilog(CONST void* buffer, int count, MPI_Datatype type, int dest, int tag, MPI_Comm comm, MPI_Request *req) { int size; MPI_Type_size(type, &size); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_BSEND_INIT, (app_ptr)buffer, count*size, dest); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_Info, tag, (app_ptr)comm, (app_ptr)req); } int MPI_Bsend_init(CONST void* buffer, int count, MPI_Datatype type, int dest, int tag, MPI_Comm comm, MPI_Request *req) { FUNCTION_ENTRY; int ret = MPI_Bsend_init_core(buffer, count, type, dest, tag, comm, req); MPI_Bsend_init_epilog(buffer, count, type, dest, tag, comm, (void*) req); return ret; } void mpif_bsend_init_(void*buffer, int*count, MPI_Fint*type, int*dest, int*tag, MPI_Fint*comm, MPI_Fint *req, int*error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*type); MPI_Comm c_comm = MPI_Comm_f2c(*comm); MPI_Request c_req = MPI_Request_f2c(*req); *error = MPI_Bsend_init_core(buffer, *count, c_type, *dest, *tag, c_comm, &c_req); *req = MPI_Request_c2f(c_req); MPI_Bsend_init_epilog(buffer, *count, c_type, *dest, *tag, c_comm, (MPI_Request *)req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_cancel.c000066400000000000000000000016731265506773700224450ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Cancel_prolog(MPI_Fint *req) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_CANCEL, (app_ptr)req); } static int MPI_Cancel_core(MPI_Request *request) { return libMPI_Cancel(request); } int MPI_Cancel(MPI_Request *req) { FUNCTION_ENTRY; MPI_Cancel_prolog((MPI_Fint*) req); int ret = MPI_Cancel_core(req); return ret; } void mpif_cancel_(MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Request c_req = MPI_Request_f2c(*r); MPI_Cancel_prolog(r); *error = MPI_Cancel_core(&c_req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_gather.c000066400000000000000000000060051265506773700224640ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Gather_prolog(CONST void *sendbuf __attribute__((unused)), int sendcnt, MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), int recvcount __attribute__((unused)), MPI_Datatype recvtype, int root, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_Gather, (app_ptr)comm, size, rank); } static int MPI_Gather_core(CONST void *sendbuf, int sendcnt, MPI_Datatype sendtype, void *recvbuf, int recvcount, MPI_Datatype recvtype, int root, MPI_Comm comm) { return libMPI_Gather(sendbuf, sendcnt, sendtype, recvbuf, recvcount, recvtype, root, comm); } static void MPI_Gather_epilog(CONST void *sendbuf __attribute__((unused)), int sendcnt __attribute__((unused)), MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), int recvcount __attribute__((unused)), MPI_Datatype recvtype, int root __attribute__((unused)), MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_Gather, (app_ptr)comm, size, rank); } int MPI_Gather(CONST void *sendbuf, int sendcnt, MPI_Datatype sendtype, void *recvbuf, int recvcount, MPI_Datatype recvtype, int root, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Gather_prolog(sendbuf, sendcnt, sendtype, recvbuf, recvcount, recvtype, root, comm); int ret = MPI_Gather_core(sendbuf, sendcnt, sendtype, recvbuf, recvcount, recvtype, root, comm); MPI_Gather_epilog(sendbuf, sendcnt, sendtype, recvbuf, recvcount, recvtype, root, comm); return ret; } void mpif_gather_(void *sbuf, int *scount, MPI_Fint *sd, void *rbuf, int *rcount, MPI_Fint *rd, int *root, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); void *c_sbuf = CHECK_MPI_IN_PLACE(sbuf); void *c_rbuf = CHECK_MPI_IN_PLACE(rbuf); MPI_Gather_prolog(c_sbuf, *scount, c_stype, c_rbuf, *rcount, c_rtype, *root, c_comm); *error = MPI_Gather_core(c_sbuf, *scount, c_stype, c_rbuf, *rcount, c_rtype, *root, c_comm); MPI_Gather_epilog(c_sbuf, *scount, c_stype, c_rbuf, *rcount, c_rtype, *root, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_gatherv.c000066400000000000000000000064661265506773700226650ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Gatherv_prolog(CONST void *sendbuf __attribute__((unused)), int sendcnt, MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), CONST int *recvcnts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype recvtype, int root, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_Gatherv, (app_ptr)comm, size, rank); } static int MPI_Gatherv_core(CONST void *sendbuf, int sendcnt, MPI_Datatype sendtype, void *recvbuf, CONST int *recvcnts, CONST int *displs, MPI_Datatype recvtype, int root, MPI_Comm comm) { return libMPI_Gatherv(sendbuf, sendcnt, sendtype, recvbuf, recvcnts, displs, recvtype, root, comm); } static void MPI_Gatherv_epilog(CONST void *sendbuf __attribute__((unused)), int sendcnt __attribute__((unused)), MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), CONST int *recvcnts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype recvtype, int root __attribute__((unused)), MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_Gatherv, (app_ptr)comm, size, rank); } int MPI_Gatherv(CONST void *sendbuf, int sendcnt, MPI_Datatype sendtype, void *recvbuf, CONST int *recvcnts, CONST int *displs, MPI_Datatype recvtype, int root, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Gatherv_prolog(sendbuf, sendcnt, sendtype, recvbuf, recvcnts, displs, recvtype, root, comm); int ret = MPI_Gatherv_core(sendbuf, sendcnt, sendtype, recvbuf, recvcnts, displs, recvtype, root, comm); MPI_Gatherv_epilog(sendbuf, sendcnt, sendtype, recvbuf, recvcnts, displs, recvtype, root, comm); return ret; } void mpif_gatherv_(void *sbuf, int *scount, MPI_Fint *sd, void *rbuf, int *rcount, int *displs, MPI_Fint *rd, int *root, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); void *c_sbuf = CHECK_MPI_IN_PLACE(sbuf); void *c_rbuf = CHECK_MPI_IN_PLACE(rbuf); MPI_Gatherv_prolog(c_sbuf, *scount, c_stype, c_rbuf, rcount, displs, c_rtype, *root, c_comm); *error = MPI_Gatherv_core(c_sbuf, *scount, c_stype, c_rbuf, rcount, displs, c_rtype, *root, c_comm); MPI_Gatherv_epilog(c_sbuf, *scount, c_stype, c_rbuf, rcount, displs, c_rtype, *root, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_get.c000066400000000000000000000067401265506773700217770ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Get_prolog(void *origin_addr __attribute__((unused)), int origin_count __attribute__((unused)), MPI_Datatype origin_datatype __attribute__((unused)), int target_rank __attribute__((unused)), MPI_Aint target_disp __attribute__((unused)), int target_count __attribute__((unused)), MPI_Datatype target_datatype __attribute__((unused)), MPI_Win win __attribute__((unused))) { EZTRACE_EVENT_PACKED_0(EZTRACE_MPI_START_GET); } static int MPI_Get_core(void *origin_addr, int origin_count, MPI_Datatype origin_datatype, int target_rank, MPI_Aint target_disp, int target_count, MPI_Datatype target_datatype, MPI_Win win) { return libMPI_Get(origin_addr, origin_count, origin_datatype, target_rank, target_disp, target_count, target_datatype, win); } static void MPI_Get_epilog(void *origin_addr __attribute__((unused)), int origin_count __attribute__((unused)), MPI_Datatype origin_datatype __attribute__((unused)), int target_rank, MPI_Aint target_disp __attribute__((unused)), int target_count, MPI_Datatype target_datatype, MPI_Win win __attribute__((unused))) { int tsize; MPI_Type_size(target_datatype, &tsize); /* FIXME: this is interpreted as a mpi_recv, but it should not ! */ EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_GET, target_count*tsize, target_rank, 0); } int MPI_Get(void *origin_addr, int origin_count, MPI_Datatype origin_datatype, int target_rank, MPI_Aint target_disp, int target_count, MPI_Datatype target_datatype, MPI_Win win) { FUNCTION_ENTRY; MPI_Get_prolog(origin_addr, origin_count, origin_datatype, target_rank, target_disp, target_count, target_datatype, win); int ret = MPI_Get_core(origin_addr, origin_count, origin_datatype, target_rank, target_disp, target_count, target_datatype, win); MPI_Get_epilog(origin_addr, origin_count, origin_datatype, target_rank, target_disp, target_count, target_datatype, win); return ret; } void mpif_get_(void *o_addr, int *o_count, MPI_Fint *o_d, int *t_rank, MPI_Aint *t_disp, int *t_count, MPI_Fint *t_d, MPI_Fint *win, int *error) { FUNCTION_ENTRY; MPI_Datatype c_otype = MPI_Type_f2c(*o_d); MPI_Datatype c_ttype = MPI_Type_f2c(*t_d); MPI_Win c_win = MPI_Win_f2c(*win); MPI_Get_prolog(o_addr, *o_count, c_otype, *t_rank, *t_disp, *t_count, c_ttype, c_win); *error = MPI_Get_core(o_addr, *o_count, c_otype, *t_rank, *t_disp, *t_count, c_ttype, c_win); MPI_Get_epilog(o_addr, *o_count, c_otype, *t_rank, *t_disp, *t_count, c_ttype, c_win); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_iallgather.c000066400000000000000000000054441265506773700233340ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Iallgather_prolog(CONST void __attribute__((unused)) *sendbuf, int sendcount, MPI_Datatype sendtype, void __attribute__((unused)) *recvbuf, int __attribute__((unused)) recvcount, MPI_Datatype recvtype, MPI_Comm comm, MPI_Request *r) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_IALLGATHER, (app_ptr)comm, size, rank, (app_ptr)r); } static int MPI_Iallgather_core(CONST void *sendbuf, int sendcount, MPI_Datatype sendtype, void *recvbuf, int recvcount, MPI_Datatype recvtype, MPI_Comm comm, MPI_Request *r) { return libMPI_Iallgather(sendbuf, sendcount, sendtype, recvbuf, recvcount, recvtype, comm, r); } static void MPI_Iallgather_epilog(CONST void __attribute__((unused)) *sendbuf, int sendcount __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), int recvcount __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IALLGATHER, (app_ptr)r); } int MPI_Iallgather(CONST void *sendbuf, int sendcount, MPI_Datatype sendtype, void *recvbuf, int recvcount, MPI_Datatype recvtype, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Iallgather_prolog(sendbuf, sendcount, sendtype, recvbuf, recvcount, recvtype, comm, r); int ret = MPI_Iallgather_core(sendbuf, sendcount, sendtype, recvbuf, recvcount, recvtype, comm, r); MPI_Iallgather_epilog(sendbuf, sendcount, sendtype, recvbuf, recvcount, recvtype, comm, r); return ret; } void mpif_iallgather_(void *sbuf, int *scount, MPI_Fint *sd, void *rbuf, int *rcount, MPI_Fint *rd, MPI_Fint *c, MPI_Fint *r,int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Iallgather_prolog(sbuf, *scount, c_stype, rbuf, *rcount, c_rtype, c_comm, r); *error = MPI_Iallgather_core(sbuf, *scount, c_stype, rbuf, *rcount, c_rtype, c_comm, &c_req); *r= MPI_Request_c2f(c_req); MPI_Iallgather_epilog(sbuf, *scount, c_stype, rbuf, *rcount, c_rtype, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_iallgatherv.c000066400000000000000000000064411265506773700235200ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Iallgatherv_prolog (CONST void *sendbuf __attribute__((unused)), int sendcount __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), CONST int *recvcounts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_IALLGATHERV, (app_ptr)comm, size, rank, (app_ptr)r); } static int MPI_Iallgatherv_core (CONST void *sendbuf __attribute__((unused)), int sendcount, MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), CONST int *recvcounts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype recvtype, MPI_Comm comm, MPI_Request *r) { return libMPI_Iallgatherv (sendbuf, sendcount, sendtype, recvbuf, recvcounts, displs, recvtype, comm, r); } static void MPI_Iallgatherv_epilog (CONST void *sendbuf __attribute__((unused)), int sendcount __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), CONST int *recvcounts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IALLGATHERV, (app_ptr)r); } int MPI_Iallgatherv (CONST void *sendbuf, int sendcount, MPI_Datatype sendtype, void *recvbuf, CONST int *recvcounts, CONST int *displs, MPI_Datatype recvtype, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Iallgatherv_prolog (sendbuf, sendcount, sendtype, recvbuf, recvcounts, displs, recvtype, comm, r); int ret = MPI_Iallgatherv_core (sendbuf, sendcount, sendtype, recvbuf, recvcounts, displs, recvtype, comm, r); MPI_Iallgatherv_epilog (sendbuf, sendcount, sendtype, recvbuf, recvcounts, displs, recvtype, comm, r); return ret; } void mpif_iallgatherv_(void *sbuf, int *scount, MPI_Fint *sd, void *rbuf, int *rcount, int *displs, MPI_Fint *rd, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Iallgatherv_prolog(sbuf, *scount, c_stype, rbuf, rcount, displs, c_rtype, c_comm, r); *error = MPI_Iallgatherv_core(sbuf, *scount, c_stype, rbuf, rcount, displs, c_rtype, c_comm, &c_req); *r = MPI_Request_c2f(c_req); MPI_Iallgatherv_epilog(sbuf, *scount, c_stype, rbuf, rcount, displs, c_rtype, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_iallreduce.c000066400000000000000000000050641265506773700233270ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Iallreduce_prolog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype, MPI_Op op __attribute__((unused)), MPI_Comm comm, MPI_Request *r) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int len; MPI_Type_size(datatype, &len); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_IALLREDUCE, (app_ptr)comm, size, rank, (app_ptr)r); } static int MPI_Iallreduce_core (CONST void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm, MPI_Request *r) { return libMPI_Iallreduce (sendbuf, recvbuf, count, datatype, op, comm, r); } static void MPI_Iallreduce_epilog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), MPI_Op op __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IALLREDUCE, (app_ptr)r); } int MPI_Iallreduce (CONST void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Iallreduce_prolog (sendbuf, recvbuf, count, datatype, op, comm, r); int ret = MPI_Iallreduce_core (sendbuf, recvbuf, count, datatype, op, comm, r); MPI_Iallreduce_epilog (sendbuf, recvbuf, count, datatype, op, comm, r); return ret; } void mpif_iallreduce_(void *sbuf, void *rbuf, int *count, MPI_Fint *d, MPI_Fint *op, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Op c_op = MPI_Op_f2c(*op); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Iallreduce_prolog(sbuf, rbuf, *count, c_type, c_op, c_comm, r); *error = MPI_Iallreduce_core(sbuf, rbuf, *count, c_type, c_op, c_comm, &c_req); *r = MPI_Request_c2f(c_req); MPI_Iallreduce_epilog(sbuf, rbuf, *count, c_type, c_op, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_ialltoall.c000066400000000000000000000056331265506773700231750ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Ialltoall_prolog (CONST void *sendbuf __attribute__((unused)), int sendcount __attribute__((unused)), MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), int recvcnt __attribute__((unused)), MPI_Datatype recvtype, MPI_Comm comm, MPI_Request *r) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int ssize, rsize; MPI_Type_size(sendtype, &ssize); MPI_Type_size(recvtype, &rsize); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_IALLTOALL, (app_ptr)comm, size, rank, (app_ptr)r); } static int MPI_Ialltoall_core (CONST void *sendbuf, int sendcount, MPI_Datatype sendtype, void *recvbuf, int recvcnt, MPI_Datatype recvtype, MPI_Comm comm, MPI_Request *r) { return libMPI_Ialltoall (sendbuf, sendcount, sendtype, recvbuf, recvcnt, recvtype, comm, r); } static void MPI_Ialltoall_epilog (CONST void *sendbuf __attribute__((unused)), int sendcount __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), int recvcnt __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IALLTOALL, (app_ptr)r); } int MPI_Ialltoall (CONST void *sendbuf, int sendcount, MPI_Datatype sendtype, void *recvbuf, int recvcnt, MPI_Datatype recvtype, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Ialltoall_prolog (sendbuf, sendcount, sendtype, recvbuf, recvcnt, recvtype, comm, r); int ret = MPI_Ialltoall_core (sendbuf, sendcount, sendtype, recvbuf, recvcnt, recvtype, comm, r); MPI_Ialltoall_epilog (sendbuf, sendcount, sendtype, recvbuf, recvcnt, recvtype, comm, r); return ret; } void mpif_ialltoall_(void *sbuf, int *scount, MPI_Fint *sd, void *rbuf, int *rcount, MPI_Fint *rd, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Ialltoall_prolog(sbuf, *scount, c_stype, rbuf, *rcount, c_rtype, c_comm, r); *error = MPI_Ialltoall_core(sbuf, *scount, c_stype, rbuf, *rcount, c_rtype, c_comm, &c_req); *r = MPI_Request_c2f(c_req); MPI_Ialltoall_epilog(sbuf, *scount, c_stype, rbuf, *rcount, c_rtype, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_ialltoallv.c000066400000000000000000000065741265506773700233700ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Ialltoallv_prolog (CONST void *sendbuf __attribute__((unused)), CONST int *sendcnts __attribute__((unused)), CONST int *sdispls __attribute__((unused)), MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), CONST int *recvcnts __attribute__((unused)), CONST int *rdispls __attribute__((unused)), MPI_Datatype recvtype, MPI_Comm comm, MPI_Request *r) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int ssize, rsize; MPI_Type_size(sendtype, &ssize); MPI_Type_size(recvtype, &rsize); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_IALLTOALLV, (app_ptr)comm, size, rank, (app_ptr)r); } static int MPI_Ialltoallv_core (CONST void *sendbuf, CONST int *sendcnts, CONST int *sdispls, MPI_Datatype sendtype, void *recvbuf, CONST int *recvcnts, CONST int *rdispls, MPI_Datatype recvtype, MPI_Comm comm, MPI_Request *r) { return libMPI_Ialltoallv (sendbuf, sendcnts, sdispls, sendtype, recvbuf, recvcnts, rdispls, recvtype, comm, r); } static void MPI_Ialltoallv_epilog (CONST void *sendbuf __attribute__((unused)), CONST int *sendcnts __attribute__((unused)), CONST int *sdispls __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), CONST int *recvcnts __attribute__((unused)), CONST int *rdispls __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IALLTOALLV, (app_ptr)r); } int MPI_Ialltoallv (CONST void *sendbuf, CONST int *sendcnts, CONST int *sdispls, MPI_Datatype sendtype, void *recvbuf, CONST int *recvcnts, CONST int *rdispls, MPI_Datatype recvtype, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Ialltoallv_prolog (sendbuf, sendcnts, sdispls, sendtype, recvbuf, recvcnts, rdispls, recvtype, comm, r); int ret = MPI_Ialltoallv_core (sendbuf, sendcnts, sdispls, sendtype, recvbuf, recvcnts, rdispls, recvtype, comm, r); MPI_Ialltoallv_epilog (sendbuf, sendcnts, sdispls, sendtype, recvbuf, recvcnts, rdispls, recvtype, comm, r); return ret; } void mpif_ialltoallv_(void *sbuf, int *scount, int *sdispls, MPI_Fint *sd, void *rbuf, int *rcount, int *rdispls, MPI_Fint *rd, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Ialltoallv_prolog(sbuf, scount, sdispls, c_stype, rbuf, rcount, rdispls, c_rtype, c_comm, r); *error = MPI_Ialltoallv_core(sbuf, scount, sdispls, c_stype, rbuf, rcount, rdispls, c_rtype, c_comm, &c_req); *r = MPI_Request_c2f(c_req); MPI_Ialltoallv_epilog(sbuf, scount, sdispls, c_stype, rbuf, rcount, rdispls, c_rtype, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_ibarrier.c000066400000000000000000000026531265506773700230160ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Ibarrier_prolog (MPI_Comm c, MPI_Fint *r) { int rank = -1; int size = -1; libMPI_Comm_size(c, &size); libMPI_Comm_rank(c, &rank); EZTRACE_EVENT_PACKED_4 (EZTRACE_MPI_IBARRIER, (app_ptr)c, rank, size, (app_ptr)r); } static int MPI_Ibarrier_core (MPI_Comm c, MPI_Request *r) { return libMPI_Ibarrier(c, r); } static void MPI_Ibarrier_epilog (MPI_Comm c, MPI_Fint *r) { EZTRACE_EVENT_PACKED_1 (EZTRACE_MPI_STOP_IBARRIER, (app_ptr)r); } int MPI_Ibarrier (MPI_Comm c, MPI_Request *req) { FUNCTION_ENTRY; MPI_Ibarrier_prolog(c, (MPI_Fint*)req); int ret = MPI_Ibarrier_core(c, req); MPI_Ibarrier_epilog(c, (MPI_Fint*)req); return ret; } void mpif_ibarrier_(MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Ibarrier_prolog(c_comm, r); *error = MPI_Ibarrier_core(c_comm, &c_req); *r= MPI_Request_c2f(c_req); MPI_Ibarrier_epilog(c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_ibcast.c000066400000000000000000000042471265506773700224650ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Ibcast_prolog(void *buffer __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype, int root, MPI_Comm comm, MPI_Request *r) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_IBCAST, (app_ptr)comm, size, rank, (app_ptr)r); } static int MPI_Ibcast_core(void *buffer, int count, MPI_Datatype datatype, int root, MPI_Comm comm, MPI_Request *r) { return libMPI_Ibcast(buffer, count, datatype, root, comm, r); } static void MPI_Ibcast_epilog(void *buffer __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IBCAST, (app_ptr)r); } int MPI_Ibcast(void *buffer, int count, MPI_Datatype datatype, int root, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Ibcast_prolog(buffer, count, datatype, root, comm, r); int ret = MPI_Ibcast_core(buffer, count, datatype, root, comm, r); MPI_Ibcast_epilog(buffer, count, datatype, root, comm, r); return ret; } void mpif_ibcast_(void *buf, int *count, MPI_Fint *d, int *root, MPI_Fint *c, MPI_Fint*r, int *error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Ibcast_prolog(buf, *count, c_type, *root, c_comm, r); *error = MPI_Ibcast_core(buf, *count, c_type, *root, c_comm, &c_req); *r= MPI_Request_c2f(c_req); MPI_Ibcast_epilog(buf, *count, c_type, *root, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_ibsend.c000066400000000000000000000044701265506773700224620ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Ibsend_prolog (CONST void* buf __attribute__((unused)), int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Fint *req) { int size; MPI_Type_size(datatype, &size); EZTRACE_EVENT_PACKED_5(EZTRACE_MPI_IBSEND, count*size, dest, tag, (app_ptr)req, (app_ptr)comm); } static int MPI_Ibsend_core(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *req) { return libMPI_Ibsend(buf, count, datatype, dest, tag, comm, req); } static void MPI_Ibsend_epilog (CONST void* buf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), int dest __attribute__((unused)), int tag __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Fint *req) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IBSEND, (app_ptr)req); } int MPI_Ibsend(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *req) { FUNCTION_ENTRY; MPI_Ibsend_prolog(buf, count, datatype, dest, tag, comm, (MPI_Fint*) req); int ret = MPI_Ibsend_core(buf, count, datatype, dest, tag, comm, req); MPI_Ibsend_epilog(buf, count, datatype, dest, tag, comm, (MPI_Fint*) req); return ret; } void mpif_ibsend_(void *buf, int *count, MPI_Fint *d, int *dest, int *tag, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Ibsend_prolog(buf, *count, c_type, *dest, *tag, c_comm, r); *error = MPI_Ibsend_core(buf, *count, c_type, *dest, *tag, c_comm, &c_req); *r = MPI_Request_c2f(c_req); MPI_Ibsend_epilog(buf, *count, c_type, *dest, *tag, c_comm, r); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_igather.c000066400000000000000000000057141265506773700226430ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Igather_prolog(CONST void *sendbuf __attribute__((unused)), int sendcnt __attribute__((unused)), MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), int recvcount __attribute__((unused)), MPI_Datatype recvtype, int root __attribute__((unused)), MPI_Comm comm, MPI_Request *r) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_IGATHER, (app_ptr)comm, size, rank, (app_ptr)r); } static int MPI_Igather_core(CONST void *sendbuf, int sendcnt, MPI_Datatype sendtype, void *recvbuf, int recvcount, MPI_Datatype recvtype, int root, MPI_Comm comm, MPI_Request *r) { return libMPI_Igather(sendbuf, sendcnt, sendtype, recvbuf, recvcount, recvtype, root, comm, r); } static void MPI_Igather_epilog(CONST void *sendbuf __attribute__((unused)), int sendcnt __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), int recvcount __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IGATHER, (app_ptr)r); } int MPI_Igather(CONST void *sendbuf, int sendcnt, MPI_Datatype sendtype, void *recvbuf, int recvcount, MPI_Datatype recvtype, int root, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Igather_prolog(sendbuf, sendcnt, sendtype, recvbuf, recvcount, recvtype, root, comm, r); int ret = MPI_Igather_core(sendbuf, sendcnt, sendtype, recvbuf, recvcount, recvtype, root, comm, r); MPI_Igather_epilog(sendbuf, sendcnt, sendtype, recvbuf, recvcount, recvtype, root, comm, r); return ret; } void mpif_igather_(void *sbuf, int *scount, MPI_Fint *sd, void *rbuf, int *rcount, MPI_Fint *rd, int *root, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Igather_prolog(sbuf, *scount, c_stype, rbuf, *rcount, c_rtype, *root, c_comm, r); *error = MPI_Igather_core(sbuf, *scount, c_stype, rbuf, *rcount, c_rtype, *root, c_comm, &c_req); *r= MPI_Request_c2f(c_req); MPI_Igather_epilog(sbuf, *scount, c_stype, rbuf, *rcount, c_rtype, *root, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_igatherv.c000066400000000000000000000061421265506773700230250ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Igatherv_prolog(CONST void *sendbuf __attribute__((unused)), int sendcnt __attribute__((unused)), MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), CONST int *recvcnts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype recvtype, int root __attribute__((unused)), MPI_Comm comm, MPI_Request *r) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_IGATHERV, (app_ptr)comm, size, rank, (app_ptr)r); } static int MPI_Igatherv_core(CONST void *sendbuf, int sendcnt, MPI_Datatype sendtype, void *recvbuf, CONST int *recvcnts, CONST int *displs, MPI_Datatype recvtype, int root, MPI_Comm comm, MPI_Request *r) { return libMPI_Igatherv(sendbuf, sendcnt, sendtype, recvbuf, recvcnts, displs, recvtype, root, comm, r); } static void MPI_Igatherv_epilog(CONST void *sendbuf __attribute__((unused)), int sendcnt __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), CONST int *recvcnts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IGATHERV, (app_ptr)r); } int MPI_Igatherv(CONST void *sendbuf, int sendcnt, MPI_Datatype sendtype, void *recvbuf, CONST int *recvcnts, CONST int *displs, MPI_Datatype recvtype, int root, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Igatherv_prolog(sendbuf, sendcnt, sendtype, recvbuf, recvcnts, displs, recvtype, root, comm, r); int ret = MPI_Igatherv_core(sendbuf, sendcnt, sendtype, recvbuf, recvcnts, displs, recvtype, root, comm, r); MPI_Igatherv_epilog(sendbuf, sendcnt, sendtype, recvbuf, recvcnts, displs, recvtype, root, comm, r); return ret; } void mpif_igatherv_(void *sbuf, int *scount, MPI_Fint *sd, void *rbuf, int *rcount, int *displs, MPI_Fint *rd, int *root, MPI_Fint *c, MPI_Fint *r,int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Igatherv_prolog(sbuf, *scount, c_stype, rbuf, rcount, displs, c_rtype, *root, c_comm, r); *error = MPI_Igatherv_core(sbuf, *scount, c_stype, rbuf, rcount, displs, c_rtype, *root, c_comm, &c_req); *r= MPI_Request_c2f(c_req); MPI_Igatherv_epilog(sbuf, *scount, c_stype, rbuf, rcount, displs, c_rtype, *root, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_iprobe.c000066400000000000000000000035441265506773700224770ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static int MPI_Iprobe_core(int source, int tag, MPI_Comm comm, int *flag, MPI_Status *status) { return libMPI_Iprobe(source, tag, comm, flag, status); } static void MPI_Iprobe_epilog(int source __attribute__((unused)), int tag __attribute__((unused)), MPI_Comm comm __attribute__((unused)), int *flag, MPI_Status *status) { if (*flag) { int length = -1; MPI_Get_count(status, MPI_BYTE, &length); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_IPROBE_SUCCESS, status->MPI_SOURCE, status->MPI_TAG, length); } #if 0 /* comment out in order to avoid spamming the output trace * when the application perform a busy waiting like this: * do { iprobe(); } while(!success); */ else { EZTRACE_EVENT_PACKED_2(EZTRACE_MPI_IPROBE_FAILED, source, tag); } #endif } int MPI_Iprobe(int source, int tag, MPI_Comm comm, int *flag, MPI_Status *status) { FUNCTION_ENTRY; int ret = MPI_Iprobe_core(source, tag, comm, flag, status); MPI_Iprobe_epilog(source, tag, comm, flag, status); return ret; } void mpif_iprobe_(int* source, int* tag, MPI_Fint* comm, int *flag, MPI_Status *status, int* err) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*comm); *err = MPI_Iprobe_core(*source, *tag, c_comm, flag, status); MPI_Iprobe_epilog(*source, *tag, c_comm, flag, status); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_irecv.c000066400000000000000000000044351265506773700223270ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Irecv_prolog(void* buf __attribute__((unused)), int count, MPI_Datatype datatype, int src, int tag, MPI_Comm comm, MPI_Fint *req) { int size; MPI_Type_size(datatype, &size); EZTRACE_EVENT_PACKED_5(EZTRACE_MPI_IRECV, count*size, src, tag, (app_ptr)req, (app_ptr)comm); } static int MPI_Irecv_core(void* buf, int count, MPI_Datatype datatype, int src, int tag, MPI_Comm comm, MPI_Request *req) { return libMPI_Irecv(buf, count, datatype, src, tag, comm, req); } static void MPI_Irecv_epilog(void* buf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), int src __attribute__((unused)), int tag __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Fint *req) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IRECV, (app_ptr)req); } int MPI_Irecv(void* buf, int count, MPI_Datatype datatype, int src, int tag, MPI_Comm comm, MPI_Request *req) { FUNCTION_ENTRY; MPI_Irecv_prolog(buf, count, datatype, src, tag, comm, (MPI_Fint*) req); int ret = MPI_Irecv_core(buf, count, datatype, src, tag, comm, req); MPI_Irecv_epilog(buf, count, datatype, src, tag, comm, (MPI_Fint*) req); return ret; } void mpif_irecv_(void *buf, int *count, MPI_Fint *d, int *src, int *tag, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Irecv_prolog(buf, *count, c_type, *src, *tag, c_comm, r); *error = MPI_Irecv_core(buf, *count, c_type, *src, *tag, c_comm, &c_req); *r= MPI_Request_c2f(c_req); MPI_Irecv_epilog(buf, *count, c_type, *src, *tag, c_comm, r); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_ireduce.c000066400000000000000000000052161265506773700226350ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Ireduce_prolog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype, MPI_Op op __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm, MPI_Request *r) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int len; MPI_Type_size(datatype, &len); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_IREDUCE, (app_ptr)comm, size, rank, (app_ptr)r); } static int MPI_Ireduce_core (CONST void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, int root, MPI_Comm comm, MPI_Request *r) { return libMPI_Ireduce (sendbuf, recvbuf, count, datatype, op, root, comm, r); } static void MPI_Ireduce_epilog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), MPI_Op op __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IREDUCE, (app_ptr)r); } int MPI_Ireduce (CONST void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, int root, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Ireduce_prolog (sendbuf, recvbuf, count, datatype, op, root, comm, r); int ret = MPI_Ireduce_core (sendbuf, recvbuf, count, datatype, op, root, comm, r); MPI_Ireduce_epilog (sendbuf, recvbuf, count, datatype, op, root, comm, r); return ret; } void mpif_ireduce_(void *sbuf, void *rbuf, int *count, MPI_Fint *d, MPI_Fint *op, int *root, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Op c_op = MPI_Op_f2c(*op); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Ireduce_prolog(sbuf, rbuf, *count, c_type, c_op, *root, c_comm, r); *error = MPI_Ireduce_core(sbuf, rbuf, *count, c_type, c_op, *root, c_comm, &c_req); *r = MPI_Request_c2f(c_req); MPI_Ireduce_epilog(sbuf, rbuf, *count, c_type, c_op, *root, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_ireduce_scatter.c000066400000000000000000000052331265506773700243610ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Ireduce_scatter_prolog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), CONST int *recvcnts __attribute__((unused)), MPI_Datatype datatype, MPI_Op op __attribute__((unused)), MPI_Comm comm, MPI_Request *r) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int len; MPI_Type_size(datatype, &len); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_IREDUCE_SCATTER, (app_ptr)comm, size, rank, (app_ptr)r); } static int MPI_Ireduce_scatter_core (CONST void *sendbuf, void *recvbuf, CONST int *recvcnts, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm, MPI_Request *r) { return libMPI_Ireduce_scatter (sendbuf, recvbuf, recvcnts, datatype, op, comm, r); } static void MPI_Ireduce_scatter_epilog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), CONST int *recvcnts __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), MPI_Op op __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IREDUCE_SCATTER, (app_ptr)r); } int MPI_Ireduce_scatter (CONST void *sendbuf, void *recvbuf, CONST int *recvcnts, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Ireduce_scatter_prolog (sendbuf, recvbuf, recvcnts, datatype, op, comm, r); int ret = MPI_Ireduce_scatter_core (sendbuf, recvbuf, recvcnts, datatype, op, comm, r); MPI_Ireduce_scatter_epilog (sendbuf, recvbuf, recvcnts, datatype, op, comm, r); return ret; } void mpif_ireduce_scatter_(void *sbuf, void *rbuf, int *rcount, MPI_Fint *d, MPI_Fint *op, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Op c_op = MPI_Op_f2c(*op); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Ireduce_scatter_prolog(sbuf, rbuf, rcount, c_type, c_op, c_comm, r); *error = MPI_Ireduce_scatter_core(sbuf, rbuf, rcount, c_type, c_op, c_comm, &c_req); *r = MPI_Request_c2f(c_req); MPI_Ireduce_scatter_epilog(sbuf, rbuf, rcount, c_type, c_op, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_irsend.c000066400000000000000000000044711265506773700225030ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Irsend_prolog (CONST void* buf __attribute__((unused)), int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Fint *req) { int size; MPI_Type_size(datatype, &size); EZTRACE_EVENT_PACKED_5(EZTRACE_MPI_IRSEND, count*size, dest, tag, (app_ptr)req, (app_ptr)comm); } static int MPI_Irsend_core(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *req) { return libMPI_Irsend(buf, count, datatype, dest, tag, comm, req); } static void MPI_Irsend_epilog (CONST void* buf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), int dest __attribute__((unused)), int tag __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Fint *req) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_IRSEND, (app_ptr)req); } int MPI_Irsend(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *req) { FUNCTION_ENTRY; MPI_Irsend_prolog(buf, count, datatype, dest, tag, comm, (MPI_Fint*) req); int ret = MPI_Irsend_core(buf, count, datatype, dest, tag, comm, req); MPI_Irsend_epilog(buf, count, datatype, dest, tag, comm, (MPI_Fint*) req); return ret; } void mpif_irsend_(void *buf, int *count, MPI_Fint *d, int *dest, int *tag, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Irsend_prolog(buf, *count, c_type, *dest, *tag, c_comm, r); *error = MPI_Irsend_core(buf, *count, c_type, *dest, *tag, c_comm, &c_req); *r = MPI_Request_c2f(c_req); MPI_Irsend_epilog(buf, *count, c_type, *dest, *tag, c_comm, r); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_iscan.c000066400000000000000000000047721265506773700223200ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Iscan_prolog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype, MPI_Op op __attribute__((unused)), MPI_Comm comm, MPI_Request *r) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int len; MPI_Type_size(datatype, &len); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_ISCAN, (app_ptr)comm, size, rank, (app_ptr)r); } static int MPI_Iscan_core (CONST void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm, MPI_Request *r) { return libMPI_Iscan (sendbuf, recvbuf, count, datatype,op, comm, r); } static void MPI_Iscan_epilog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), MPI_Op op __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_ISCAN, (app_ptr)r); } int MPI_Iscan (CONST void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Iscan_prolog (sendbuf, recvbuf, count, datatype,op, comm, r); int ret = MPI_Iscan_core (sendbuf, recvbuf, count, datatype,op, comm, r); MPI_Iscan_epilog (sendbuf, recvbuf, count, datatype,op, comm, r); return ret; } void mpif_iscan_(void *sbuf, void *rbuf, int *count, MPI_Fint *d, MPI_Fint *op, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Op c_op = MPI_Op_f2c(*op); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Iscan_prolog(sbuf, rbuf, *count, c_type, c_op, c_comm, r); *error = MPI_Iscan_core(sbuf, rbuf, *count, c_type, c_op, c_comm, &c_req); *r = MPI_Request_c2f(c_req); MPI_Iscan_epilog(sbuf, rbuf, *count, c_type, c_op, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_iscatter.c000066400000000000000000000060121265506773700230260ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Iscatter_prolog(CONST void *sendbuf __attribute__((unused)), int sendcnt __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), int recvcnt __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm, MPI_Request *r ) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int ssize; MPI_Type_size(sendtype, &ssize); EZTRACE_EVENT_PACKED_5(EZTRACE_MPI_ISCATTER, (app_ptr)comm, size, rank, (ssize*sendcnt), (app_ptr)r); } static int MPI_Iscatter_core(CONST void *sendbuf, int sendcnt, MPI_Datatype sendtype, void *recvbuf, int recvcnt, MPI_Datatype recvtype, int root, MPI_Comm comm, MPI_Request *r) { return libMPI_Iscatter(sendbuf, sendcnt, sendtype, recvbuf, recvcnt, recvtype, root, comm, r); } static void MPI_Iscatter_epilog(CONST void *sendbuf __attribute__((unused)), int sendcnt __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), int recvcnt __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r ) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_ISCATTER, (app_ptr)r); } int MPI_Iscatter(CONST void *sendbuf, int sendcnt, MPI_Datatype sendtype, void *recvbuf, int recvcnt, MPI_Datatype recvtype, int root, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Iscatter_prolog(sendbuf, sendcnt, sendtype, recvbuf, recvcnt, recvtype, root, comm, r); int ret = MPI_Iscatter_core(sendbuf, sendcnt, sendtype, recvbuf, recvcnt, recvtype, root, comm, r); MPI_Iscatter_epilog(sendbuf, sendcnt, sendtype, recvbuf, recvcnt, recvtype, root, comm, r); return ret; } void mpif_iscatter_(void *sbuf, int *scount, MPI_Fint *sd, void *rbuf, int *rcount, MPI_Fint *rd, int *root, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Iscatter_prolog(sbuf, *scount, c_stype, rbuf, *rcount, c_rtype, *root, c_comm, r); *error = MPI_Iscatter_core(sbuf, *scount, c_stype, rbuf, *rcount, c_rtype, *root, c_comm, &c_req); *r= MPI_Request_c2f(c_req); MPI_Iscatter_epilog(sbuf, *scount, c_stype, rbuf, *rcount, c_rtype, *root, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_iscatterv.c000066400000000000000000000066061265506773700232250ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" #ifdef USE_MPI3 static void MPI_Iscatterv_prolog(CONST void *sendbuf __attribute__((unused)), CONST int *sendcnts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), int recvcnt __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm, MPI_Request *r) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int ssize; MPI_Type_size(sendtype, &ssize); EZTRACE_EVENT_PACKED_5(EZTRACE_MPI_ISCATTERV, (app_ptr)comm, size, rank, (ssize*(*sendcnts)), (app_ptr)r); } static int MPI_Iscatterv_core(CONST void *sendbuf, CONST int *sendcnts, CONST int *displs, MPI_Datatype sendtype, void *recvbuf, int recvcnt, MPI_Datatype recvtype, int root, MPI_Comm comm, MPI_Request *r) { return libMPI_Iscatterv(sendbuf, sendcnts, displs, sendtype, recvbuf, recvcnt, recvtype, root, comm, r); } static void MPI_Iscatterv_epilog(CONST void *sendbuf __attribute__((unused)), CONST int *sendcnts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), int recvcnt __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Request *r) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_ISCATTERV, (app_ptr)r); } int MPI_Iscatterv(CONST void *sendbuf, CONST int *sendcnts, CONST int *displs, MPI_Datatype sendtype, void *recvbuf, int recvcnt, MPI_Datatype recvtype, int root, MPI_Comm comm, MPI_Request *r) { FUNCTION_ENTRY; MPI_Iscatterv_prolog(sendbuf, sendcnts, displs, sendtype, recvbuf, recvcnt, recvtype, root, comm, r); int ret = MPI_Iscatterv_core(sendbuf, sendcnts, displs, sendtype, recvbuf, recvcnt, recvtype, root, comm, r); MPI_Iscatterv_epilog(sendbuf, sendcnts, displs, sendtype, recvbuf, recvcnt, recvtype, root, comm, r); return ret; } void mpif_iscatterv_(void *sbuf, int *scount, int *displs, MPI_Fint *sd, void *rbuf, int *rcount, MPI_Fint *rd, int *root, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Iscatterv_prolog(sbuf, scount, displs, c_stype, rbuf, *rcount, c_rtype, *root, c_comm, r); *error = MPI_Iscatterv_core(sbuf, scount, displs, c_stype, rbuf, *rcount, c_rtype, *root, c_comm, &c_req); *r= MPI_Request_c2f(c_req); MPI_Iscatterv_epilog(sbuf, scount, displs, c_stype, rbuf, *rcount, c_rtype, *root, c_comm, r); } #endif eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_isend.c000066400000000000000000000044361265506773700223220ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Isend_prolog (CONST void* buf __attribute__((unused)), int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Fint *req) { int size; MPI_Type_size(datatype, &size); EZTRACE_EVENT_PACKED_5(EZTRACE_MPI_ISEND, count * size, dest, tag, (app_ptr)req, (app_ptr)comm); } static int MPI_Isend_core(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *req) { return libMPI_Isend(buf, count, datatype, dest, tag, comm, req); } static void MPI_Isend_epilog (CONST void* buf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), int dest __attribute__((unused)), int tag __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Fint *req) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_ISEND, (app_ptr)req); } int MPI_Isend(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *req) { FUNCTION_ENTRY; MPI_Isend_prolog(buf, count, datatype, dest, tag, comm, (MPI_Fint*) req); int ret = MPI_Isend_core(buf, count, datatype, dest, tag, comm, req); MPI_Isend_epilog(buf, count, datatype, dest, tag, comm, (MPI_Fint*) req); return ret; } void mpif_isend_(void *buf, int *count, MPI_Fint *d, int *dest, int *tag, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Isend_prolog(buf, *count, c_type, *dest, *tag, c_comm, r); *error = MPI_Isend_core(buf, *count, c_type, *dest, *tag, c_comm, &c_req); *r = MPI_Request_c2f(c_req); MPI_Isend_epilog(buf, *count, c_type, *dest, *tag, c_comm, r); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_issend.c000066400000000000000000000044711265506773700225040ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Issend_prolog (CONST void* buf __attribute__((unused)), int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Fint *req) { int size; MPI_Type_size(datatype, &size); EZTRACE_EVENT_PACKED_5(EZTRACE_MPI_ISSEND, count*size, dest, tag, (app_ptr)req, (app_ptr)comm); } static int MPI_Issend_core(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *req) { return libMPI_Issend(buf, count, datatype, dest, tag, comm, req); } static void MPI_Issend_epilog (CONST void* buf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), int dest __attribute__((unused)), int tag __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Fint *req) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_ISSEND, (app_ptr)req); } int MPI_Issend(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *req) { FUNCTION_ENTRY; MPI_Issend_prolog(buf, count, datatype, dest, tag, comm, (MPI_Fint*) req); int ret = MPI_Issend_core(buf, count, datatype, dest, tag, comm, req); MPI_Issend_epilog(buf, count, datatype, dest, tag, comm, (MPI_Fint*) req); return ret; } void mpif_issend_(void *buf, int *count, MPI_Fint *d, int *dest, int *tag, MPI_Fint *c, MPI_Fint *r, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Request c_req = MPI_Request_f2c(*r); MPI_Issend_prolog(buf, *count, c_type, *dest, *tag, c_comm, r); *error = MPI_Issend_core(buf, *count, c_type, *dest, *tag, c_comm, &c_req); *r = MPI_Request_c2f(c_req); MPI_Issend_epilog(buf, *count, c_type, *dest, *tag, c_comm, r); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_probe.c000066400000000000000000000036021265506773700223210ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Probe_prolog(int source __attribute__((unused)), int tag __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Status *status __attribute__((unused))) { EZTRACE_EVENT_PACKED_0(EZTRACE_MPI_START_PROBE); } static int MPI_Probe_core(int source, int tag, MPI_Comm comm, MPI_Status *status) { return libMPI_Probe(source, tag, comm, status); } static void MPI_Probe_epilog(int source __attribute__((unused)), int tag __attribute__((unused)), MPI_Comm comm __attribute__((unused)), MPI_Status *status) { int length = -1; MPI_Get_count(status, MPI_BYTE, &length); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_PROBE, status->MPI_SOURCE, status->MPI_TAG, length); } int MPI_Probe(int source, int tag, MPI_Comm comm, MPI_Status *status) { FUNCTION_ENTRY; MPI_Probe_prolog(source, tag, comm, status); int ret = MPI_Probe_core(source, tag, comm, status); MPI_Probe_epilog(source, tag, comm, status); return ret; } void mpif_probe_(int* source, int* tag, MPI_Fint* comm, MPI_Status *status, int* err) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*comm); MPI_Probe_prolog(*source, *tag, c_comm, status); *err = MPI_Probe_core(*source, *tag, c_comm, status); MPI_Probe_epilog(*source, *tag, c_comm, status); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_put.c000066400000000000000000000064131265506773700220250ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Put_prolog(CONST void *origin_addr __attribute__((unused)), int origin_count __attribute__((unused)), MPI_Datatype origin_datatype, int target_rank, MPI_Aint target_disp __attribute__((unused)), int target_count, MPI_Datatype target_datatype, MPI_Win win __attribute__((unused))) { int osize; MPI_Type_size(origin_datatype, &osize); int tsize; MPI_Type_size(target_datatype, &tsize); /* FIXME: this is interpreted as a mpi_send, but it should not ! */ EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_PUT, target_count*tsize, target_rank, 0); } static int MPI_Put_core(CONST void *origin_addr, int origin_count, MPI_Datatype origin_datatype, int target_rank, MPI_Aint target_disp, int target_count, MPI_Datatype target_datatype, MPI_Win win) { return libMPI_Put(origin_addr, origin_count, origin_datatype, target_rank, target_disp, target_count, target_datatype, win); } static void MPI_Put_epilog(CONST void *origin_addr __attribute__((unused)), int origin_count __attribute__((unused)), MPI_Datatype origin_datatype __attribute__((unused)), int target_rank __attribute__((unused)), MPI_Aint target_disp __attribute__((unused)), int target_count __attribute__((unused)), MPI_Datatype target_datatype __attribute__((unused)), MPI_Win win __attribute__((unused))) { EZTRACE_EVENT_PACKED_0(EZTRACE_MPI_STOP_PUT); } int MPI_Put(CONST void *origin_addr, int origin_count, MPI_Datatype origin_datatype, int target_rank, MPI_Aint target_disp, int target_count, MPI_Datatype target_datatype, MPI_Win win) { FUNCTION_ENTRY; MPI_Put_prolog(origin_addr, origin_count, origin_datatype, target_rank, target_disp, target_count, target_datatype, win); int ret = MPI_Put_core(origin_addr, origin_count, origin_datatype, target_rank, target_disp, target_count, target_datatype, win); MPI_Put_epilog(origin_addr, origin_count, origin_datatype, target_rank, target_disp, target_count, target_datatype, win); return ret; } void mpif_put_(void *o_addr, int *o_count, MPI_Fint *o_d, int *t_rank, MPI_Aint *t_disp, int *t_count, MPI_Fint *t_d, MPI_Fint *win, int *error) { FUNCTION_ENTRY; MPI_Datatype c_otype = MPI_Type_f2c(*o_d); MPI_Datatype c_ttype = MPI_Type_f2c(*t_d); MPI_Win c_win = MPI_Win_f2c(*win); MPI_Put_prolog(o_addr, *o_count, c_otype, *t_rank, *t_disp, *t_count, c_ttype, c_win); *error = MPI_Put_core(o_addr, *o_count, c_otype, *t_rank, *t_disp, *t_count, c_ttype, c_win); MPI_Put_epilog(o_addr, *o_count, c_otype, *t_rank, *t_disp, *t_count, c_ttype, c_win); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_recv.c000066400000000000000000000045441265506773700221570ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Recv_prolog(void *buf __attribute__((unused)), int count, MPI_Datatype datatype, int source, int tag, MPI_Comm comm, MPI_Status *status __attribute__((unused))) { int size; MPI_Type_size(datatype, &size); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_START_RECV, count*size, source, tag, (app_ptr) comm); } static int MPI_Recv_core(void *buf, int count, MPI_Datatype datatype, int source, int tag, MPI_Comm comm, MPI_Status *status) { return libMPI_Recv(buf, count, datatype, source, tag, comm, status); } static void MPI_Recv_epilog(void *buf __attribute__((unused)), int count, MPI_Datatype datatype, int source, int tag, MPI_Comm comm, MPI_Status *status __attribute__((unused))) { int size; EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_STOP_RECV, count*size, source, tag, (app_ptr)comm); MPI_Type_size(datatype, &size); } /* C function */ int MPI_Recv(void *buf, int count, MPI_Datatype datatype, int source, int tag, MPI_Comm comm, MPI_Status *status) { FUNCTION_ENTRY; MPI_Recv_prolog(buf, count, datatype, source, tag, comm, status); int ret = MPI_Recv_core(buf, count, datatype, source, tag, comm, status); MPI_Recv_epilog(buf, count, datatype, source, tag, comm, status); return ret; } /* fortran function */ void mpif_recv_(void *buf, int *count, MPI_Fint *d, int *src, int *tag, MPI_Fint *c, MPI_Fint *s, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Status c_status; MPI_Recv_prolog(buf, *count, c_type, *src, *tag, c_comm, &c_status); *error = MPI_Recv_core(buf, *count, c_type, *src, *tag, c_comm, &c_status); MPI_Status_c2f(&c_status, s); MPI_Recv_epilog(buf, *count, c_type, *src, *tag, c_comm, &c_status); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_recv_init.c000066400000000000000000000035251265506773700232000ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static int MPI_Recv_init_core(void* buffer, int count, MPI_Datatype type, int src, int tag, MPI_Comm comm, MPI_Request *req) { return libMPI_Recv_init(buffer, count, type, src, tag, comm, req); } static void MPI_Recv_init_epilog(void* buffer, int count, MPI_Datatype type, int src, int tag, MPI_Comm comm, MPI_Fint *req) { int size; MPI_Type_size(type, &size); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_RECV_INIT, (app_ptr)buffer, count*size, src); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_Info, tag, (app_ptr)comm, (app_ptr)req); } int MPI_Recv_init(void* buffer, int count, MPI_Datatype type, int src, int tag, MPI_Comm comm, MPI_Request *req) { FUNCTION_ENTRY; int ret = MPI_Recv_init_core(buffer, count, type, src, tag, comm, req); MPI_Recv_init_epilog(buffer, count, type, src, tag, comm, (MPI_Fint*) req); return ret; } void mpif_recv_init_(void*buffer, int*count, MPI_Fint*type, int*src, int*tag, MPI_Fint*comm, MPI_Fint *req, int*error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*type); MPI_Comm c_comm = MPI_Comm_f2c(*comm); MPI_Request c_req = MPI_Request_f2c(*req); *error = MPI_Recv_init_core(buffer, *count, c_type, *src, *tag, c_comm, &c_req); *req = MPI_Request_c2f(c_req); MPI_Recv_init_epilog(buffer, *count, c_type, *src, *tag, c_comm, req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_reduce.c000066400000000000000000000053521265506773700224650ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Reduce_prolog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype, MPI_Op op __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int len; MPI_Type_size(datatype, &len); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_Reduce, (app_ptr)comm, size, rank); } static int MPI_Reduce_core(CONST void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, int root, MPI_Comm comm) { return libMPI_Reduce(sendbuf, recvbuf, count, datatype, op, root, comm); } static void MPI_Reduce_epilog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype, MPI_Op op __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int len; MPI_Type_size(datatype, &len); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_Reduce, (app_ptr)comm, size, rank); } int MPI_Reduce(CONST void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, int root, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Reduce_prolog(sendbuf, recvbuf, count, datatype, op, root, comm); int ret = MPI_Reduce_core(sendbuf, recvbuf, count, datatype, op, root, comm); MPI_Reduce_epilog(sendbuf, recvbuf, count, datatype, op, root, comm); return ret; } void mpif_reduce_(void *sbuf, void *rbuf, int *count, MPI_Fint *d, MPI_Fint *op, int *root, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Op c_op = MPI_Op_f2c(*op); MPI_Comm c_comm = MPI_Comm_f2c(*c); void *c_sbuf = CHECK_MPI_IN_PLACE(sbuf); void *c_rbuf = CHECK_MPI_IN_PLACE(rbuf); MPI_Reduce_prolog(c_sbuf, c_rbuf, *count, c_type, c_op, *root, c_comm); *error = MPI_Reduce_core(c_sbuf, c_rbuf, *count, c_type, c_op, *root, c_comm); MPI_Reduce_epilog(c_sbuf, c_rbuf, *count, c_type, c_op, *root, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_reduce_scatter.c000066400000000000000000000054661265506773700242200ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Reduce_scatter_prolog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), CONST int *recvcnts __attribute__((unused)), MPI_Datatype datatype, MPI_Op op __attribute__((unused)), MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int len; MPI_Type_size(datatype, &len); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_Reduce_scatter, (app_ptr)comm, size, rank); } static int MPI_Reduce_scatter_core(CONST void *sendbuf, void *recvbuf, CONST int *recvcnts, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm) { return libMPI_Reduce_scatter(sendbuf, recvbuf, recvcnts, datatype, op, comm); } static void MPI_Reduce_scatter_epilog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), CONST int *recvcnts __attribute__((unused)), MPI_Datatype datatype, MPI_Op op __attribute__((unused)), MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int len; MPI_Type_size(datatype, &len); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_Reduce_scatter, (app_ptr)comm, size, rank); } int MPI_Reduce_scatter(CONST void *sendbuf, void *recvbuf, CONST int *recvcnts, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Reduce_scatter_prolog(sendbuf, recvbuf, recvcnts, datatype, op, comm); int ret = MPI_Reduce_scatter_core(sendbuf, recvbuf, recvcnts, datatype, op, comm); MPI_Reduce_scatter_epilog(sendbuf, recvbuf, recvcnts, datatype, op, comm); return ret; } void mpif_reduce_scatter_(void *sbuf, void *rbuf, int *rcount, MPI_Fint *d, MPI_Fint *op, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Op c_op = MPI_Op_f2c(*op); MPI_Comm c_comm = MPI_Comm_f2c(*c); void *c_sbuf = CHECK_MPI_IN_PLACE(sbuf); void *c_rbuf = CHECK_MPI_IN_PLACE(rbuf); MPI_Reduce_scatter_prolog(c_sbuf, c_rbuf, rcount, c_type, c_op, c_comm); *error = MPI_Reduce_scatter_core(c_sbuf, c_rbuf, rcount, c_type, c_op, c_comm); MPI_Reduce_scatter_epilog(c_sbuf, c_rbuf, rcount, c_type, c_op, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_rsend.c000066400000000000000000000037651265506773700223370ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Rsend_prolog (CONST void* buf __attribute__((unused)), int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { int size; MPI_Type_size(datatype, &size); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_START_RSEND, count*size, dest, tag, (app_ptr)comm); } static int MPI_Rsend_core(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { return libMPI_Rsend(buf, count, datatype, dest, tag, comm); } static void MPI_Rsend_epilog (CONST void* buf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), int dest, int tag, MPI_Comm comm) { EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_RSEND, dest, tag, (app_ptr)comm); } int MPI_Rsend(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Rsend_prolog(buf, count, datatype, dest, tag, comm); int ret = MPI_Rsend_core(buf, count, datatype, dest, tag, comm); MPI_Rsend_epilog(buf, count, datatype, dest, tag, comm); return ret; } void mpif_rsend_(void *buf, int *count, MPI_Fint *d, int *dest, int *tag, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Rsend_prolog(buf, *count, c_type, *dest, *tag, c_comm); *error = MPI_Rsend_core(buf, *count, c_type, *dest, *tag, c_comm); MPI_Rsend_epilog(buf, *count, c_type, *dest, *tag, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_rsend_init.c000066400000000000000000000037031265506773700233520ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static int MPI_Rsend_init_core(CONST void* buffer, int count, MPI_Datatype type, int dest, int tag, MPI_Comm comm, MPI_Request *req) { return libMPI_Rsend_init(buffer, count, type, dest, tag, comm, req); } static void MPI_Rsend_init_epilog(CONST void* buffer, int count, MPI_Datatype type, int dest, int tag, MPI_Comm comm, MPI_Fint *req) { int size; MPI_Type_size(type, &size); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_RSEND_INIT, (app_ptr)buffer, count*size, dest); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_Info, tag, (app_ptr)comm, (app_ptr)req); } int MPI_Rsend_init(CONST void* buffer, int count, MPI_Datatype type, int dest, int tag, MPI_Comm comm, MPI_Request *req) { FUNCTION_ENTRY; int ret = MPI_Rsend_init_core(buffer, count, type, dest, tag, comm, req); MPI_Rsend_init_epilog(buffer, count, type, dest, tag, comm, (MPI_Fint*) req); return ret; } void mpif_rsend_init_(void*buffer, int*count, MPI_Fint*type, int*dest, int*tag, MPI_Fint*comm, MPI_Fint *req, int*error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*type); MPI_Comm c_comm = MPI_Comm_f2c(*comm); MPI_Request c_req = MPI_Request_f2c(*req); *error = MPI_Rsend_init_core(buffer, *count, c_type, *dest, *tag, c_comm, &c_req); *req = MPI_Request_c2f(c_req); MPI_Rsend_init_epilog(buffer, *count, c_type, *dest, *tag, c_comm, req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_scan.c000066400000000000000000000046231265506773700221420ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Scan_prolog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype, MPI_Op op __attribute__((unused)), MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int len; MPI_Type_size(datatype, &len); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_Scan, (app_ptr)comm, size, rank); } static int MPI_Scan_core(CONST void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm) { return libMPI_Scan(sendbuf, recvbuf, count, datatype, op, comm); } static void MPI_Scan_epilog (CONST void *sendbuf __attribute__((unused)), void *recvbuf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype, MPI_Op op __attribute__((unused)), MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); int len; MPI_Type_size(datatype, &len); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_Scan, (app_ptr)comm, size, rank); } int MPI_Scan(CONST void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Scan_prolog(sendbuf, recvbuf, count, datatype, op, comm); int ret = MPI_Scan_core(sendbuf, recvbuf, count, datatype, op, comm); MPI_Scan_epilog(sendbuf, recvbuf, count, datatype, op, comm); return ret; } void mpif_scan_(void *sbuf, void *rbuf, int *count, MPI_Fint *d, MPI_Fint *op, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Op c_op = MPI_Op_f2c(*op); MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Scan_prolog(sbuf, rbuf, *count, c_type, c_op, c_comm); *error = MPI_Scan_core(sbuf, rbuf, *count, c_type, c_op, c_comm); MPI_Scan_epilog(sbuf, rbuf, *count, c_type, c_op, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_scatter.c000066400000000000000000000063461265506773700226670ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Scatter_prolog(CONST void *sendbuf __attribute__((unused)), int sendcnt, MPI_Datatype sendtype, void *recvbuf __attribute__((unused)), int recvcnt __attribute__((unused)), MPI_Datatype recvtype, int root, MPI_Comm comm ) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_Scatter, (app_ptr)comm, size, rank); } static int MPI_Scatter_core(CONST void *sendbuf, int sendcnt, MPI_Datatype sendtype, void *recvbuf, int recvcnt, MPI_Datatype recvtype, int root, MPI_Comm comm) { return libMPI_Scatter(sendbuf, sendcnt, sendtype, recvbuf, recvcnt, recvtype, root, comm); } static void MPI_Scatter_epilog(CONST void *sendbuf __attribute__((unused)), int sendcnt __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), int recvcnt __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_Scatter, (app_ptr)comm, size, rank); } int MPI_Scatter(CONST void *sendbuf, int sendcnt, MPI_Datatype sendtype, void *recvbuf, int recvcnt, MPI_Datatype recvtype, int root, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Scatter_prolog(sendbuf, sendcnt, sendtype, recvbuf, recvcnt, recvtype, root, comm); int ret = MPI_Scatter_core(sendbuf, sendcnt, sendtype, recvbuf, recvcnt, recvtype, root, comm); MPI_Scatter_epilog(sendbuf, sendcnt, sendtype, recvbuf, recvcnt, recvtype, root, comm); return ret; } void mpif_scatter_(void *sbuf, int *scount, MPI_Fint *sd, void *rbuf, int *rcount, MPI_Fint *rd, int *root, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); void *c_sbuf = CHECK_MPI_IN_PLACE(sbuf); void *c_rbuf = CHECK_MPI_IN_PLACE(rbuf); MPI_Scatter_prolog(c_sbuf, *scount, c_stype, c_rbuf, *rcount, c_rtype, *root, c_comm); *error = MPI_Scatter_core(c_sbuf, *scount, c_stype, c_rbuf, *rcount, c_rtype, *root, c_comm); MPI_Scatter_epilog(c_sbuf, *scount, c_stype, c_rbuf, *rcount, c_rtype, *root, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_scatterv.c000066400000000000000000000064661265506773700230600ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Scatterv_prolog(CONST void *sendbuf __attribute__((unused)), CONST int *sendcnts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), int recvcnt, MPI_Datatype recvtype, int root, MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_START_Scatterv, (app_ptr)comm, size, rank); } static int MPI_Scatterv_core(CONST void *sendbuf, CONST int *sendcnts, CONST int *displs, MPI_Datatype sendtype, void *recvbuf, int recvcnt, MPI_Datatype recvtype, int root, MPI_Comm comm) { return libMPI_Scatterv(sendbuf, sendcnts, displs, sendtype, recvbuf, recvcnt, recvtype, root, comm); } static void MPI_Scatterv_epilog(CONST void *sendbuf __attribute__((unused)), CONST int *sendcnts __attribute__((unused)), CONST int *displs __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), void *recvbuf __attribute__((unused)), int recvcnt __attribute__((unused)), MPI_Datatype recvtype __attribute__((unused)), int root __attribute__((unused)), MPI_Comm comm) { int rank = -1; int size = -1; libMPI_Comm_size(comm, &size); libMPI_Comm_rank(comm, &rank); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_Scatterv, (app_ptr)comm, size, rank); } int MPI_Scatterv(CONST void *sendbuf, CONST int *sendcnts, CONST int *displs, MPI_Datatype sendtype, void *recvbuf, int recvcnt, MPI_Datatype recvtype, int root, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Scatterv_prolog(sendbuf, sendcnts, displs, sendtype, recvbuf, recvcnt, recvtype, root, comm); int ret = MPI_Scatterv_core(sendbuf, sendcnts, displs, sendtype, recvbuf, recvcnt, recvtype, root, comm); MPI_Scatterv_epilog(sendbuf, sendcnts, displs, sendtype, recvbuf, recvcnt, recvtype, root, comm); return ret; } void mpif_scatterv_(void *sbuf, int *scount, int *displs, MPI_Fint *sd, void *rbuf, int *rcount, MPI_Fint *rd, int *root, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Datatype c_stype = MPI_Type_f2c(*sd); MPI_Datatype c_rtype = MPI_Type_f2c(*rd); MPI_Comm c_comm = MPI_Comm_f2c(*c); void *c_sbuf = CHECK_MPI_IN_PLACE(sbuf); void *c_rbuf = CHECK_MPI_IN_PLACE(rbuf); MPI_Scatterv_prolog(c_sbuf, scount, displs, c_stype, c_rbuf, *rcount, c_rtype, *root, c_comm); *error = MPI_Scatterv_core(c_sbuf, scount, displs, c_stype, c_rbuf, *rcount, c_rtype, *root, c_comm); MPI_Scatterv_epilog(c_sbuf, scount, displs, c_stype, c_rbuf, *rcount, c_rtype, *root, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_send.c000066400000000000000000000041121265506773700221400ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Send_prolog(CONST void *buf __attribute__((unused)), int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { int size; /* retrieve the size of the datatype so that we can compute the message length */ MPI_Type_size(datatype, &size); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_START_SEND, count*size, dest, tag, (app_ptr)comm); } static int MPI_Send_core(CONST void *buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { return libMPI_Send(buf, count, datatype, dest, tag, comm); } static void MPI_Send_epilog(CONST void *buf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), int dest, int tag, MPI_Comm comm) { EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_SEND, dest, tag, (app_ptr)comm); } /* C function */ int MPI_Send(CONST void *buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Send_prolog(buf, count, datatype, dest, tag, comm); int ret = MPI_Send_core(buf, count, datatype, dest, tag, comm); MPI_Send_epilog(buf, count, datatype, dest, tag, comm); return ret; } /* fortran function */ void mpif_send_(void* buf, int *count, MPI_Fint *d, int *dest, int *tag, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Send_prolog(buf, *count, c_type, *dest, *tag, c_comm); *error = MPI_Send_core(buf, *count, c_type, *dest, *tag, c_comm); MPI_Send_epilog(buf, *count, c_type, *dest, *tag, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_send_init.c000066400000000000000000000041071265506773700231670ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static int MPI_Send_init_core(CONST void* buffer, int count, MPI_Datatype type, int dest, int tag, MPI_Comm comm, MPI_Request *req) { return libMPI_Send_init(buffer, count, type, dest, tag, comm, req); } static void MPI_Send_init_epilog(CONST void* buffer, int count, MPI_Datatype type, int dest, int tag, MPI_Comm comm, MPI_Fint *req) { int size; MPI_Type_size(type, &size); /* We need to record the events after mpi_send_init since * it may modify the request. * If we don't, req may have an invalid value. */ EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_SEND_INIT, (app_ptr)buffer, count*size, dest); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_Info, tag, (app_ptr)comm, (app_ptr)req); } int MPI_Send_init(CONST void* buffer, int count, MPI_Datatype type, int dest, int tag, MPI_Comm comm, MPI_Request *req) { FUNCTION_ENTRY; int ret = MPI_Send_init_core(buffer, count, type, dest, tag, comm, req); MPI_Send_init_epilog(buffer, count, type, dest, tag, comm, (MPI_Fint*) req); return ret; } void mpif_send_init_(void*buffer, int*count, MPI_Fint*type, int*dest, int*tag, MPI_Fint*comm, MPI_Fint *req, int*error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*type); MPI_Comm c_comm = MPI_Comm_f2c(*comm); MPI_Request c_req = MPI_Request_f2c(*req); *error = MPI_Send_init_core(buffer, *count, c_type, *dest, *tag, c_comm, &c_req); *req = MPI_Request_c2f(c_req); MPI_Send_init_epilog(buffer, *count, c_type, *dest, *tag, c_comm, req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_sendrecv.c000066400000000000000000000077211265506773700230310ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Sendrecv_prolog (CONST void *sendbuf __attribute__((unused)), int sendcount, MPI_Datatype sendtype, int dest, int sendtag, void *recvbuf __attribute__((unused)), int recvcount, MPI_Datatype recvtype, int src, int recvtag, MPI_Comm comm, MPI_Status *status __attribute__((unused))) { int ssize, rsize; MPI_Type_size(sendtype, &ssize); MPI_Type_size(recvtype, &rsize); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_START_SENDRECV, recvcount * rsize, src, recvtag, (app_ptr)comm); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_Info, sendcount * ssize, dest, sendtag); } static int MPI_Sendrecv_core(CONST void *sendbuf, int sendcount, MPI_Datatype sendtype, int dest, int sendtag, void *recvbuf, int recvcount, MPI_Datatype recvtype, int src, int recvtag, MPI_Comm comm, MPI_Status *status) { return libMPI_Sendrecv(sendbuf, sendcount, sendtype, dest, sendtag, recvbuf, recvcount, recvtype, src, recvtag, comm, status); } static void MPI_Sendrecv_epilog (CONST void *sendbuf __attribute__((unused)), int sendcount __attribute__((unused)), MPI_Datatype sendtype __attribute__((unused)), int dest __attribute__((unused)), int sendtag __attribute__((unused)), void *recvbuf __attribute__((unused)), int recvcount, MPI_Datatype recvtype, int src, int recvtag, MPI_Comm comm, MPI_Status *status __attribute__((unused))) { int ssize, rsize; MPI_Type_size(sendtype, &ssize); MPI_Type_size(recvtype, &rsize); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_STOP_SENDRECV, recvcount * rsize, src, recvtag, (app_ptr)comm); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_Info, sendcount * ssize, dest, sendtag); } int MPI_Sendrecv(CONST void *sendbuf, int sendcount, MPI_Datatype sendtype, int dest, int sendtag, void *recvbuf, int recvcount, MPI_Datatype recvtype, int src, int recvtag, MPI_Comm comm, MPI_Status *status) { FUNCTION_ENTRY; MPI_Sendrecv_prolog(sendbuf, sendcount, sendtype, dest, sendtag, recvbuf, recvcount, recvtype, src, recvtag, comm, status); int ret = MPI_Sendrecv_core(sendbuf, sendcount, sendtype, dest, sendtag, recvbuf, recvcount, recvtype, src, recvtag, comm, status); MPI_Sendrecv_epilog(sendbuf, sendcount, sendtype, dest, sendtag, recvbuf, recvcount, recvtype, src, recvtag, comm, status); return ret; } void mpif_sendrecv_(void *sendbuf, int *sendcount, MPI_Fint *sendtype, int *dest, int *sendtag, void *recvbuf, int *recvcount, MPI_Fint *recvtype, int *src, int *recvtag, MPI_Fint *comm, MPI_Status *status, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*comm); MPI_Datatype c_stype = MPI_Type_f2c(*sendtype); MPI_Datatype c_rtype = MPI_Type_f2c(*recvtype); MPI_Sendrecv_prolog(sendbuf, *sendcount, c_stype, *dest, *sendtag, recvbuf, *recvcount, c_rtype, *src, *recvtag, c_comm, status); *error = MPI_Sendrecv_core(sendbuf, *sendcount, c_stype, *dest, *sendtag, recvbuf, *recvcount, c_rtype, *src, *recvtag, c_comm, status); MPI_Sendrecv_epilog(sendbuf, *sendcount, c_stype, *dest, *sendtag, recvbuf, *recvcount, c_rtype, *src, *recvtag, c_comm, status); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_sendrecv_replace.c000066400000000000000000000062741265506773700245260ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Sendrecv_replace_prolog (void* buf __attribute__((unused)), int count, MPI_Datatype type, int dest, int sendtag, int src, int recvtag, MPI_Comm comm, MPI_Status *status __attribute__((unused))) { /* same as mpi_sendrecv but the same buffer is used for sending *and* receiving */ int size; MPI_Type_size(type, &size); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_START_SENDRECV_REPLACE, count * size, src, recvtag, (app_ptr)comm); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_Info, count * size, dest, sendtag); } static int MPI_Sendrecv_replace_core(void* buf, int count, MPI_Datatype type, int dest, int sendtag, int src, int recvtag, MPI_Comm comm, MPI_Status *status) { return libMPI_Sendrecv_replace(buf, count, type, dest, sendtag, src, recvtag, comm, status); } static void MPI_Sendrecv_replace_epilog (void* buf __attribute__((unused)), int count, MPI_Datatype type, int dest, int sendtag, int src, int recvtag, MPI_Comm comm, MPI_Status *status __attribute__((unused))) { int size; MPI_Type_size(type, &size); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_STOP_SENDRECV_REPLACE, count * size, dest, sendtag, (app_ptr)comm); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_Info, count * size, src, recvtag); } int MPI_Sendrecv_replace(void* buf, int count, MPI_Datatype type, int dest, int sendtag, int src, int recvtag, MPI_Comm comm, MPI_Status *status) { FUNCTION_ENTRY; MPI_Sendrecv_replace_prolog(buf, count, type, dest, sendtag, src, recvtag, comm, status); int ret = MPI_Sendrecv_replace_core(buf, count, type, dest, sendtag, src, recvtag, comm, status); MPI_Sendrecv_replace_epilog(buf, count, type, dest, sendtag, src, recvtag, comm, status); return ret; } void mpif_sendrecv_replace_(void* buf, int *count, MPI_Fint *type, int *dest, int *sendtag, int *src, int *recvtag, MPI_Fint *comm, MPI_Status *status, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*comm); MPI_Datatype c_type = MPI_Type_f2c(*type); MPI_Sendrecv_replace_prolog(buf, *count, c_type, *dest, *sendtag, *src, *recvtag, c_comm, status); *error = MPI_Sendrecv_replace_core(buf, *count, c_type, *dest, *sendtag, *src, *recvtag, c_comm, status); MPI_Sendrecv_replace_epilog(buf, *count, c_type, *dest, *sendtag, *src, *recvtag, c_comm, status); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_ssend.c000066400000000000000000000037711265506773700223350ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Ssend_prolog (CONST void* buf __attribute__((unused)), int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { int size; MPI_Type_size(datatype, &size); EZTRACE_EVENT_PACKED_4(EZTRACE_MPI_START_SSEND, count*size, dest, tag, (app_ptr)comm); } static int MPI_Ssend_core(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { return libMPI_Ssend(buf, count, datatype, dest, tag, comm); } static void MPI_Ssend_epilog (CONST void* buf __attribute__((unused)), int count __attribute__((unused)), MPI_Datatype datatype __attribute__((unused)), int dest, int tag, MPI_Comm comm) { EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_STOP_SSEND, dest, tag, (app_ptr)comm); } int MPI_Ssend(CONST void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) { FUNCTION_ENTRY; MPI_Ssend_prolog(buf, count, datatype, dest, tag, comm); int ret = MPI_Ssend_core(buf, count, datatype, dest, tag, comm); MPI_Ssend_epilog(buf, count, datatype, dest, tag, comm); return ret; } void mpif_ssend_(void *buf, int *count, MPI_Fint *d, int *dest, int *tag, MPI_Fint *c, int *error) { FUNCTION_ENTRY; MPI_Comm c_comm = MPI_Comm_f2c(*c); MPI_Datatype c_type = MPI_Type_f2c(*d); MPI_Ssend_prolog(buf, *count, c_type, *dest, *tag, c_comm); *error = MPI_Ssend_core(buf, *count, c_type, *dest, *tag, c_comm); MPI_Ssend_epilog(buf, *count, c_type, *dest, *tag, c_comm); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_ssend_init.c000066400000000000000000000036721265506773700233600ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static int MPI_Ssend_init_core(CONST void* buffer, int count, MPI_Datatype type, int dest, int tag, MPI_Comm comm, MPI_Request *req) { return libMPI_Ssend_init(buffer, count, type, dest, tag, comm, req); } static void MPI_Ssend_init_epilog(CONST void* buffer, int count, MPI_Datatype type, int dest, int tag, MPI_Comm comm, MPI_Fint *req) { int size; MPI_Type_size(type, &size); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_SSEND_INIT, buffer, count*size, dest); EZTRACE_EVENT_PACKED_3(EZTRACE_MPI_Info, tag, (app_ptr)comm, (app_ptr)req); } int MPI_Ssend_init(CONST void* buffer, int count, MPI_Datatype type, int dest, int tag, MPI_Comm comm, MPI_Request *req) { FUNCTION_ENTRY; int ret = MPI_Ssend_init_core(buffer, count, type, dest, tag, comm, req); MPI_Ssend_init_epilog(buffer, count, type, dest, tag, comm, (MPI_Fint*) req); return ret; } void mpif_ssend_init_(void*buffer, int*count, MPI_Fint*type, int*dest, int*tag, MPI_Fint*comm, MPI_Fint *req, int*error) { FUNCTION_ENTRY; MPI_Datatype c_type = MPI_Type_f2c(*type); MPI_Comm c_comm = MPI_Comm_f2c(*comm); MPI_Request c_req = MPI_Request_f2c(*req); *error = MPI_Ssend_init_core(buffer, *count, c_type, *dest, *tag, c_comm, &c_req); *req = MPI_Request_c2f(c_req); MPI_Ssend_init_epilog(buffer, *count, c_type, *dest, *tag, c_comm, req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_start.c000066400000000000000000000017241265506773700223520ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Start_prolog(MPI_Fint *req) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_START, (app_ptr)req); } static int MPI_Start_core(MPI_Request *req) { return libMPI_Start(req); } int MPI_Start(MPI_Request *req) { FUNCTION_ENTRY; MPI_Start_prolog((MPI_Fint*) req); int ret = MPI_Start_core(req); return ret; } void mpif_start_(MPI_Fint *req, int*error) { FUNCTION_ENTRY; MPI_Request c_req = MPI_Request_f2c(*req); MPI_Start_prolog(req); *error = MPI_Start_core(&c_req); *req = MPI_Request_c2f(c_req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_startall.c000066400000000000000000000027121265506773700230410ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Startall_prolog(int count, void*req, size_t size) { int i; for (i = 0; i < count; i++) /* we can't use &req[i] here since req may be an array of MPI_Request or MPI_Fint * (which may have different size) */ EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_START, (app_ptr)((void*)req + (i*size))); } static int MPI_Startall_core(int count, MPI_Request *req) { return libMPI_Startall(count, req); } int MPI_Startall(int count, MPI_Request *req) { FUNCTION_ENTRY; MPI_Startall_prolog(count, req, sizeof(MPI_Request)); int ret = MPI_Startall_core(count, req); return ret; } void mpif_startall_(int*count, MPI_Fint *reqs, int*error) { FUNCTION_ENTRY; int i; ALLOCATE_ITEMS(MPI_Request, *count, c_req, p_req); for (i = 0; i < *count; i++) p_req[i] = MPI_Request_f2c(reqs[i]); MPI_Startall_prolog(*count, reqs, sizeof(MPI_Fint)); *error = MPI_Startall_core(*count, p_req); for (i = 0; i < *count; i++) reqs[i] = MPI_Request_c2f(p_req[i]); FREE_ITEMS(*count, p_req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_test.c000066400000000000000000000023371265506773700221750ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static int MPI_Test_core(MPI_Request *req, int *a, MPI_Status *s) { return libMPI_Test(req, a, s); } static void MPI_Test_epilog(MPI_Fint *req, int *a, MPI_Status *s __attribute__((unused))) { if (*a) EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_TEST_SUCCESS, (app_ptr)req); } int MPI_Test(MPI_Request *req, int *a, MPI_Status *s) { FUNCTION_ENTRY; int res = MPI_Test_core(req, a, s); MPI_Test_epilog((MPI_Fint*) req, a, s); return res; } void mpif_test_(MPI_Fint *r, int *f, MPI_Fint *s, int *error) { FUNCTION_ENTRY; MPI_Request c_req = MPI_Request_f2c(*r); MPI_Status c_status; *error = MPI_Test_core(&c_req, f, &c_status); *r = MPI_Request_c2f(c_req); if (*f) { MPI_Status_c2f(&c_status, s); } MPI_Test_epilog(r, f, &c_status); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_testall.c000066400000000000000000000030611265506773700226610ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static int MPI_Testall_core(int count, MPI_Request *reqs, int *flag, MPI_Status *s) { return libMPI_Testall(count, reqs, flag, s); } static void MPI_Testall_epilog(int count, MPI_Fint *reqs, int *flag, MPI_Status *s __attribute__((unused)), size_t size) { if (*flag) { int i; for (i = 0; i < count; i++) EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_TEST_SUCCESS, (app_ptr)((void*)reqs + (i*size))); } } int MPI_Testall(int count, MPI_Request *reqs, int *flag, MPI_Status *s) { FUNCTION_ENTRY; int ret = MPI_Testall_core(count, reqs, flag, s); MPI_Testall_epilog(count, (void*)reqs, flag, s, sizeof(MPI_Request)); return ret; } void mpif_testall_(int *count, MPI_Fint *r, int *index, MPI_Status *s, int *error) { FUNCTION_ENTRY; int i; ALLOCATE_ITEMS(MPI_Request, *count, c_req, p_req); for (i = 0; i < *count; i++) p_req[i] = MPI_Request_f2c(r[i]); *error = MPI_Testall_core(*count, p_req, index, s); for (i = 0; i < *count; i++) r[i] = MPI_Request_c2f(p_req[i]); MPI_Testall_epilog(*count, r, index, s, sizeof(MPI_Fint)); FREE_ITEMS(*count, p_req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_testany.c000066400000000000000000000033671265506773700227110ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static int MPI_Testany_core(int count, MPI_Request *reqs, int *index, int *flag, MPI_Status *status) { return libMPI_Testany(count, reqs, index, flag, status); } static void MPI_Testany_epilog(int count __attribute__((unused)), void *reqs, int *index, int *flag, MPI_Status *status __attribute__((unused)), size_t size) { if (*flag) EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_TEST_SUCCESS, (app_ptr)((void*)reqs + ((*index)*size))); } int MPI_Testany(int count, MPI_Request *reqs, int *index, int *flag, MPI_Status *status) { FUNCTION_ENTRY; int ret = MPI_Testany_core(count, reqs, index, flag, status); MPI_Testany_epilog(count, reqs, index, flag, status, sizeof(MPI_Request)); return ret; } void mpif_testany_(int *count, MPI_Fint *r, int *index, int *flag, MPI_Status *s, int *error) { FUNCTION_ENTRY; int i; ALLOCATE_ITEMS(MPI_Request, *count, c_req, p_req); for (i = 0; i < *count; i++) p_req[i] = MPI_Request_f2c(r[i]); *error = MPI_Testany_core(*count, p_req, index, flag, s); for (i = 0; i < *count; i++) r[i] = MPI_Request_c2f(p_req[i]); MPI_Testany_epilog(*count, r, index, flag, s, sizeof(MPI_Fint)); FREE_ITEMS(*count, p_req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_testsome.c000066400000000000000000000036761265506773700230700ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static int MPI_Testsome_core(int incount, MPI_Request *reqs, int *outcount, int *indexes, MPI_Status *statuses) { return libMPI_Testsome(incount, reqs, outcount, indexes, statuses); } static void MPI_Testsome_epilog(int incount __attribute__((unused)), void *reqs, int *outcount, int *indexes __attribute__((unused)), MPI_Status *statuses __attribute__((unused)), size_t size) { if (*outcount) { int i; for (i = 0; i < *outcount; i++) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_TEST_SUCCESS, (app_ptr) ((void*)reqs + (i*size))); } } } int MPI_Testsome(int incount, MPI_Request *reqs, int *outcount, int *indexes, MPI_Status *statuses) { FUNCTION_ENTRY; int res = MPI_Testsome_core(incount, reqs, outcount, indexes, statuses); MPI_Testsome_epilog(incount, reqs, outcount, indexes, statuses, sizeof(MPI_Request)); return res; } void mpif_testsome_(int *ic, MPI_Fint *r, int* oc, int* indexes, MPI_Status *s, int *error) { FUNCTION_ENTRY; int i; ALLOCATE_ITEMS(MPI_Request, *ic, c_req, p_req); for (i = 0; i < *ic; i++) p_req[i] = MPI_Request_f2c(r[i]); *error = MPI_Testsome_core(*ic, p_req, oc, indexes, s); for (i = 0; i < *ic; i++) r[i] = MPI_Request_c2f(p_req[i]); MPI_Testsome_epilog(*ic, r, oc, indexes, s, sizeof(MPI_Fint)); FREE_ITEMS(*ic, p_req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_wait.c000066400000000000000000000025421265506773700221600ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Wait_prolog(MPI_Fint *req, MPI_Status *s __attribute__((unused))) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_START_WAIT, (app_ptr)req); } static int MPI_Wait_core(MPI_Request *req, MPI_Status *s) { return libMPI_Wait(req, s); } static void MPI_Wait_epilog(MPI_Fint *req, MPI_Status *s __attribute__((unused))) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_WAIT, (app_ptr)req); } int MPI_Wait(MPI_Request *req, MPI_Status *s) { FUNCTION_ENTRY; MPI_Wait_prolog((MPI_Fint*) req, s); int ret = MPI_Wait_core(req, s); MPI_Wait_epilog((MPI_Fint*) req, s); return ret; } void mpif_wait_(MPI_Fint *r, MPI_Fint *s, int *error) { FUNCTION_ENTRY; MPI_Request c_req = MPI_Request_f2c(*r); MPI_Status c_status; MPI_Wait_prolog(r, &c_status); *error = MPI_Wait_core(&c_req, &c_status); MPI_Status_c2f(&c_status, s); MPI_Wait_epilog(r, &c_status); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_waitall.c000066400000000000000000000051201265506773700226440ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Waitall_prolog(int count, void*req, MPI_Status *s __attribute__((unused)), size_t size) { int i; /* we have to iterate over the array of requests so that eztrace_convert * know which requests the application is waiting for */ EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_START_WAITALL, count); for (i = 0; i < count; i++) { /* we can't use &req[i] here since req may be an array of MPI_Request or MPI_Fint * (which may have different size) */ EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_Info, (app_ptr)((void*)req + (i*size))); } } static int MPI_Waitall_core(int count, MPI_Request *req, MPI_Status *s) { return libMPI_Waitall(count, req, s); } static void MPI_Waitall_epilog(int count, void*req, MPI_Status *s __attribute__((unused)), size_t size) { int i; EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_STOP_WAITALL, count); for (i = 0; i < count; i++) { /* we can't use &req[i] here since req may be an array of MPI_Request or MPI_Fint * (which may have different size) */ EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_Info, (app_ptr)((void*)req + (i*size))); } } int MPI_Waitall(int count, MPI_Request *req, MPI_Status *s) { FUNCTION_ENTRY; MPI_Waitall_prolog(count, req, s, sizeof(MPI_Request)); int ret = MPI_Waitall_core(count, req, s); MPI_Waitall_epilog(count, req, s, sizeof(MPI_Request)); return ret; } void mpif_waitall_(int *c, MPI_Fint *r, MPI_Status *s, int *error) { FUNCTION_ENTRY; int i; MPI_Waitall_prolog(*c, r, s, sizeof(MPI_Fint)); /* allocate a MPI_Request array and convert all the fortran requests * into C requests */ ALLOCATE_ITEMS(MPI_Request, *c, c_req, p_req); for (i = 0; i < *c; i++) p_req[i] = MPI_Request_f2c(r[i]); /* call the C version of MPI_Wait */ *error = MPI_Waitall_core(*c, p_req, s); /* Since the requests may have been modified by MPI_Waitall, * we need to convert them back to Fortran */ for (i = 0; i < *c; i++) r[i] = MPI_Request_c2f(p_req[i]); MPI_Waitall_epilog(*c, r, s, sizeof(MPI_Fint)); FREE_ITEMS(*c, p_req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_waitany.c000066400000000000000000000047071265506773700226750ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" static void MPI_Waitany_prolog(int count, void*reqs, int *index __attribute__((unused)), MPI_Status *status __attribute__((unused)), size_t size) { EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_START_WAITANY, count); int i; for (i = 0; i < count; i++) { /* we can't use &req[i] here since req may be an array of MPI_Request or MPI_Fint * (which may have different size) */ EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_Info, (app_ptr)((void*)reqs+(i*size))); } } static int MPI_Waitany_core(int count, MPI_Request *reqs, int *index, MPI_Status *status) { return libMPI_Waitany(count, reqs, index, status); } static void MPI_Waitany_epilog(int count, void *reqs, int *index, MPI_Status *status __attribute__((unused)), size_t size) { int i; EZTRACE_EVENT_PACKED_2(EZTRACE_MPI_STOP_WAITANY, count, *index); for (i = 0; i < count; i++) { /* we can't use &req[i] here since req may be an array of MPI_Request or MPI_Fint * (which may have different size) */ EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_Info, (app_ptr)((void*)reqs+(i*size))); } } int MPI_Waitany(int count, MPI_Request *reqs, int *index, MPI_Status *status) { FUNCTION_ENTRY; MPI_Waitany_prolog(count, reqs, index, status, sizeof(MPI_Request)); int ret = MPI_Waitany_core(count, reqs, index, status); MPI_Waitany_epilog(count, reqs, index, status, sizeof(MPI_Request)); return ret; } void mpif_waitany_(int *c, MPI_Fint *r, MPI_Status *s, int *index, int *error) { FUNCTION_ENTRY; int i; MPI_Waitany_prolog(*c, r, index, s, sizeof(MPI_Fint)); ALLOCATE_ITEMS(MPI_Request, *c, c_req, p_req); for (i = 0; i < *c; i++) p_req[i] = MPI_Request_f2c(r[i]); *error = MPI_Waitany_core(*c, p_req, index, s); for (i = 0; i < *c; i++) r[i] = MPI_Request_c2f(p_req[i]); MPI_Waitany_epilog(*c, r, index, s, sizeof(MPI_Fint)); FREE_ITEMS(*c, p_req); } eztrace-1.1-2/src/modules/mpi/mpi_funcs/mpi_waitsome.c000066400000000000000000000062521265506773700230460ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "mpi.h" #include "mpi_eztrace.h" #include "mpi_ev_codes.h" #include "eztrace.h" /* todo: implement this function ! */ static void MPI_Waitsome_prolog( int incount, void *reqs, int *outcount __attribute__((unused)), int *array_of_indices __attribute__((unused)), MPI_Status *array_of_statuses __attribute__((unused)), size_t size) { int i; for (i = 0; i < incount; i++) { /* we can't use &reqs[i] here since req may be an array of MPI_Request or MPI_Fint * (which may have different size) */ EZTRACE_EVENT_PACKED_1(EZTRACE_MPI_START_WAIT, (app_ptr)((void*)reqs + (i*size))); } } static int MPI_Waitsome_core(int incount, MPI_Request *reqs, int *outcount, int *array_of_indices, MPI_Status *array_of_statuses) { return libMPI_Waitsome(incount, reqs, outcount, array_of_indices, array_of_statuses); } static void MPI_Waitsome_epilog( int incount __attribute__((unused)), void *reqs, int *outcount, int *array_of_indices, MPI_Status *array_of_statuses __attribute__((unused)), size_t size) { int i, j = 0; /* create a MPI_STOP_WAIT event for all successfull requests */ for (i=0; i&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @OPENMP_FOUND_TRUE@am__append_1 = -DOPENMP_FOUND subdir = src/modules/omp ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(noinst_HEADERS) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = eztrace_cc CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(libdir)" "$(DESTDIR)$(bindir)" LTLIBRARIES = $(lib_LTLIBRARIES) libeztrace_autostart_omp_la_DEPENDENCIES = am_libeztrace_autostart_omp_la_OBJECTS = \ libeztrace_autostart_omp_la-gomp.lo libeztrace_autostart_omp_la_OBJECTS = \ $(am_libeztrace_autostart_omp_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libeztrace_autostart_omp_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(libeztrace_autostart_omp_la_CFLAGS) $(CFLAGS) \ $(libeztrace_autostart_omp_la_LDFLAGS) $(LDFLAGS) -o $@ am__DEPENDENCIES_1 = am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) am_libeztrace_convert_omp_la_OBJECTS = \ libeztrace_convert_omp_la-eztrace_convert_gomp.lo libeztrace_convert_omp_la_OBJECTS = \ $(am_libeztrace_convert_omp_la_OBJECTS) libeztrace_convert_omp_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(libeztrace_convert_omp_la_CFLAGS) $(CFLAGS) \ $(libeztrace_convert_omp_la_LDFLAGS) $(LDFLAGS) -o $@ libeztrace_omp_la_DEPENDENCIES = $(am__DEPENDENCIES_2) am_libeztrace_omp_la_OBJECTS = libeztrace_omp_la-gomp.lo libeztrace_omp_la_OBJECTS = $(am_libeztrace_omp_la_OBJECTS) libeztrace_omp_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(libeztrace_omp_la_CFLAGS) $(CFLAGS) \ $(libeztrace_omp_la_LDFLAGS) $(LDFLAGS) -o $@ SCRIPTS = $(bin_SCRIPTS) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libeztrace_autostart_omp_la_SOURCES) \ $(libeztrace_convert_omp_la_SOURCES) \ $(libeztrace_omp_la_SOURCES) DIST_SOURCES = $(libeztrace_autostart_omp_la_SOURCES) \ $(libeztrace_convert_omp_la_SOURCES) \ $(libeztrace_omp_la_SOURCES) RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ ctags-recursive dvi-recursive html-recursive info-recursive \ install-data-recursive install-dvi-recursive \ install-exec-recursive install-html-recursive \ install-info-recursive install-pdf-recursive \ install-ps-recursive install-recursive installcheck-recursive \ installdirs-recursive pdf-recursive ps-recursive \ tags-recursive uninstall-recursive am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac HEADERS = $(noinst_HEADERS) RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \ distclean-recursive maintainer-clean-recursive am__recursive_targets = \ $(RECURSIVE_TARGETS) \ $(RECURSIVE_CLEAN_TARGETS) \ $(am__extra_recursive_targets) AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ distdir am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags DIST_SUBDIRS = $(SUBDIRS) am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/eztrace_cc.in \ $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) am__relativize = \ dir0=`pwd`; \ sed_first='s,^\([^/]*\)/.*$$,\1,'; \ sed_rest='s,^[^/]*/*,,'; \ sed_last='s,^.*/\([^/]*\)$$,\1,'; \ sed_butlast='s,/*[^/]*$$,,'; \ while test -n "$$dir1"; do \ first=`echo "$$dir1" | sed -e "$$sed_first"`; \ if test "$$first" != "."; then \ if test "$$first" = ".."; then \ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \ else \ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \ if test "$$first2" = "$$first"; then \ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \ else \ dir2="../$$dir2"; \ fi; \ dir0="$$dir0"/"$$first"; \ fi; \ fi; \ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \ done; \ reldir="$$dir2" ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ TLCFLAGS = $(TL_CPPFLAGS) TLLDFLAGS = $(TL_LDFLAGS) TLLIBADD = $(TL_LIB) GTGCFLAGS = $(GTG_CPPFLAGS) GTGLDFLAGS = $(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD = $(GTG_LIB) bin_SCRIPTS = eztrace_cc lib_LTLIBRARIES = libeztrace-convert-omp.la \ libeztrace-omp.la \ libeztrace-autostart-omp.la AM_CFLAGS = -W -Wall -Wextra $(am__append_1) -I$(srcdir)/../../core/ \ -I$(top_builddir)/src/core -I$(top_srcdir)/src/pptrace libeztrace_convert_omp_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) libeztrace_convert_omp_la_CFLAGS = $(AM_CFLAGS) libeztrace_convert_omp_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) libeztrace_convert_omp_la_LDFLAGS = --no-undefined $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_omp_la_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace_convert_omp_la_SOURCES = eztrace_convert_gomp.c libeztrace_omp_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_omp_la_CFLAGS = $(AM_CFLAGS) libeztrace_omp_la_LIBADD = -lm -lpthread $(TLLIBADD) libeztrace_omp_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_omp_la_SOURCES = gomp.c libeztrace_autostart_omp_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_autostart_omp_la_CFLAGS = -W -Wall -Wextra -DEZTRACE_AUTOSTART $(AM_CFLAGS) libeztrace_autostart_omp_la_LIBADD = -lm -lpthread $(TLLIB) libeztrace_autostart_omp_la_LDFLAGS = -rdynamic --no-undefined $(TLLDFLAGS) libeztrace_autostart_omp_la_SOURCES = gomp.c noinst_HEADERS = gomp_ev_codes.h #pomp2_lib.h EXTRA_DIST = eztrace_cc.in SUBDIRS = pomp-lib-dummy all: all-recursive .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/modules/omp/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu src/modules/omp/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): eztrace_cc: $(top_builddir)/config.status $(srcdir)/eztrace_cc.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ } uninstall-libLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ done clean-libLTLIBRARIES: -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) @list='$(lib_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libeztrace-autostart-omp.la: $(libeztrace_autostart_omp_la_OBJECTS) $(libeztrace_autostart_omp_la_DEPENDENCIES) $(EXTRA_libeztrace_autostart_omp_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_autostart_omp_la_LINK) -rpath $(libdir) $(libeztrace_autostart_omp_la_OBJECTS) $(libeztrace_autostart_omp_la_LIBADD) $(LIBS) libeztrace-convert-omp.la: $(libeztrace_convert_omp_la_OBJECTS) $(libeztrace_convert_omp_la_DEPENDENCIES) $(EXTRA_libeztrace_convert_omp_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_convert_omp_la_LINK) -rpath $(libdir) $(libeztrace_convert_omp_la_OBJECTS) $(libeztrace_convert_omp_la_LIBADD) $(LIBS) libeztrace-omp.la: $(libeztrace_omp_la_OBJECTS) $(libeztrace_omp_la_DEPENDENCIES) $(EXTRA_libeztrace_omp_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_omp_la_LINK) -rpath $(libdir) $(libeztrace_omp_la_OBJECTS) $(libeztrace_omp_la_LIBADD) $(LIBS) install-binSCRIPTS: $(bin_SCRIPTS) @$(NORMAL_INSTALL) @list='$(bin_SCRIPTS)'; test -n "$(bindir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(bindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(bindir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ if test -f "$$d$$p"; then echo "$$d$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n' \ -e 'h;s|.*|.|' \ -e 'p;x;s,.*/,,;$(transform)' | sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1; } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) { files[d] = files[d] " " $$1; \ if (++n[d] == $(am__install_max)) { \ print "f", d, files[d]; n[d] = 0; files[d] = "" } } \ else { print "f", d "/" $$4, $$1 } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_SCRIPT) $$files '$(DESTDIR)$(bindir)$$dir'"; \ $(INSTALL_SCRIPT) $$files "$(DESTDIR)$(bindir)$$dir" || exit $$?; \ } \ ; done uninstall-binSCRIPTS: @$(NORMAL_UNINSTALL) @list='$(bin_SCRIPTS)'; test -n "$(bindir)" || exit 0; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 's,.*/,,;$(transform)'`; \ dir='$(DESTDIR)$(bindir)'; $(am__uninstall_files_from_dir) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_autostart_omp_la-gomp.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_omp_la-eztrace_convert_gomp.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_omp_la-gomp.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< libeztrace_autostart_omp_la-gomp.lo: gomp.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_omp_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_omp_la_CFLAGS) $(CFLAGS) -MT libeztrace_autostart_omp_la-gomp.lo -MD -MP -MF $(DEPDIR)/libeztrace_autostart_omp_la-gomp.Tpo -c -o libeztrace_autostart_omp_la-gomp.lo `test -f 'gomp.c' || echo '$(srcdir)/'`gomp.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_autostart_omp_la-gomp.Tpo $(DEPDIR)/libeztrace_autostart_omp_la-gomp.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gomp.c' object='libeztrace_autostart_omp_la-gomp.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_omp_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_omp_la_CFLAGS) $(CFLAGS) -c -o libeztrace_autostart_omp_la-gomp.lo `test -f 'gomp.c' || echo '$(srcdir)/'`gomp.c libeztrace_convert_omp_la-eztrace_convert_gomp.lo: eztrace_convert_gomp.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_omp_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_convert_omp_la_CFLAGS) $(CFLAGS) -MT libeztrace_convert_omp_la-eztrace_convert_gomp.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_omp_la-eztrace_convert_gomp.Tpo -c -o libeztrace_convert_omp_la-eztrace_convert_gomp.lo `test -f 'eztrace_convert_gomp.c' || echo '$(srcdir)/'`eztrace_convert_gomp.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_omp_la-eztrace_convert_gomp.Tpo $(DEPDIR)/libeztrace_convert_omp_la-eztrace_convert_gomp.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_gomp.c' object='libeztrace_convert_omp_la-eztrace_convert_gomp.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_omp_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_convert_omp_la_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_omp_la-eztrace_convert_gomp.lo `test -f 'eztrace_convert_gomp.c' || echo '$(srcdir)/'`eztrace_convert_gomp.c libeztrace_omp_la-gomp.lo: gomp.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_omp_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_omp_la_CFLAGS) $(CFLAGS) -MT libeztrace_omp_la-gomp.lo -MD -MP -MF $(DEPDIR)/libeztrace_omp_la-gomp.Tpo -c -o libeztrace_omp_la-gomp.lo `test -f 'gomp.c' || echo '$(srcdir)/'`gomp.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_omp_la-gomp.Tpo $(DEPDIR)/libeztrace_omp_la-gomp.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gomp.c' object='libeztrace_omp_la-gomp.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_omp_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_omp_la_CFLAGS) $(CFLAGS) -c -o libeztrace_omp_la-gomp.lo `test -f 'gomp.c' || echo '$(srcdir)/'`gomp.c mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs # This directory's subdirectories are mostly independent; you can cd # into them and run 'make' without going through this Makefile. # To change the values of 'make' variables: instead of editing Makefiles, # (1) if the variable is set in 'config.status', edit 'config.status' # (which will cause the Makefiles to be regenerated when you run 'make'); # (2) otherwise, pass the desired values on the 'make' command line. $(am__recursive_targets): @fail=; \ if $(am__make_keepgoing); then \ failcom='fail=yes'; \ else \ failcom='exit 1'; \ fi; \ dot_seen=no; \ target=`echo $@ | sed s/-recursive//`; \ case "$@" in \ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ *) list='$(SUBDIRS)' ;; \ esac; \ for subdir in $$list; do \ echo "Making $$target in $$subdir"; \ if test "$$subdir" = "."; then \ dot_seen=yes; \ local_target="$$target-am"; \ else \ local_target="$$target"; \ fi; \ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ || eval $$failcom; \ done; \ if test "$$dot_seen" = "no"; then \ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ fi; test -z "$$fail" ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-recursive TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ include_option=--etags-include; \ empty_fix=.; \ else \ include_option=--include; \ empty_fix=; \ fi; \ list='$(SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ test ! -f $$subdir/TAGS || \ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \ fi; \ done; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-recursive CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-recursive cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ $(am__make_dryrun) \ || test -d "$(distdir)/$$subdir" \ || $(MKDIR_P) "$(distdir)/$$subdir" \ || exit 1; \ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \ $(am__relativize); \ new_distdir=$$reldir; \ dir1=$$subdir; dir2="$(top_distdir)"; \ $(am__relativize); \ new_top_distdir=$$reldir; \ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \ ($(am__cd) $$subdir && \ $(MAKE) $(AM_MAKEFLAGS) \ top_distdir="$$new_top_distdir" \ distdir="$$new_distdir" \ am__remove_distdir=: \ am__skip_length_check=: \ am__skip_mode_fix=: \ distdir) \ || exit 1; \ fi; \ done check-am: all-am check: check-recursive all-am: Makefile $(LTLIBRARIES) $(SCRIPTS) $(HEADERS) installdirs: installdirs-recursive installdirs-am: for dir in "$(DESTDIR)$(libdir)" "$(DESTDIR)$(bindir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-recursive install-exec: install-exec-recursive install-data: install-data-recursive uninstall: uninstall-recursive install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-recursive install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-recursive clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ mostlyclean-am distclean: distclean-recursive -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-recursive dvi-am: html: html-recursive html-am: info: info-recursive info-am: install-data-am: install-dvi: install-dvi-recursive install-dvi-am: install-exec-am: install-binSCRIPTS install-libLTLIBRARIES install-html: install-html-recursive install-html-am: install-info: install-info-recursive install-info-am: install-man: install-pdf: install-pdf-recursive install-pdf-am: install-ps: install-ps-recursive install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-recursive -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-recursive mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-recursive pdf-am: ps: ps-recursive ps-am: uninstall-am: uninstall-binSCRIPTS uninstall-libLTLIBRARIES .MAKE: $(am__recursive_targets) install-am install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am check \ check-am clean clean-generic clean-libLTLIBRARIES \ clean-libtool cscopelist-am ctags ctags-am distclean \ distclean-compile distclean-generic distclean-libtool \ distclean-tags distdir dvi dvi-am html html-am info info-am \ install install-am install-binSCRIPTS install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-libLTLIBRARIES install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs installdirs-am \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ pdf pdf-am ps ps-am tags tags-am uninstall uninstall-am \ uninstall-binSCRIPTS uninstall-libLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/src/modules/omp/eztrace_cc.in000066400000000000000000000035271265506773700206640ustar00rootroot00000000000000#!/bin/sh # Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. # usage: eztrace_cc gcc -o foo foo.c -I/usr/include/bar -L/lib/bar -lbar cc_cmd=$* prefix=@prefix@ exec_prefix=${prefix} libdir=${exec_prefix}/lib includedir=${prefix}/include bindir=${exec_prefix}/bin OPARI=${bindir}/opari2 CFLAGS=-I${includedir} LDFLAGS="-lpomp2 -L${libdir} -Wl,-rpath=${libdir}" tmpdir=`mktemp -d` instrumentFile() { param=$1 new_file_name=$2 # copy the file to tmpdir and instrument it param_base=`basename $param` param_dir=`dirname $param` cp $param $tmpdir ${OPARI} --nosrc --untied=keep --untied=no-warn ${tmpdir}/${param_base} $new_file_name res_grep=`echo "$cc_cmd" |grep -- "-c" ` if [ "x$res_grep" != "x" ]; then res_grep=`echo "$cc_cmd" |grep -- "-o" ` if [ "x$res_grep" = "x" ]; then # there is no -o in the compilation line # we need to add -o param.o # otherwise the generated file would be tmp.xxxx.o instead of param.o doto_file=`echo "$param_base" |sed 's/\.[c|f|F]$/\.o/' |sed 's/\.f90$/\.o/'` cc_cmd="$cc_cmd -o $doto_file" fi fi cc_cmd=`echo $cc_cmd -I$param_dir | sed "s@$param\s@$new_file_name @"` } cleanup_cmd="rm -rf opari.rc $tmpdir" for x in $(seq $#) ; do param=$(eval echo \$"$x") case $param in *.c ) new_file_name=`mktemp --suffix=.c --tmpdir=$tmpdir` instrumentFile $param $new_file_name ;; *.f ) new_file_name=`mktemp --suffix=.f --tmpdir=$tmpdir` instrumentFile $param $new_file_name ;; *.F ) new_file_name=`mktemp --suffix=.F --tmpdir=$tmpdir` instrumentFile $param $new_file_name ;; *.f90 ) new_file_name=`mktemp --suffix=.f90 --tmpdir=$PWD` instrumentFile $param $new_file_name ;; esac done cc_cmd="$cc_cmd $CFLAGS $LDFLAGS" $cc_cmd $cleanup_cmd eztrace-1.1-2/src/modules/omp/eztrace_convert_gomp.c000066400000000000000000000661361265506773700226220ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include #include #include "gomp_ev_codes.h" #include "eztrace_list.h" #include "eztrace_stack.h" #include "eztrace_convert.h" #include "pomp-lib-dummy/pomp2_lib.h" static struct ezt_list_t section_list; static int recording_stats = 0; static int nb_parallel_region = 0; #define GOMP_CHANGE() if(!recording_stats) CHANGE() /* contains all the information of a parallel section */ struct gomp_section_t { void (*func)(void *); app_ptr data; POMP2_Region_handle id; int nb_threads; struct eztrace_container_t * main_thread; struct eztrace_container_t ** working_threads; char** link_value_start; char** link_id_start; char** link_value_end; char** link_id_end; float start_time; /* time at which the parallel_start occurs */ float* fork_time; /* time at which the fork happens for each thread */ float* join_time; /* time at which the thread reach join */ float join_done_time; /* time at which the join ends */ int nb_joined; /* number of threads that finished end_loop */ ezt_stack_token_t token; }; /* pointer to a parallel section. This structure is used in the * section_stack field of the gomp_thread_info_t structure */ struct gomp_thread_section_t { struct gomp_section_t *process_section; ezt_stack_token_t token; }; /* contains the list of parallel sections that a thread is currently processing */ struct gomp_thread_info_t { ezt_stack_t section_stack; struct thread_info_t *p_thread; }; /* contains the list of parallel sections that a process is currently processing */ struct gomp_process_info_t { struct ezt_list_t section_list; struct process_info_t *p_process; struct ezt_list_t finished_section_list; }; /* add a hook in the process structure in order to store information * about pending parallel sections */ static struct gomp_process_info_t *__register_process_hook( struct process_info_t *p_process) { struct gomp_process_info_t *g_info = (struct gomp_process_info_t*) malloc( sizeof(struct gomp_process_info_t)); g_info->p_process = p_process; ezt_list_new(&g_info->section_list); ezt_list_new(&g_info->finished_section_list); /* add the hook in the thread info structure */ ezt_hook_list_add(&g_info->p_process->hooks, g_info, (uint8_t) EZTRACE_GOMP_EVENTS_ID); return g_info; } /* add a hook in the thread structure in order to store information * about pending parallel sections */ struct gomp_thread_info_t *__register_thread_hook(int tid) { DECLARE_CUR_PROCESS(p_process); struct gomp_thread_info_t *g_info = (struct gomp_thread_info_t*) malloc( sizeof(struct gomp_thread_info_t)); g_info->p_thread = GET_THREAD_INFO(CUR_INDEX, tid); ezt_stack_new(&g_info->section_stack); /* add the hook in the thread info structure */ ezt_hook_list_add(&g_info->p_thread->hooks, g_info, (uint8_t) EZTRACE_GOMP_EVENTS_ID); return g_info; } /* declare a var variable that points to the process_info structure */ #define INIT_GOMP_PROCESS_INFO(p_process, var) \ struct gomp_process_info_t *var = (struct gomp_process_info_t*) \ ezt_hook_list_retrieve_data(&p_process->hooks, (uint8_t)EZTRACE_GOMP_EVENTS_ID); \ if(!(var)) { \ var = __register_process_hook(p_process); \ } /* declare a var variable that points to the thread_info structure */ #define INIT_GOMP_THREAD_INFO(p_thread_info, var) \ struct gomp_thread_info_t *var = (struct gomp_thread_info_t*) \ ezt_hook_list_retrieve_data(&p_thread_info->hooks, (uint8_t)EZTRACE_GOMP_EVENTS_ID); \ if(!(var)) { \ var = __register_thread_hook(CUR_THREAD_ID); \ } /* retrieve the gomp_section structure that corresponds to a section id */ struct ezt_list_token_t *__find_matching_section( struct process_info_t*p_process, POMP2_Region_handle id) { INIT_GOMP_PROCESS_INFO(p_process, process_info) struct ezt_list_token_t *token = NULL; ezt_list_foreach(&process_info->section_list, token) { struct gomp_section_t * section = (struct gomp_section_t *) token->data; if (section->id == id) return token; } return NULL; } /* OpenMP */ void handle_gomp_new_fork() { /* This event occurs when a parallel section begins. * This event is generated by the new thread (ie. not by the main thread * that called #omp parallel) */ FUNC_NAME; /* We have to: * - retrieve the gomp_section structur that was created by the main thread * - add this section to the thread's stack * - create the links between the main thread and the current thread * - set the state of the current thread to 'working' */ DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_GOMP_THREAD_INFO(p_thread, g_info); DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); /* retrieve the gomp_section structure that was created by the main thread */ POMP2_Region_handle section_id; int my_id; int nb_threads; GET_PARAM_PACKED_3(CUR_EV, section_id, my_id, nb_threads); struct ezt_list_token_t *token = __find_matching_section(p_process, section_id); assert(token); struct gomp_section_t * section = (struct gomp_section_t *) token->data; assert(section->main_thread); char* main_thread_str = section->main_thread->id; if (section->nb_threads) { assert(section->nb_threads == nb_threads); } if (!section->nb_threads) { /* We are the first thread that reach the section, allocate everything */ section->id = section_id; section->nb_threads = nb_threads; section->nb_joined = 0; section->working_threads = malloc( sizeof(struct eztrace_container_t*) * section->nb_threads); section->link_value_start = malloc(sizeof(char*) * section->nb_threads); section->link_id_start = malloc(sizeof(char*) * section->nb_threads); section->link_value_end = malloc(sizeof(char*) * section->nb_threads); section->link_id_end = malloc(sizeof(char*) * section->nb_threads); section->fork_time = malloc(sizeof(float) * section->nb_threads); section->join_time = malloc(sizeof(float) * section->nb_threads); } assert(section->id == section_id); section->working_threads[my_id] = GET_THREAD_CONTAINER(CUR_INDEX, CUR_THREAD_ID); section->fork_time[my_id] = CURRENT; /* create the links between the main thread and the current thread */ int res __attribute__ ((__unused__)); res = asprintf(§ion->link_id_start[my_id], "%d_%d_%d", CUR_RANK, section->id, my_id); res = asprintf(§ion->link_value_start[my_id], "p#%d_section#%d_thread#%d", CUR_RANK, section->id, my_id); /* add this section to the thread's stack */ struct gomp_thread_section_t *p_th_section = (struct gomp_thread_section_t*) malloc( sizeof(struct gomp_thread_section_t)); p_th_section->process_section = section; p_th_section->token.data = p_th_section; ezt_stack_push(&g_info->section_stack, &p_th_section->token); GOMP_CHANGE() startLink(section->start_time, "GOMP_Section_Link", "C_Prog", main_thread_str, thread_id, section->link_value_start[my_id], section->link_id_start[my_id]); GOMP_CHANGE() endLink(CURRENT, "GOMP_Section_Link", "C_Prog", main_thread_str, thread_id, section->link_value_start[my_id], section->link_id_start[my_id]); /* set the state of the current thread to 'working' */ GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_Section_State"); } void handle_gomp_new_join() { /* This event occurs when a parallel section ends. * This event is generated by the new thread (ie. not by the main thread * that called #omp parallel) */ FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); /* We have to: * - retrieve and remove the gomp_section structure that was stacked * - create the links between the main thread and the current thread * - set the state of the current thread to 'blocked' */ DECLARE_CUR_THREAD(p_thread); INIT_GOMP_THREAD_INFO(p_thread, g_info); DECLARE_CUR_PROCESS(p_process); INIT_GOMP_PROCESS_INFO(p_process, process_info); int my_id; GET_PARAM_PACKED_1(CUR_EV, my_id); /* retrieve and remove the gomp_section structure that was stacked */ ezt_stack_token_t *token = ezt_stack_get_top(&g_info->section_stack); if(g_info->section_stack.nb_item) { assert(token); struct gomp_thread_section_t *thread_section = (struct gomp_thread_section_t *) token->data; struct gomp_section_t *section = thread_section->process_section; section->join_time[my_id] = CURRENT; /* create the links between the main thread and the current thread */ int res __attribute__ ((__unused__)); res = asprintf(§ion->link_id_end[my_id], "%d_%d_%d", CUR_RANK, section->id, my_id); res = asprintf(§ion->link_value_end[my_id], "p#%d_section#%d_thread#%d", CUR_RANK, section->id, my_id); GOMP_CHANGE() startLink(CURRENT, "GOMP_Section_Link", "C_Prog", thread_id, section->main_thread->id, section->link_value_end[my_id], section->link_id_end[my_id]); section->nb_joined++; if(section->nb_joined == section->nb_threads) { /* This is the last thread to finish end_loop */ section->join_done_time = CURRENT; /* end all the links that were started by the new_join event */ int i; for (i = 0; i < section->nb_threads; i++) { GOMP_CHANGE() endLink(CURRENT, "GOMP_Section_Link", "C_Prog", section->working_threads[i]->id, section->main_thread->id, section->link_value_end[i], section->link_id_end[i]); } /* free the section structure and set the current state to working */ struct ezt_list_token_t *process_section_token = __find_matching_section(p_process, section->id); assert(process_section_token); ezt_list_remove(process_section_token); ezt_list_add(&process_info->finished_section_list, §ion->token); } GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } } void handle_gomp_parallel_start() { /* This event occurs when a parallel section begins. * This event is generated by the main thread */ FUNC_NAME; struct gomp_section_t * section = (struct gomp_section_t*) malloc( sizeof(struct gomp_section_t)); nb_parallel_region++; /* Initialize the section strcuture */ GET_PARAM_PACKED_1(CUR_EV, section->id); section->nb_threads = 0; section->main_thread = GET_THREAD_CONTAINER(CUR_INDEX, CUR_THREAD_ID); section->working_threads = NULL; section->start_time = CURRENT; section->token.data = section; DECLARE_CUR_PROCESS(p_process); INIT_GOMP_PROCESS_INFO(p_process, g_info); /* add the section structure to the list of pending sections */ ezt_list_add(&g_info->section_list, §ion->token); } void handle_gomp_critical_start() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Blocked"); } void handle_gomp_critical_start_done() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_Critical"); } void handle_gomp_critical_stop() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_finalize() { } void handle_pomp2_atomic_enter() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_Atomic"); } void handle_pomp2_atomic_exit() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_critical_enter() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Blocked"); } void handle_pomp2_critical_begin() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_Critical"); } void handle_pomp2_critical_end() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_critical_exit() { } void handle_pomp2_barrier_enter() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_Barrier"); } void handle_pomp2_barrier_exit() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_implicit_barrier_enter() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_Implicit_Barrier"); } void handle_pomp2_implicit_barrier_exit() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_flush_enter() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_Flush"); } void handle_pomp2_flush_exit() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_task_create_begin() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_Task_Create"); } void handle_pomp2_task_create_end() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_task_begin() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_Task"); } void handle_pomp2_task_end() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_untied_task_create_begin() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_Untied_Task_Create"); } void handle_pomp2_untied_task_create_end() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_untied_task_begin() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_Untied_Task"); } void handle_pomp2_untied_task_end() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_taskwait_begin() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_TaskWait"); } void handle_pomp2_taskwait_end() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_for_enter() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_For"); } void handle_pomp2_for_exit() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_master_begin() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "GOMP_Master"); } void handle_pomp2_master_end() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_parallel_begin() { /* Since the runtime functions provide more information, let's forget these compiler functions */ FUNC_NAME; } void handle_pomp2_parallel_end() { /* Since the runtime functions provide more information, let's forget these compiler functions */ FUNC_NAME; } void handle_pomp2_parallel_fork() { /* Since the runtime functions provide more information, let's forget these compiler functions */ FUNC_NAME; } void handle_pomp2_parallel_join() { /* Since the runtime functions provide more information, let's forget these compiler functions */ FUNC_NAME; } void handle_pomp2_sections_enter() { /* todo */ } void handle_pomp2_sections_exit() { /* todo */ } void handle_pomp2_section_begin() { /* todo */ } void handle_pomp2_section_end() { /* todo */ } void handle_pomp2_single_enter() { /* todo */ } void handle_pomp2_single_exit() { /* todo */ } void handle_pomp2_single_begin() { /* todo */ } void handle_pomp2_single_end() { /* todo */ } void handle_pomp2_workshare_enter() { /* todo */ } void handle_pomp2_workshare_exit() { /* todo */ } #ifdef OPENMP_FOUND void handle_pomp2_set_lock_entry() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_GOMP_Lock"); } void handle_pomp2_set_lock_exit() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_GOMP_Locked"); } void handle_pomp2_test_lock_success() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_GOMP_Locked"); } void handle_pomp2_unset_lock() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_pomp2_set_nest_lock_entry() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_GOMP_NLock"); } void handle_pomp2_set_nest_lock_exit() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_GOMP_NLocked"); } void handle_pomp2_test_nest_lock_success() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_GOMP_NLocked"); } void handle_pomp2_unset_nest_lock() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); GOMP_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } #endif /* OPENMP_FOUND */ int eztrace_convert_gomp_init() { if (get_mode() == EZTRACE_CONVERT) { addLinkType("GOMP_Section_Link", "OpenMP Parallel Section", "CT_Program", "CT_Thread", "CT_Thread"); addEntityValue("GOMP_Section_State", "ST_Thread", "GOMP_Section_State", GTG_PINK); addEntityValue("GOMP_Critical", "ST_Thread", "GOMP_Critical", GTG_GREEN); addEntityValue("GOMP_Atomic", "ST_Thread", "GOMP_Atomic", GTG_GREEN); addEntityValue("GOMP_Barrier", "ST_Thread", "GOMP_Barrier", GTG_ORANGE); addEntityValue("GOMP_Implicit_Barrier", "ST_Thread", "GOMP_Implicit_Barrier", GTG_RED); addEntityValue("GOMP_For", "ST_Thread", "GOMP_For", GTG_LIGHTGREY); addEntityValue("GOMP_Master", "ST_Thread", "GOMP_Master", GTG_WHITE); #ifdef OPENMP_FOUND addEntityValue("STV_GOMP_Lock", "ST_Thread", "Blocked on an OpenMP lock", GTG_RED); addEntityValue("STV_GOMP_Locked", "ST_Thread", "Holding an OpenMP lock", GTG_GREEN); addEntityValue("STV_GOMP_NLock", "ST_Thread", "Blocked on an OpenMP nested lock", GTG_RED); addEntityValue("STV_GOMP_NLocked", "ST_Thread", "Holding an OpenMP nested lock", GTG_GREEN); #endif /* OPENMP_FOUND */ addEntityValue("GOMP_TaskWait", "ST_Thread", "GOMP_TaskWait", GTG_ORANGE); addEntityValue("GOMP_Task", "ST_Thread", "GOMP_Task", GTG_WHITE); addEntityValue("GOMP_Untied_Task", "ST_Thread", "GOMP_Task", GTG_TEAL); addEntityValue("GOMP_Task_Create", "ST_Thread", "Creating an OpenMP Task", GTG_KAKI); addEntityValue("GOMP_Untied_Task_Create", "ST_Thread", "Creating an OpenMP Task", GTG_SEABLUE); } ezt_list_new(§ion_list); return 0; } /* return 1 if the event was handled */ int handle_gomp_events(eztrace_event_t *ev) { if (!STARTED) return 0; switch (LITL_READ_GET_CODE(ev)) { /* OpenMP */ case EZTRACE_GOMP_NEW_FORK: handle_gomp_new_fork(); break; case EZTRACE_GOMP_NEW_JOIN: handle_gomp_new_join(); break; case EZTRACE_GOMP_PARALLEL_START: handle_gomp_parallel_start(); break; case EZTRACE_GOMP_CRITICAL_START: handle_gomp_critical_start(); break; case EZTRACE_GOMP_CRITICAL_START_DONE: handle_gomp_critical_start_done(); break; case EZTRACE_GOMP_CRITICAL_STOP: handle_gomp_critical_stop(); break; case EZTRACE_POMP2_FINALIZE: handle_pomp2_finalize(); break; case EZTRACE_POMP2_ATOMIC_ENTER: handle_pomp2_atomic_enter(); break; case EZTRACE_POMP2_ATOMIC_EXIT: handle_pomp2_atomic_exit(); break; case EZTRACE_POMP2_BARRIER_ENTER: handle_pomp2_barrier_enter(); break; case EZTRACE_POMP2_BARRIER_EXIT: handle_pomp2_barrier_exit(); break; case EZTRACE_POMP2_IMPLICIT_BARRIER_ENTER: handle_pomp2_implicit_barrier_enter(); break; case EZTRACE_POMP2_IMPLICIT_BARRIER_EXIT: handle_pomp2_implicit_barrier_exit(); break; case EZTRACE_POMP2_FLUSH_ENTER: handle_pomp2_flush_enter(); break; case EZTRACE_POMP2_FLUSH_EXIT: handle_pomp2_flush_exit(); break; case EZTRACE_POMP2_CRITICAL_ENTER: handle_pomp2_critical_enter(); break; case EZTRACE_POMP2_CRITICAL_EXIT: handle_pomp2_critical_exit(); break; case EZTRACE_POMP2_CRITICAL_BEGIN: handle_pomp2_critical_begin(); break; case EZTRACE_POMP2_CRITICAL_END: handle_pomp2_critical_end(); break; case EZTRACE_POMP2_FOR_ENTER: handle_pomp2_for_enter(); break; case EZTRACE_POMP2_FOR_EXIT: handle_pomp2_for_exit(); break; case EZTRACE_POMP2_MASTER_BEGIN: handle_pomp2_master_begin(); break; case EZTRACE_POMP2_MASTER_END: handle_pomp2_master_end(); break; case EZTRACE_POMP2_PARALLEL_BEGIN: handle_pomp2_parallel_begin(); break; case EZTRACE_POMP2_PARALLEL_END: handle_pomp2_parallel_end(); break; case EZTRACE_POMP2_PARALLEL_FORK: handle_pomp2_parallel_fork(); break; case EZTRACE_POMP2_PARALLEL_JOIN: handle_pomp2_parallel_join(); break; case EZTRACE_POMP2_SECTIONS_ENTER: handle_pomp2_sections_enter(); break; case EZTRACE_POMP2_SECTIONS_EXIT: handle_pomp2_sections_exit(); break; case EZTRACE_POMP2_SECTION_BEGIN: handle_pomp2_section_begin(); break; case EZTRACE_POMP2_SECTION_END: handle_pomp2_section_end(); break; case EZTRACE_POMP2_SINGLE_ENTER: handle_pomp2_single_enter(); break; case EZTRACE_POMP2_SINGLE_EXIT: handle_pomp2_single_exit(); break; case EZTRACE_POMP2_SINGLE_BEGIN: handle_pomp2_single_begin(); break; case EZTRACE_POMP2_SINGLE_END: handle_pomp2_single_end(); break; case EZTRACE_POMP2_WORKSHARE_ENTER: handle_pomp2_workshare_enter(); break; case EZTRACE_POMP2_WORKSHARE_EXIT: handle_pomp2_workshare_exit(); break; case EZTRACE_POMP2_TASK_CREATE_BEGIN: handle_pomp2_task_create_begin(); break; case EZTRACE_POMP2_TASK_CREATE_END: handle_pomp2_task_create_end(); break; case EZTRACE_POMP2_TASK_BEGIN: handle_pomp2_task_begin(); break; case EZTRACE_POMP2_TASK_END: handle_pomp2_task_end(); break; case EZTRACE_POMP2_UNTIED_TASK_CREATE_BEGIN: handle_pomp2_untied_task_create_begin(); break; case EZTRACE_POMP2_UNTIED_TASK_CREATE_END: handle_pomp2_untied_task_create_end(); break; case EZTRACE_POMP2_UNTIED_TASK_BEGIN: handle_pomp2_untied_task_begin(); break; case EZTRACE_POMP2_UNTIED_TASK_END: handle_pomp2_untied_task_end(); break; case EZTRACE_POMP2_TASKWAIT_BEGIN: handle_pomp2_taskwait_begin(); break; case EZTRACE_POMP2_TASKWAIT_END: handle_pomp2_taskwait_end(); break; #ifdef OPENMP_FOUND case EZTRACE_POMP2_SET_LOCK_ENTRY: handle_pomp2_set_lock_entry(); break; case EZTRACE_POMP2_SET_LOCK_EXIT: handle_pomp2_set_lock_exit(); break; case EZTRACE_POMP2_TEST_LOCK_SUCCESS: handle_pomp2_test_lock_success(); break; case EZTRACE_POMP2_UNSET_LOCK: handle_pomp2_unset_lock(); break; case EZTRACE_POMP2_SET_NEST_LOCK_ENTRY: handle_pomp2_set_nest_lock_entry(); break; case EZTRACE_POMP2_SET_NEST_LOCK_EXIT: handle_pomp2_set_nest_lock_exit(); break; case EZTRACE_POMP2_TEST_NEST_LOCK_SUCCESS: handle_pomp2_test_nest_lock_success(); break; case EZTRACE_POMP2_UNSET_NEST_LOCK: handle_pomp2_unset_nest_lock(); break; #endif /* OPENMP_FOUND */ default: return 0; } return 1; } /* return 1 if the event was handled */ int handle_gomp_stats(eztrace_event_t *ev) { recording_stats = 1; return handle_gomp_events(ev); } void print_gomp_stats() { printf("\nOpenMP:\n"); printf("----------\n"); printf("%d parallel regions\n", nb_parallel_region); /* todo: * add: * - min/max/average duration of parallel regions * - maximum depth (nested) */ /* browse the processes finished_section_list and extract statistics */ int i; for (i = 0; i < NB_TRACES; i++) { struct process_info_t *p_process = GET_PROCESS_INFO(i); struct gomp_process_info_t *p_info = (struct gomp_process_info_t*) ezt_hook_list_retrieve_data( &p_process->hooks, (uint8_t) EZTRACE_GOMP_EVENTS_ID); if (!p_info) continue; /* No gomp process info attached, skip this process */ /* todo: implement other statistics (min/max duration, depth, etc.) */ unsigned nb_sections = 0; float total_duration = 0; ezt_stack_token_t *token; ezt_list_foreach(&p_info->finished_section_list, token) { struct gomp_section_t * section = (struct gomp_section_t *) token->data; total_duration += section->join_done_time - section->start_time; nb_sections++; } printf("%s: \t %d parallel regions (average duration: %f ms)\n", p_process->container->name, nb_sections, total_duration / nb_sections); } } struct eztrace_convert_module gomp_module; void libinit(void) __attribute__ ((constructor)); void libinit(void) { gomp_module.api_version = EZTRACE_API_VERSION; gomp_module.init = eztrace_convert_gomp_init; gomp_module.handle = handle_gomp_events; gomp_module.handle_stats = handle_gomp_stats; gomp_module.print_stats = print_gomp_stats; gomp_module.module_prefix = EZTRACE_GOMP_EVENTS_ID; int res __attribute__ ((__unused__)); res = asprintf(&gomp_module.name, "omp"); res = asprintf(&gomp_module.description, "Module for OpenMP parallel regions"); gomp_module.token.data = &gomp_module; eztrace_convert_register_module(&gomp_module); } void libfinalize(void) __attribute__ ((destructor)); void libfinalize(void) { } eztrace-1.1-2/src/modules/omp/gomp.c000066400000000000000000000566721265506773700173510ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 #define _REENTRANT #include #include #include #include #include #include #include #include #include "pomp-lib-dummy/pomp2_lib.h" #include "gomp_ev_codes.h" #include "eztrace.h" #include "pptrace.h" static int pomp2_found = 0; #define GOMP_RECORD if(!pomp2_found) // todo: add hooks for // OMP_Barrier // OMP_critical ? static POMP2_Region_handle _next_section_id = 0; void (*libGOMP_parallel_loop_static_start)(void (*)(void *), void *, unsigned, long, long, long, long); void (*libGOMP_parallel_loop_runtime_start)(void (*)(void *), void *, unsigned, long, long, long, long); void (*libGOMP_parallel_loop_dynamic_start)(void (*)(void *), void *, unsigned, long, long, long, long); void (*libGOMP_parallel_loop_guided_start)(void (*)(void *), void *, unsigned, long, long, long, long); void (*libGOMP_parallel_start)(void (*fn)(void *), void *data, unsigned num_threads); void (*libGOMP_parallel_end)(); void (*libGOMP_critical_start)(void); void (*libGOMP_critical_end)(void); /* these function are only available in GOMP 4 */ void (*libGOMP_parallel_loop_static) (void (*)(void *), void *, unsigned, long, long, long, long, unsigned); void (*libGOMP_parallel_loop_dynamic) (void (*)(void *), void *, unsigned, long, long, long, long, unsigned); void (*libGOMP_parallel_loop_guided) (void (*)(void *), void *, unsigned, long, long, long, long, unsigned); void (*libGOMP_parallel_loop_runtime) (void (*)(void *), void *, unsigned, long, long, long, unsigned); static int use_pomp = 1; struct gomp_arg_t { void (*func)(void *); void *data; POMP2_Region_handle id; }; /* Function called by GOMP_parallel_start for each thread */ void gomp_new_thread(void *arg) { FUNCTION_ENTRY; struct gomp_arg_t *_arg = (struct gomp_arg_t*) arg; void (*func)(void *) = _arg->func; void *data = _arg->data; POMP2_Region_handle section_id = _arg->id; int nb_threads = omp_get_num_threads(); int my_id = omp_get_thread_num(); /* Since the runtime functions provide more information, let's use it instead of the compiler functions */ GOMP_RECORD { EZTRACE_EVENT_PACKED_3(EZTRACE_GOMP_NEW_FORK, section_id, my_id, nb_threads); } func(data); GOMP_RECORD { EZTRACE_EVENT_PACKED_1(EZTRACE_GOMP_NEW_JOIN, my_id); } return; } /* generic implementation of parallel loop */ #define GOMP_PARALLEL_LOOP_GENERIC(fn, data, varname, gomp_func, section_id) \ { \ EZTRACE_PROTECT_ON(); \ /* Since the runtime functions provide more information, let's use it instead of the compiler functions */ \ /* call unprotected function 'cause the block is protected */ \ EZTRACE_EVENT1_PACKED_UNPROTECTED(EZTRACE_GOMP_PARALLEL_START, section_id); \ struct gomp_arg_t *varname = (struct gomp_arg_t*) malloc (sizeof (struct gomp_arg_t)); \ varname->func = fn; \ varname->data = data; \ varname->id = section_id; \ EZTRACE_PROTECT_OFF(); \ gomp_func; \ } #define GOMP4_PARALLEL_LOOP_GENERIC(fn, data, varname, gomp_func) \ { \ FUNCTION_ENTRY; \ POMP2_Region_handle section_id = _next_section_id++; \ GOMP_PARALLEL_LOOP_GENERIC(fn, data, varname, gomp_func, section_id); \ } /* generic implementation of parallel loop */ #define GOMP3_PARALLEL_LOOP_GENERIC(fn, data, varname, gomp_func) \ { \ FUNCTION_ENTRY; \ POMP2_Region_handle section_id = _next_section_id++; \ GOMP_PARALLEL_LOOP_GENERIC(fn, data, varname, gomp_func, section_id); \ int nb_threads = omp_get_num_threads(); \ int my_id = omp_get_thread_num(); \ GOMP_RECORD { \ EZTRACE_EVENT_PACKED_3 (EZTRACE_GOMP_NEW_FORK, section_id, my_id, nb_threads); \ } \ return; \ } /* should be called when reaching #pragma omp parallel for schedule(static) * However, this function doesn't seem to be called. Let's implement it just in case. */ void GOMP_parallel_loop_static_start(void (*fn)(void *), void * data, unsigned num_threads, long a1, long a2, long a3, long a4) { GOMP3_PARALLEL_LOOP_GENERIC(fn, data, arg, libGOMP_parallel_loop_static_start(gomp_new_thread, arg, num_threads, a1, a2, a3, a4)); } /* Function called when reaching #pragma omp parallel for schedule(runtime) */ void GOMP_parallel_loop_runtime_start(void (*fn)(void *), void * data, unsigned num_threads, long a1, long a2, long a3, long a4) { GOMP3_PARALLEL_LOOP_GENERIC(fn, data, arg, libGOMP_parallel_loop_runtime_start(gomp_new_thread, arg, num_threads, a1, a2, a3, a4)); } /* Function called when reaching #pragma omp parallel for schedule(dynamic) */ void GOMP_parallel_loop_dynamic_start(void (*fn)(void *), void * data, unsigned num_threads, long a1, long a2, long a3, long a4) { GOMP3_PARALLEL_LOOP_GENERIC(fn, data, arg, libGOMP_parallel_loop_dynamic_start(gomp_new_thread, arg, num_threads, a1, a2, a3, a4)); } /* Function called when reaching #pragma omp parallel for schedule(guided) */ void GOMP_parallel_loop_guided_start(void (*fn)(void *), void * data, unsigned num_threads, long a1, long a2, long a3, long a4) { GOMP3_PARALLEL_LOOP_GENERIC(fn, data, arg, libGOMP_parallel_loop_guided_start(gomp_new_thread, arg, num_threads, a1, a2, a3, a4)); } void GOMP_parallel_loop_static (void (*fn)(void *), void *data, unsigned num_threads, long start, long end, long incr, long chunk_size, unsigned flags) { GOMP4_PARALLEL_LOOP_GENERIC(fn, data, arg, libGOMP_parallel_loop_static(gomp_new_thread, arg, num_threads, start, end, incr, chunk_size, flags)); } void GOMP_parallel_loop_dynamic (void (*fn) (void *), void *data, unsigned num_threads, long start, long end, long incr, long chunk_size, unsigned flags) { GOMP4_PARALLEL_LOOP_GENERIC(fn, data, arg, libGOMP_parallel_loop_dynamic(gomp_new_thread, arg, num_threads, start, end, incr, chunk_size, flags)); } void GOMP_parallel_loop_guided (void (*fn) (void *), void *data, unsigned num_threads, long start, long end, long incr, long chunk_size, unsigned flags) { GOMP4_PARALLEL_LOOP_GENERIC(fn, data, arg, libGOMP_parallel_loop_guided(gomp_new_thread, arg, num_threads, start, end, incr, chunk_size, flags)); } void GOMP_parallel_loop_runtime (void (*fn) (void *), void *data, unsigned num_threads, long start, long end, long incr, unsigned flags) { GOMP4_PARALLEL_LOOP_GENERIC(fn, data, arg, libGOMP_parallel_loop_runtime(gomp_new_thread, arg, num_threads, start, end, incr, flags)); } // Called by the main thread (ie. only once) during #pragma omp parallel // (fork) void GOMP_parallel_start(void (*fn)(void *), void *data, unsigned num_threads) { GOMP4_PARALLEL_LOOP_GENERIC(fn, data, arg, libGOMP_parallel_start(gomp_new_thread, arg, num_threads)); } // Called at the end of a parallel section (~ join) void GOMP_parallel_end() { FUNCTION_ENTRY; /* Since the runtime functions provide more information, let's use it instead of the compiler functions */ int my_id = omp_get_thread_num(); GOMP_RECORD { EZTRACE_EVENT_PACKED_1(EZTRACE_GOMP_NEW_JOIN, my_id); } libGOMP_parallel_end(); } void GOMP_critical_start() { FUNCTION_ENTRY; GOMP_RECORD EZTRACE_EVENT_PACKED_0(EZTRACE_GOMP_CRITICAL_START); libGOMP_critical_start(); GOMP_RECORD EZTRACE_EVENT_PACKED_0(EZTRACE_GOMP_CRITICAL_START_DONE); } void GOMP_critical_end() { FUNCTION_ENTRY; GOMP_RECORD EZTRACE_EVENT_PACKED_0(EZTRACE_GOMP_CRITICAL_STOP); libGOMP_critical_end(); } /* beginning of pomp2 internals */ void POMP2_Finalize() { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_FINALIZE); } void POMP2_Init() { /* todo: initialize stuff ? */ } void POMP2_Off() { /* todo: stop recording events ? */ } void POMP2_On() { /* todo: initialize stuff ? */ } void POMP2_Begin(POMP2_Region_handle* pomp2_handle __attribute__((unused))) { /** Called at the begin of a user defined POMP2 region. @param pomp2_handle The handle of the started region. */ } void POMP2_End(POMP2_Region_handle* pomp2_handle __attribute__((unused))) { } void POMP2_Assign_handle( POMP2_Region_handle* pomp2_handle __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { /** Registers a POMP2 region and returns a region handle. @param pomp2_handle Returns the handle for the newly registered region. @param ctc_string A string containing the region data. */ } /* end of pomp2 internals */ void POMP2_Atomic_enter( POMP2_Region_handle* pomp2_handle __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { /** Called before an atomic statement. @param pomp2_handle The handle of the started region. @param ctc_string Initialization string. May be ignored if \ is already initialized. */ FUNCTION_ENTRY; /* todo: record the initialization string ? */ EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_ATOMIC_ENTER); } void POMP2_Atomic_exit( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_ATOMIC_EXIT); } void POMP2_Implicit_barrier_enter( POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle* pomp2_old_task __attribute__((unused))) { /** Called before an implicit barrier. \e OpenMP \e 3.0: Barriers can be used as scheduling points for tasks. When entering a barrier the task id of the currently executing task (\e pomp2_current_task) is saved in \e pomp2_old_task, which is defined inside the instrumented user code. @param pomp2_handle The handle of the started region. @param pomp2_old_task Pointer to a "taskprivate" variable where the current task id is stored. */ FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_IMPLICIT_BARRIER_ENTER); /* todo: implement */ } extern void POMP2_Implicit_barrier_exit( POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle pomp2_old_task __attribute__((unused))) { /* todo: implement */ FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_IMPLICIT_BARRIER_EXIT); } void POMP2_Barrier_enter( POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle* pomp2_old_task __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_BARRIER_ENTER); } void POMP2_Barrier_exit( POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle pomp2_old_task __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_BARRIER_EXIT); } void POMP2_Flush_enter( POMP2_Region_handle* pomp2_handle __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_FLUSH_ENTER); } void POMP2_Flush_exit(POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_FLUSH_EXIT); } void POMP2_Critical_begin( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_CRITICAL_BEGIN); } void POMP2_Critical_end( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_CRITICAL_END); } void POMP2_Critical_enter( POMP2_Region_handle* pomp2_handle __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_CRITICAL_ENTER); } void POMP2_Critical_exit( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_CRITICAL_EXIT); } void POMP2_Master_begin( POMP2_Region_handle* pomp2_handle __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_MASTER_BEGIN); } void POMP2_Master_end(POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_MASTER_END); } void POMP2_Parallel_fork( POMP2_Region_handle* pomp2_handle __attribute__((unused)), int if_clause __attribute__((unused)), int num_threads __attribute__((unused)), POMP2_Task_handle* pomp2_old_task __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; *pomp2_handle = _next_section_id++; POMP2_Region_handle section_id = *pomp2_handle; EZTRACE_EVENT_PACKED_1(EZTRACE_GOMP_PARALLEL_START, section_id); } void POMP2_Parallel_join( POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle pomp2_old_task __attribute__((unused))) { /* the runtime function GOMP_parallel end already records an event at the end * of a join. We don't need to do anuthing here. */ /* todo: what about non-GNU OpenMP ? */ } void POMP2_For_enter(POMP2_Region_handle* pomp2_handle __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_FOR_ENTER); } void POMP2_For_exit(POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_FOR_EXIT); } void POMP2_Parallel_begin( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; int nb_threads = omp_get_num_threads(); int my_id = omp_get_thread_num(); POMP2_Region_handle section_id = *pomp2_handle; EZTRACE_EVENT_PACKED_3(EZTRACE_GOMP_NEW_FORK, section_id, my_id, nb_threads); } void POMP2_Parallel_end( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; int my_id = omp_get_thread_num(); EZTRACE_EVENT_PACKED_1(EZTRACE_GOMP_NEW_JOIN, my_id); } void POMP2_Section_begin( POMP2_Region_handle* pomp2_handle __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_SECTION_BEGIN); } void POMP2_Section_end( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_SECTION_END); } void POMP2_Sections_enter( POMP2_Region_handle* pomp2_handle __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_SECTIONS_ENTER); } void POMP2_Sections_exit( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_SECTIONS_EXIT); } void POMP2_Single_begin( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_SINGLE_BEGIN); } void POMP2_Single_end(POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_SINGLE_END); } void POMP2_Single_enter( POMP2_Region_handle* pomp2_handle __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_SINGLE_ENTER); } void POMP2_Single_exit( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_SINGLE_EXIT); } void POMP2_Workshare_enter( POMP2_Region_handle* pomp2_handle __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_WORKSHARE_ENTER); } void POMP2_Workshare_exit( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_WORKSHARE_EXIT); } void POMP2_Ordered_begin( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { /** Called at the start of an ordered region. @param pomp2_handle The handle of the region. */ FUNCTION_ENTRY; // todo : EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_ORDERED_BEGIN); } void POMP2_Ordered_end( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { /* todo: implement that */ } void POMP2_Ordered_enter( POMP2_Region_handle* pomp2_handle __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { /* todo: implement that */ } void POMP2_Ordered_exit( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { /* todo: implement that */ } /** \e OpenMP \e 3.0: When a task encounters a task construct it creates a new task. The task may be scheduled for later execution or executed immediately. In both cases the pomp-adapter assigns the id of the currently active task to \e pomp2_old_task which is defined in the instrumented user code. @param pomp2_handle The handle of the region. @param pomp2_old_task Pointer to the task id in the instrumented user code @param pomp2_if If an if clause is present on the task directive this variable holds the evaluated result of the argument of the if clause. Else it is 1. @param ctc_string The initialization string. */ void POMP2_Task_create_begin( POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle* pomp2_new_task __attribute__((unused)), POMP2_Task_handle* pomp2_old_task __attribute__((unused)), int pomp2_if __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; /* we could use pomp2_new_task to store the task id, but this would require a mutex * (or at least an atomic increment primitive) that would kill the performance. * In order to keep the overhead as low as possible, let's only record the event. */ EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_TASK_CREATE_BEGIN); } void POMP2_Task_create_end( POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle pomp2_old_task __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_TASK_CREATE_END); } void POMP2_Task_begin(POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle pomp2_task __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_TASK_BEGIN); } void POMP2_Task_end(POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_TASK_END); } void POMP2_Untied_task_create_begin( POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle* pomp2_new_task __attribute__((unused)), POMP2_Task_handle* pomp2_old_task __attribute__((unused)), int pomp2_if __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; /* we could use pomp2_new_task to store the task id, but this would require a mutex * (or at least an atomic increment primitive) that would kill the performance. * In order to keep the overhead as low as possible, let's only record the event. */ EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_UNTIED_TASK_CREATE_BEGIN); } void POMP2_Untied_task_create_end( POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle pomp2_old_task __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_UNTIED_TASK_CREATE_END); } void POMP2_Untied_task_begin( POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle pomp2_parent_task __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_UNTIED_TASK_BEGIN); } void POMP2_Untied_task_end( POMP2_Region_handle* pomp2_handle __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_UNTIED_TASK_END); } void POMP2_Taskwait_begin( POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle* pomp2_old_task __attribute__((unused)), const char ctc_string[] __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_TASKWAIT_BEGIN); } void POMP2_Taskwait_end( POMP2_Region_handle* pomp2_handle __attribute__((unused)), POMP2_Task_handle pomp2_old_task __attribute__((unused))) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_POMP2_TASKWAIT_END); } #ifdef OPENMP_FOUND void POMP2_Init_lock( omp_lock_t* s ) { omp_init_lock(s); } void POMP2_Destroy_lock( omp_lock_t* s ) { omp_destroy_lock(s); } void POMP2_Set_lock( omp_lock_t* s ) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_1(EZTRACE_POMP2_SET_LOCK_ENTRY, s); omp_set_lock(s); EZTRACE_EVENT_PACKED_1(EZTRACE_POMP2_SET_LOCK_EXIT, s); } void POMP2_Unset_lock( omp_lock_t* s ) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_1(EZTRACE_POMP2_UNSET_LOCK, s); omp_unset_lock(s); } int POMP2_Test_lock( omp_lock_t* s ) { int ret = omp_test_lock(s); if(ret) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_1(EZTRACE_POMP2_TEST_LOCK_SUCCESS, s); } return ret; } void POMP2_Init_nest_lock( omp_nest_lock_t* s ) { omp_init_nest_lock(s); } void POMP2_Destroy_nest_lock( omp_nest_lock_t* s ) { omp_destroy_nest_lock(s); } void POMP2_Set_nest_lock( omp_nest_lock_t* s ) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_1(EZTRACE_POMP2_SET_NEST_LOCK_ENTRY, s); omp_set_nest_lock(s); EZTRACE_EVENT_PACKED_1(EZTRACE_POMP2_SET_NEST_LOCK_EXIT, s); } void POMP2_Unset_nest_lock( omp_nest_lock_t* s ) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_1(EZTRACE_POMP2_UNSET_NEST_LOCK, s); omp_unset_nest_lock(s); } int POMP2_Test_nest_lock( omp_nest_lock_t* s ) { int ret = omp_test_nest_lock(s); if(ret) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_1(EZTRACE_POMP2_TEST_NEST_LOCK_SUCCESS, s); } return ret; } #endif /* OPENMP_FOUND */ void (*libPOMP2_Finalize)(); START_INTERCEPT_MODULE(omp) INTERCEPT2("GOMP_parallel_start", libGOMP_parallel_start) INTERCEPT2("GOMP_parallel_end", libGOMP_parallel_end) INTERCEPT2("GOMP_parallel_loop_static_start", libGOMP_parallel_loop_static_start) INTERCEPT2("GOMP_parallel_loop_runtime_start", libGOMP_parallel_loop_runtime_start) INTERCEPT2("GOMP_parallel_loop_dynamic_start", libGOMP_parallel_loop_dynamic_start) INTERCEPT2("GOMP_parallel_loop_guided_start", libGOMP_parallel_loop_guided_start) INTERCEPT2("GOMP_critical_start", libGOMP_critical_start) INTERCEPT2("GOMP_critical_end", libGOMP_critical_end) INTERCEPT2("GOMP_parallel_loop_static", libGOMP_parallel_loop_static) INTERCEPT2("GOMP_parallel_loop_dynamic",libGOMP_parallel_loop_dynamic) INTERCEPT2("GOMP_parallel_loop_guided", libGOMP_parallel_loop_guided) INTERCEPT2("GOMP_parallel_loop_runtime",libGOMP_parallel_loop_runtime) END_INTERCEPT_MODULE(omp) void __gomp_init(void) __attribute__ ((constructor)); void __gomp_init(void) { DYNAMIC_INTERCEPT_ALL_MODULE(omp); /* This symbol is only available if the program was compiled with eztrace_cc. * Use this information as a test and print a warning message. */ INTERCEPT("POMP2_Finalize", libPOMP2_Finalize); if (libGOMP_critical_end && !libPOMP2_Finalize) { printf( "Only GNU OpenMP runtime functions will be intercepted. For a more precise trace, please instrument your program with eztrace_cc.\n"); use_pomp = 0; } if (libPOMP2_Finalize) pomp2_found = 1; else pomp2_found = 0; #ifdef EZTRACE_AUTOSTART eztrace_start (); #endif } void __gomp_conclude(void) __attribute__ ((destructor)); void __gomp_conclude(void) { eztrace_stop(); } eztrace-1.1-2/src/modules/omp/gomp_ev_codes.h000066400000000000000000000106431265506773700212110ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef __GOMP_EV_CODES_H__ #define __GOMP_EV_CODES_H__ #include "ev_codes.h" #define EZTRACE_GOMP_EVENTS_ID SYSTEM_MODULE_ID(0x01) #define EZTRACE_GOMP_PREFIX GENERATE_SYSTEM_MODULE_PREFIX(EZTRACE_GOMP_EVENTS_ID) #define EZTRACE_GOMP_PARALLEL_START (EZTRACE_GOMP_PREFIX | 0x0001) #define EZTRACE_GOMP_NEW_FORK (EZTRACE_GOMP_PREFIX | 0x0002) #define EZTRACE_GOMP_NEW_JOIN (EZTRACE_GOMP_PREFIX | 0x0003) #define EZTRACE_GOMP_JOIN_DONE (EZTRACE_GOMP_PREFIX | 0x0004) #define EZTRACE_GOMP_CRITICAL_START (EZTRACE_GOMP_PREFIX | 0x0005) #define EZTRACE_GOMP_CRITICAL_START_DONE (EZTRACE_GOMP_PREFIX | 0x0006) #define EZTRACE_GOMP_CRITICAL_STOP (EZTRACE_GOMP_PREFIX | 0x0007) #define EZTRACE_POMP2_FINALIZE (EZTRACE_GOMP_PREFIX | 0xffff) #define EZTRACE_POMP2_ATOMIC_ENTER (EZTRACE_GOMP_PREFIX | 0x0010) #define EZTRACE_POMP2_ATOMIC_EXIT (EZTRACE_GOMP_PREFIX | 0x0011) #define EZTRACE_POMP2_BARRIER_ENTER (EZTRACE_GOMP_PREFIX | 0x0020) #define EZTRACE_POMP2_BARRIER_EXIT (EZTRACE_GOMP_PREFIX | 0x0021) #define EZTRACE_POMP2_IMPLICIT_BARRIER_ENTER (EZTRACE_GOMP_PREFIX | 0x0022) #define EZTRACE_POMP2_IMPLICIT_BARRIER_EXIT (EZTRACE_GOMP_PREFIX | 0x0023) #define EZTRACE_POMP2_FLUSH_ENTER (EZTRACE_GOMP_PREFIX | 0x0030) #define EZTRACE_POMP2_FLUSH_EXIT (EZTRACE_GOMP_PREFIX | 0x0031) #define EZTRACE_POMP2_CRITICAL_ENTER (EZTRACE_GOMP_PREFIX | 0x0040) #define EZTRACE_POMP2_CRITICAL_EXIT (EZTRACE_GOMP_PREFIX | 0x0041) #define EZTRACE_POMP2_CRITICAL_BEGIN (EZTRACE_GOMP_PREFIX | 0x0042) #define EZTRACE_POMP2_CRITICAL_END (EZTRACE_GOMP_PREFIX | 0x0043) #define EZTRACE_POMP2_FOR_ENTER (EZTRACE_GOMP_PREFIX | 0x0050) #define EZTRACE_POMP2_FOR_EXIT (EZTRACE_GOMP_PREFIX | 0x0051) #define EZTRACE_POMP2_MASTER_BEGIN (EZTRACE_GOMP_PREFIX | 0x0060) #define EZTRACE_POMP2_MASTER_END (EZTRACE_GOMP_PREFIX | 0x0061) #define EZTRACE_POMP2_PARALLEL_BEGIN (EZTRACE_GOMP_PREFIX | 0x0070) #define EZTRACE_POMP2_PARALLEL_END (EZTRACE_GOMP_PREFIX | 0x0071) #define EZTRACE_POMP2_PARALLEL_FORK (EZTRACE_GOMP_PREFIX | 0x0072) #define EZTRACE_POMP2_PARALLEL_JOIN (EZTRACE_GOMP_PREFIX | 0x0073) #define EZTRACE_POMP2_SECTIONS_ENTER (EZTRACE_GOMP_PREFIX | 0x0080) #define EZTRACE_POMP2_SECTIONS_EXIT (EZTRACE_GOMP_PREFIX | 0x0081) #define EZTRACE_POMP2_SECTION_BEGIN (EZTRACE_GOMP_PREFIX | 0x0082) #define EZTRACE_POMP2_SECTION_END (EZTRACE_GOMP_PREFIX | 0x0083) #define EZTRACE_POMP2_SINGLE_ENTER (EZTRACE_GOMP_PREFIX | 0x0090) #define EZTRACE_POMP2_SINGLE_EXIT (EZTRACE_GOMP_PREFIX | 0x0091) #define EZTRACE_POMP2_SINGLE_BEGIN (EZTRACE_GOMP_PREFIX | 0x0092) #define EZTRACE_POMP2_SINGLE_END (EZTRACE_GOMP_PREFIX | 0x0093) #define EZTRACE_POMP2_WORKSHARE_ENTER (EZTRACE_GOMP_PREFIX | 0x00a0) #define EZTRACE_POMP2_WORKSHARE_EXIT (EZTRACE_GOMP_PREFIX | 0x00a1) #define EZTRACE_POMP2_TASK_BEGIN (EZTRACE_GOMP_PREFIX | 0x00b0) #define EZTRACE_POMP2_TASK_END (EZTRACE_GOMP_PREFIX | 0x00b1) #define EZTRACE_POMP2_TASK_CREATE_BEGIN (EZTRACE_GOMP_PREFIX | 0x00b2) #define EZTRACE_POMP2_TASK_CREATE_END (EZTRACE_GOMP_PREFIX | 0x00b3) #define EZTRACE_POMP2_UNTIED_TASK_BEGIN (EZTRACE_GOMP_PREFIX | 0x00b4) #define EZTRACE_POMP2_UNTIED_TASK_END (EZTRACE_GOMP_PREFIX | 0x00b5) #define EZTRACE_POMP2_UNTIED_TASK_CREATE_BEGIN (EZTRACE_GOMP_PREFIX | 0x00b6) #define EZTRACE_POMP2_UNTIED_TASK_CREATE_END (EZTRACE_GOMP_PREFIX | 0x00b7) #define EZTRACE_POMP2_TASKWAIT_BEGIN (EZTRACE_GOMP_PREFIX | 0x00b8) #define EZTRACE_POMP2_TASKWAIT_END (EZTRACE_GOMP_PREFIX | 0x00b9) #define EZTRACE_POMP2_TASK_INFO (EZTRACE_GOMP_PREFIX | 0x00ba) #ifdef OPENMP_FOUND #define EZTRACE_POMP2_SET_LOCK_ENTRY (EZTRACE_GOMP_PREFIX | 0x0101) #define EZTRACE_POMP2_SET_LOCK_EXIT (EZTRACE_GOMP_PREFIX | 0x0102) #define EZTRACE_POMP2_TEST_LOCK_SUCCESS (EZTRACE_GOMP_PREFIX | 0x0103) #define EZTRACE_POMP2_UNSET_LOCK (EZTRACE_GOMP_PREFIX | 0x0104) #define EZTRACE_POMP2_SET_NEST_LOCK_ENTRY (EZTRACE_GOMP_PREFIX | 0x0111) #define EZTRACE_POMP2_SET_NEST_LOCK_EXIT (EZTRACE_GOMP_PREFIX | 0x0112) #define EZTRACE_POMP2_TEST_NEST_LOCK_SUCCESS (EZTRACE_GOMP_PREFIX | 0x0113) #define EZTRACE_POMP2_UNSET_NEST_LOCK (EZTRACE_GOMP_PREFIX | 0x0114) #endif /* OPENMP_FOUND */ #endif /* __GOMP_EV_CODES_H__ */ eztrace-1.1-2/src/modules/papi/000077500000000000000000000000001265506773700163615ustar00rootroot00000000000000eztrace-1.1-2/src/modules/papi/Makefile.am000066400000000000000000000030011265506773700204070ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. TLCFLAGS=$(TL_CPPFLAGS) TLLDFLAGS=$(TL_LDFLAGS) TLLIBADD=$(TL_LIB) GTGCFLAGS=$(GTG_CPPFLAGS) GTGLDFLAGS=$(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD=$(GTG_LIB) if USE_PAPI lib_LTLIBRARIES = libeztrace-convert-papi.la \ libeztrace-papi.la \ libeztrace-autostart-papi.la AM_CFLAGS = -W -Wall -Wextra -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ -I$(top_srcdir)/src/pptrace libeztrace_convert_papi_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) $(PAPI_CPPFLAGS) libeztrace_convert_papi_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) -lpapi libeztrace_convert_papi_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) $(PAPI_LDFLAGS) libeztrace_convert_papi_la_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace_convert_papi_la_SOURCES = eztrace_convert_papi.c libeztrace_papi_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(PAPI_CPPFLAGS) libeztrace_papi_la_LIBADD = $(TLLIBADD) -lpapi libeztrace_papi_la_LDFLAGS = --no-undefined $(TLLDFLAGS) $(PAPI_LDFLAGS) libeztrace_papi_la_SOURCES = papi.c libeztrace_autostart_papi_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(PAPI_CPPFLAGS) libeztrace_autostart_papi_la_LIBADD = $(TLLIBADD) -lpapi libeztrace_autostart_papi_la_LDFLAGS = --no-undefined $(TLLDFLAGS) $(PAPI_LDFLAGS) libeztrace_autostart_papi_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra -DEZTRACE_AUTOSTART libeztrace_autostart_papi_la_SOURCES = papi.c noinst_HEADERS = papi_ev_codes.h endif # USE_PAPI eztrace-1.1-2/src/modules/papi/Makefile.in000066400000000000000000000731421265506773700204350ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = src/modules/papi ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__noinst_HEADERS_DIST) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(libdir)" LTLIBRARIES = $(lib_LTLIBRARIES) am__DEPENDENCIES_1 = am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) @USE_PAPI_TRUE@libeztrace_autostart_papi_la_DEPENDENCIES = \ @USE_PAPI_TRUE@ $(am__DEPENDENCIES_2) am__libeztrace_autostart_papi_la_SOURCES_DIST = papi.c @USE_PAPI_TRUE@am_libeztrace_autostart_papi_la_OBJECTS = \ @USE_PAPI_TRUE@ libeztrace_autostart_papi_la-papi.lo libeztrace_autostart_papi_la_OBJECTS = \ $(am_libeztrace_autostart_papi_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libeztrace_autostart_papi_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(libeztrace_autostart_papi_la_CFLAGS) $(CFLAGS) \ $(libeztrace_autostart_papi_la_LDFLAGS) $(LDFLAGS) -o $@ @USE_PAPI_TRUE@am_libeztrace_autostart_papi_la_rpath = -rpath \ @USE_PAPI_TRUE@ $(libdir) am__libeztrace_convert_papi_la_SOURCES_DIST = eztrace_convert_papi.c @USE_PAPI_TRUE@am_libeztrace_convert_papi_la_OBJECTS = libeztrace_convert_papi_la-eztrace_convert_papi.lo libeztrace_convert_papi_la_OBJECTS = \ $(am_libeztrace_convert_papi_la_OBJECTS) libeztrace_convert_papi_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_convert_papi_la_LDFLAGS) \ $(LDFLAGS) -o $@ @USE_PAPI_TRUE@am_libeztrace_convert_papi_la_rpath = -rpath $(libdir) @USE_PAPI_TRUE@libeztrace_papi_la_DEPENDENCIES = \ @USE_PAPI_TRUE@ $(am__DEPENDENCIES_2) am__libeztrace_papi_la_SOURCES_DIST = papi.c @USE_PAPI_TRUE@am_libeztrace_papi_la_OBJECTS = \ @USE_PAPI_TRUE@ libeztrace_papi_la-papi.lo libeztrace_papi_la_OBJECTS = $(am_libeztrace_papi_la_OBJECTS) libeztrace_papi_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_papi_la_LDFLAGS) \ $(LDFLAGS) -o $@ @USE_PAPI_TRUE@am_libeztrace_papi_la_rpath = -rpath $(libdir) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libeztrace_autostart_papi_la_SOURCES) \ $(libeztrace_convert_papi_la_SOURCES) \ $(libeztrace_papi_la_SOURCES) DIST_SOURCES = $(am__libeztrace_autostart_papi_la_SOURCES_DIST) \ $(am__libeztrace_convert_papi_la_SOURCES_DIST) \ $(am__libeztrace_papi_la_SOURCES_DIST) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__noinst_HEADERS_DIST = papi_ev_codes.h HEADERS = $(noinst_HEADERS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ TLCFLAGS = $(TL_CPPFLAGS) TLLDFLAGS = $(TL_LDFLAGS) TLLIBADD = $(TL_LIB) GTGCFLAGS = $(GTG_CPPFLAGS) GTGLDFLAGS = $(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD = $(GTG_LIB) @USE_PAPI_TRUE@lib_LTLIBRARIES = libeztrace-convert-papi.la \ @USE_PAPI_TRUE@ libeztrace-papi.la \ @USE_PAPI_TRUE@ libeztrace-autostart-papi.la @USE_PAPI_TRUE@AM_CFLAGS = -W -Wall -Wextra -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ @USE_PAPI_TRUE@ -I$(top_srcdir)/src/pptrace @USE_PAPI_TRUE@libeztrace_convert_papi_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) $(PAPI_CPPFLAGS) @USE_PAPI_TRUE@libeztrace_convert_papi_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) -lpapi @USE_PAPI_TRUE@libeztrace_convert_papi_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) $(PAPI_LDFLAGS) @USE_PAPI_TRUE@libeztrace_convert_papi_la_DEPENDENCIES = $(GTGDEPENDENCIES) @USE_PAPI_TRUE@libeztrace_convert_papi_la_SOURCES = eztrace_convert_papi.c @USE_PAPI_TRUE@libeztrace_papi_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(PAPI_CPPFLAGS) @USE_PAPI_TRUE@libeztrace_papi_la_LIBADD = $(TLLIBADD) -lpapi @USE_PAPI_TRUE@libeztrace_papi_la_LDFLAGS = --no-undefined $(TLLDFLAGS) $(PAPI_LDFLAGS) @USE_PAPI_TRUE@libeztrace_papi_la_SOURCES = papi.c @USE_PAPI_TRUE@libeztrace_autostart_papi_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(PAPI_CPPFLAGS) @USE_PAPI_TRUE@libeztrace_autostart_papi_la_LIBADD = $(TLLIBADD) -lpapi @USE_PAPI_TRUE@libeztrace_autostart_papi_la_LDFLAGS = --no-undefined $(TLLDFLAGS) $(PAPI_LDFLAGS) @USE_PAPI_TRUE@libeztrace_autostart_papi_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra -DEZTRACE_AUTOSTART @USE_PAPI_TRUE@libeztrace_autostart_papi_la_SOURCES = papi.c @USE_PAPI_TRUE@noinst_HEADERS = papi_ev_codes.h all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/modules/papi/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu src/modules/papi/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ } uninstall-libLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ done clean-libLTLIBRARIES: -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) @list='$(lib_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libeztrace-autostart-papi.la: $(libeztrace_autostart_papi_la_OBJECTS) $(libeztrace_autostart_papi_la_DEPENDENCIES) $(EXTRA_libeztrace_autostart_papi_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_autostart_papi_la_LINK) $(am_libeztrace_autostart_papi_la_rpath) $(libeztrace_autostart_papi_la_OBJECTS) $(libeztrace_autostart_papi_la_LIBADD) $(LIBS) libeztrace-convert-papi.la: $(libeztrace_convert_papi_la_OBJECTS) $(libeztrace_convert_papi_la_DEPENDENCIES) $(EXTRA_libeztrace_convert_papi_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_convert_papi_la_LINK) $(am_libeztrace_convert_papi_la_rpath) $(libeztrace_convert_papi_la_OBJECTS) $(libeztrace_convert_papi_la_LIBADD) $(LIBS) libeztrace-papi.la: $(libeztrace_papi_la_OBJECTS) $(libeztrace_papi_la_DEPENDENCIES) $(EXTRA_libeztrace_papi_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_papi_la_LINK) $(am_libeztrace_papi_la_rpath) $(libeztrace_papi_la_OBJECTS) $(libeztrace_papi_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_autostart_papi_la-papi.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_papi_la-eztrace_convert_papi.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_papi_la-papi.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< libeztrace_autostart_papi_la-papi.lo: papi.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_papi_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_papi_la_CFLAGS) $(CFLAGS) -MT libeztrace_autostart_papi_la-papi.lo -MD -MP -MF $(DEPDIR)/libeztrace_autostart_papi_la-papi.Tpo -c -o libeztrace_autostart_papi_la-papi.lo `test -f 'papi.c' || echo '$(srcdir)/'`papi.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_autostart_papi_la-papi.Tpo $(DEPDIR)/libeztrace_autostart_papi_la-papi.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='papi.c' object='libeztrace_autostart_papi_la-papi.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_papi_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_papi_la_CFLAGS) $(CFLAGS) -c -o libeztrace_autostart_papi_la-papi.lo `test -f 'papi.c' || echo '$(srcdir)/'`papi.c libeztrace_convert_papi_la-eztrace_convert_papi.lo: eztrace_convert_papi.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_papi_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_papi_la-eztrace_convert_papi.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_papi_la-eztrace_convert_papi.Tpo -c -o libeztrace_convert_papi_la-eztrace_convert_papi.lo `test -f 'eztrace_convert_papi.c' || echo '$(srcdir)/'`eztrace_convert_papi.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_papi_la-eztrace_convert_papi.Tpo $(DEPDIR)/libeztrace_convert_papi_la-eztrace_convert_papi.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_papi.c' object='libeztrace_convert_papi_la-eztrace_convert_papi.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_papi_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_papi_la-eztrace_convert_papi.lo `test -f 'eztrace_convert_papi.c' || echo '$(srcdir)/'`eztrace_convert_papi.c libeztrace_papi_la-papi.lo: papi.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_papi_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_papi_la-papi.lo -MD -MP -MF $(DEPDIR)/libeztrace_papi_la-papi.Tpo -c -o libeztrace_papi_la-papi.lo `test -f 'papi.c' || echo '$(srcdir)/'`papi.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_papi_la-papi.Tpo $(DEPDIR)/libeztrace_papi_la-papi.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='papi.c' object='libeztrace_papi_la-papi.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_papi_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_papi_la-papi.lo `test -f 'papi.c' || echo '$(srcdir)/'`papi.c mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) $(HEADERS) installdirs: for dir in "$(DESTDIR)$(libdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-libLTLIBRARIES install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-libLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libLTLIBRARIES clean-libtool cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-libLTLIBRARIES install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-libLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/src/modules/papi/eztrace_convert_papi.c000066400000000000000000000113111265506773700227300ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include #include #include "eztrace_convert.h" #include "papi_ev_codes.h" #include "eztrace_list.h" static int recording_stats = 0; #define PAPI_CHANGE() if(!recording_stats) CHANGE() static int nb_papi_counters = 0; struct __papi_counter_info { int counter_code; char* gtg_alias; char* gtg_desc; uint64_t sum_counters; double total_duration; }; static struct __papi_counter_info *counters_info; void handle_papi_event() { if (!STARTED) return; FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); int index; long_long counter_diff; int duration; GET_PARAM_PACKED_3(CUR_EV, index, counter_diff, duration); counters_info[index].sum_counters += counter_diff; counters_info[index].total_duration += duration; PAPI_CHANGE() setVar(CURRENT, counters_info[index].gtg_alias, thread_id, counter_diff); } void handle_papi_init() { FUNC_NAME; /* if using MPI + PAPI, papi is initialized once per process */ static int already_initialized = 0; int i; int nb_counters; GET_PARAM_PACKED_1(CUR_EV, nb_counters); if (already_initialized) { /* make sure all the processes use the same counters */ assert(nb_counters == nb_papi_counters); } nb_papi_counters = nb_counters; if(!already_initialized) counters_info = malloc(nb_papi_counters*sizeof(struct __papi_counter_info)); /* if using MPI, we still need to process the following events (the ones that define the PAPI * codes to use). */ for(i=0; iid, EZTRACE_PAPI_INIT_COUNTERS); int index; int event_code; GET_PARAM_PACKED_2(CUR_EV, index, event_code); assert(index == i); wait_for_an_event(CUR_TRACE->id, EZTRACE_PAPI_INIT_COUNTERS); /* get the name of the counter */ assert(LITL_READ_GET_TYPE(CUR_EV) == LITL_TYPE_RAW); char* name = NULL; asprintf(&name, "%s", LITL_READ_RAW(CUR_EV)->data); wait_for_an_event(CUR_TRACE->id, EZTRACE_PAPI_INIT_COUNTERS); /* get the unit of the counter */ assert(LITL_READ_GET_TYPE(CUR_EV) == LITL_TYPE_RAW); char* units = NULL; asprintf(&units, "%s", LITL_READ_RAW(CUR_EV)->data); if(already_initialized) { /* make sure all the processes use the same counters */ assert(counters_info[i].counter_code == event_code); /* we don't need to do the remaining */ continue; } counters_info[i].counter_code = event_code; counters_info[i].gtg_desc = NULL; asprintf(&(counters_info[i].gtg_desc), "%s (%s per second)", name, units); counters_info[i].gtg_alias = name; counters_info[i].sum_counters = 0; counters_info[i].total_duration = 0; if(get_mode() == EZTRACE_CONVERT) { addVarType (counters_info[i].gtg_alias, counters_info[i].gtg_desc, "CT_Thread"); } } if(nb_papi_counters) already_initialized = 1; } int eztrace_convert_papi_init() { if (get_mode() == EZTRACE_CONVERT) { addVarType("V_L3miss", "L3 Misses", "CT_Thread"); } return 0; } /* return 1 if the event was handled */ int handle_papi_events(eztrace_event_t *ev) { switch (LITL_READ_GET_CODE(ev)) { case EZTRACE_PAPI_INIT: handle_papi_init(); break; case EZTRACE_PAPI_MEASUREMENT: handle_papi_event(); break; default: return 0; } return 1; } int handle_papi_stats(eztrace_event_t *ev) { recording_stats = 1; return handle_papi_events(ev); } void print_papi_stats() { printf("\nPAPI:\n"); printf("-------\n"); int i; for (i = 0; i < nb_papi_counters; i++) { printf("average %s: %lf\n", counters_info[i].gtg_desc, counters_info[i].sum_counters / counters_info[i].total_duration); } } struct eztrace_convert_module papi_module; void libinit(void) __attribute__ ((constructor)); void libinit(void) { papi_module.api_version = EZTRACE_API_VERSION; papi_module.init = eztrace_convert_papi_init; papi_module.handle = handle_papi_events; papi_module.handle_stats = handle_papi_stats; papi_module.print_stats = print_papi_stats; papi_module.module_prefix = EZTRACE_PAPI_EVENTS_ID; asprintf(&papi_module.name, "papi"); asprintf(&papi_module.description, "Module for PAPI Performance counters"); papi_module.token.data = &papi_module; eztrace_convert_register_module(&papi_module); int ret = PAPI_library_init(PAPI_VER_CURRENT); if (ret != PAPI_VER_CURRENT && ret > 0) { fprintf(stderr, "PAPI library version mismatch!\n"); exit(1); } __papi_init_counter_ids(); } void libfinalize(void) __attribute__ ((destructor)); void libfinalize(void) { } eztrace-1.1-2/src/modules/papi/papi.c000066400000000000000000000223741265506773700174660ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 /* or _BSD_SOURCE or _SVID_SOURCE */ #define _REENTRANT #include #include #include #include #include #include #include #include #include "eztrace_sampling.h" #include "papi_ev_codes.h" #include "eztrace.h" /* set to 1 when all the hooks are set. * This is usefull in order to avoid recursive calls */ static int __papi_initialized = 0; //#define VERBOSE 1 /* We don't use the FUNCTION_NAME macro (defined in src/core/eztrace.h) * to avoid infinite loops (since it calls record_counters). */ #ifdef FUNCTION_NAME #undef FUNCTION_NAME #endif #ifdef VERBOSE #define FUNCTION_NAME fprintf(stderr, "Calling [%s]\n", __FUNCTION__) #else #define FUNCTION_NAME (void) 0 #endif #define TIME_DIFF(t1, t2) \ ((t2.tv_sec - t1.tv_sec) * 1000000 + (t2.tv_usec - t1.tv_usec)) static pthread_key_t papi_thread_info_key; struct __papi_thread_info { int Events; long_long *values; struct timeval last_tick; }; static int nb_events; static int Events; static int* Event_codes; static char** Event_names; static char** units_names; struct __papi_thread_info * papi_init_hw_counter(); #define handle_error(n) \ fprintf(stderr, "%s: PAPI error %d: %s\n",__FUNCTION__, n,PAPI_strerror(n)) int papi_record(struct ezt_sampling_callback_instance *instance) { if (!__papi_initialized || !nb_events) return 0; struct __papi_thread_info *ptr = NULL; struct timeval cur_tick; gettimeofday(&cur_tick, NULL ); /* retrieve the thread-specific structure */ if(! instance->plugin_data) { ptr = papi_init_hw_counter(instance); if (!ptr) { return -1; } } ptr = instance->plugin_data; /* read hardware counter */ // this region needs to be protected in order to disable infinite recursion due to the intercepting of functions. // Because, PAPI functions can possibly be intercepted too. EZTRACE_PROTECT { EZTRACE_PROTECT_ON(); int ret; /* get the values of counters */ if ((ret = PAPI_stop(ptr->Events, ptr->values)) != PAPI_OK) { handle_error(ret); abort(); } /* restart counters */ ret = PAPI_start(ptr->Events); if(ret != PAPI_OK) { handle_error(ret); abort(); } int duration = TIME_DIFF(instance->last_call, cur_tick); /* duration in usec */ int i; for (i = 0; i < nb_events; i++) { // As this region is protected, the unprotected function is called EZTRACE_EVENT3_PACKED_UNPROTECTED(EZTRACE_PAPI_MEASUREMENT, i, ptr->values[i], duration); } /* reset the timer */ instance->last_call.tv_usec = cur_tick.tv_usec; instance->last_call.tv_sec = cur_tick.tv_sec; EZTRACE_PROTECT_OFF(); return 0; } return 1; } /* Initialize the PAPI counter interface for a thread */ struct __papi_thread_info * papi_init_hw_counter(struct ezt_sampling_callback_instance *instance) { if (!nb_events) /* no counter were selected. We don't need to do anything */ return NULL; struct __papi_thread_info *ptr = NULL; // this region needs to be protected in order to disable infinite recursion due to the intercepting of functions. // Because, PAPI functions can possibly be intercepted too. EZTRACE_PROTECT { EZTRACE_PROTECT_ON(); int ret; /* initialize the thread-specific structure */ if (instance->plugin_data == NULL ) { /* This thread has not been initialized yet */ PAPI_register_thread(); ptr = malloc(sizeof(struct __papi_thread_info)); ptr->values = malloc(sizeof(long_long) * nb_events); int i; /* Create a new EventSet */ ptr->Events = PAPI_NULL; ret = PAPI_create_eventset(&ptr->Events); if(ret != PAPI_OK) { handle_error(ret); abort(); } /* copy Events to the EventSet */ for (i = 0; i < nb_events; i++) { ret = PAPI_add_event( ptr->Events, Event_codes[i] ); if(ret != PAPI_OK) { handle_error(ret); abort(); } } /* Start the counter */ if ((ret = PAPI_start(ptr->Events)) != PAPI_OK) { if (ret == PAPI_ECNFLCT) { fprintf(stderr, "PAPI error %d (%s): It is likely that you selected too many counters to monitor\n", ret, PAPI_strerror(ret)); exit(-1); } } /* set the structure Thread-specific */ instance->plugin_data = ptr; /* first measurement */ gettimeofday(&instance->last_call, NULL ); int retval = PAPI_stop( ptr->Events, ptr->values); if (retval != PAPI_OK) { fprintf(stderr, "PAPI_stop() failed\n"); } retval = PAPI_start(ptr->Events); if (retval != PAPI_OK) { fprintf(stderr,"PAPI_start() failed\n"); exit(1); } } EZTRACE_PROTECT_OFF(); } return ptr; } static int __papi_add_counter(char* counter_name) { nb_events++; Event_codes = realloc(Event_codes, sizeof(int) * nb_events); Event_names = realloc(Event_names, sizeof(char*) * nb_events); units_names = realloc(units_names, sizeof(char*) * nb_events); int code; int retval; if ( (retval = PAPI_event_name_to_code( counter_name, &code )) == PAPI_OK ) { retval = PAPI_add_event( Events, code ); if (retval != PAPI_OK) { handle_error(retval); nb_events--; return retval; } else { #if PAPI_VERSION > PAPI_VERSION_NUMBER(5,0,0,0) PAPI_event_info_t info; retval = PAPI_get_event_info(code, &info); if (retval != PAPI_OK) { /* PAPI_get_event_info failed. Let's assume there is no unit */ handle_error(retval); asprintf(&units_names[nb_events-1], " "); } else { asprintf(&units_names[nb_events-1], "%s", info.units); } #else asprintf(&units_names[nb_events-1], " "); #endif Event_codes[nb_events-1] = code; asprintf(&Event_names[nb_events-1], "%s", counter_name); return PAPI_OK; } } handle_error(retval); nb_events--; return retval; } /* select the counters to monitor */ static void __papi_select_counters() { int invalid_counters = 0; char* env1 = getenv("EZTRACE_PAPI_COUNTERS"); nb_events = 0; Events = PAPI_NULL; if ( PAPI_create_eventset( &Events ) != PAPI_OK ) { abort(); } if (env1) { /* EZTRACE_PAPI_COUNTERS is defined */ /* strtok may modify env, so let's make a copy of it */ char* env; asprintf(&env, "%s", env1); char *token = strtok(env, " "); /* for each token, get the code id and fill the Events array */ while (token) { if(__papi_add_counter(token) != PAPI_OK) { invalid_counters = 1; } token = strtok(NULL, " "); } } else { /* EZTRACE_PAPI_COUNTERS is not defined, use the default values */ __papi_add_counter("PAPI_TOT_INS"); } if (invalid_counters) { fprintf(stderr, "Available counters:\n"); __papi_print_available_counters(); } } /* In some cases (eg. using -O3 with gcc), the compiler may optimize too agressively and remove the function array symbol. * This results in pptrace being unable to load the module (since the symbol is not found). * This can be "solved" by declaring 2 callbacks to avoid the compiler optimization */ void (*libfoo)(void*); void (*libfoo2)(void*); START_INTERCEPT_MODULE(papi) INTERCEPT2("foo", libfoo) INTERCEPT2("foo2", libfoo2) END_INTERCEPT_MODULE(papi) static void __papi_init(void) __attribute__ ((constructor)); static void __papi_init(void) { DYNAMIC_INTERCEPT_ALL_MODULE(papi); int ret; pthread_key_create(&papi_thread_info_key, NULL ); /* initialize PAPI */ ret = PAPI_library_init(PAPI_VER_CURRENT); if (ret != PAPI_VER_CURRENT && ret > 0) { fprintf(stderr, "PAPI library version mismatch!\n"); exit(1); } /* There may be several threads, so let's tell this to PAPI */ if ((ret = PAPI_thread_init(pthread_self)) != PAPI_OK) handle_error(ret); __papi_init_counter_ids(); __papi_select_counters(); char* env=getenv("EZTRACE_PAPI_SAMPLE_INTERVAL"); int sample_interval=100; /* by default, check counter every 100 µs */ if(env) { sample_interval = atoi(env); if(sample_interval <= 0) { fprintf(stderr, "[EZTrace] please enter a value > 0 when setting EZTRACE_PAPI_SAMPLE_INTERVAL\n"); sample_interval=100; } } #ifdef EZTRACE_AUTOSTART eztrace_start (); #endif __papi_initialized = 1; /* Tell how many counters (and which counters) are monitored */ EZTRACE_EVENT_PACKED_1(EZTRACE_PAPI_INIT, nb_events); int i; for (i = 0; i < nb_events; i++) { EZTRACE_EVENT_PACKED_2(EZTRACE_PAPI_INIT_COUNTERS, i, Event_codes[i]); litl_write_probe_raw(__ezt_trace.litl_trace, EZTRACE_PAPI_INIT_COUNTERS, strlen(Event_names[i]), (litl_data_t*) Event_names[i]); litl_write_probe_raw(__ezt_trace.litl_trace, EZTRACE_PAPI_INIT_COUNTERS, strlen(units_names[i]), (litl_data_t*)units_names[i]); /* todo: add event description */ } ezt_sampling_register_callback(papi_record, sample_interval); } static void __papi_conclude(void) __attribute__ ((destructor)); static void __papi_conclude(void) { __papi_initialized = 0; eztrace_stop(); } eztrace-1.1-2/src/modules/papi/papi_ev_codes.h000066400000000000000000000057611265506773700213430ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef __PAPI_EV_CODES_H__ #define __PAPI_EV_CODES_H__ #include #include "ev_codes.h" #define EZTRACE_PAPI_EVENTS_ID SYSTEM_MODULE_ID(0x06) #define EZTRACE_PAPI_PREFIX GENERATE_SYSTEM_MODULE_PREFIX(EZTRACE_PAPI_EVENTS_ID) #define EZTRACE_PAPI_INIT (EZTRACE_PAPI_PREFIX | 0X0001) #define EZTRACE_PAPI_INIT_COUNTERS (EZTRACE_PAPI_PREFIX | 0X0002) #define EZTRACE_PAPI_INIT_COUNTER_NAME (EZTRACE_PAPI_PREFIX | 0X0003) #define EZTRACE_PAPI_MEASUREMENT (EZTRACE_PAPI_PREFIX | 0X0010) struct papi_counter_id { int code; char* code_str; char* description; }; struct papi_counter_id *papi_counter_ids; static int nb_counters = 0; static inline void __papi_print_counter_ids() { int i; for (i = 0; i < nb_counters; i++) { printf("[%d] code %x : %s (%s)\n", i, papi_counter_ids[i].code, papi_counter_ids[i].code_str, papi_counter_ids[i].description); } } static inline void __papi_print_available_counters() { PAPI_event_info_t info; int retval; int mask = PAPI_PRESET_ENUM_AVAIL | PAPI_NTV_ENUM_UMASKS; int start = 0 | PAPI_PRESET_MASK; int i = start; do { retval = PAPI_get_event_info(i, &info); if (retval == PAPI_OK) { printf("%-20s %s\n", info.symbol, info.long_descr); } } while ((retval = PAPI_enum_event(&i, mask)) == PAPI_OK); } /* search for a counter name and return the corresponding code. * if not found, return -1; */ static inline int __papi_get_counter_id(char* counter_name) { int i; for (i = 0; i < nb_counters; i++) { if (strcmp(counter_name, papi_counter_ids[i].code_str) == 0) { return i; } } return -1; } static inline int __papi_get_counter_id_by_code(int counter_code) { int i; for (i = 0; i < nb_counters; i++) { if (counter_code == papi_counter_ids[i].code) return i; } return -1; } #define define_counter(id, __code__, __code_str__, __desc__) \ { \ papi_counter_ids[id].code = __code__; \ asprintf(&(papi_counter_ids[id].code_str), "%s", __code_str__); \ asprintf(&(papi_counter_ids[id].description), "%s", __desc__); \ } static inline void __papi_init_counter_ids() { nb_counters = 0; papi_counter_ids = NULL; PAPI_event_info_t info; int retval; int cur_counter = 0; int mask = PAPI_PRESET_ENUM_AVAIL; int start = 0 | PAPI_PRESET_MASK; int i = start; do { retval = PAPI_get_event_info(i, &info); if (retval == PAPI_OK) nb_counters++; } while ((retval = PAPI_enum_event(&i, mask)) == PAPI_OK); papi_counter_ids = malloc(sizeof(struct papi_counter_id) * nb_counters); i = start; do { retval = PAPI_get_event_info(i, &info); if (retval == PAPI_OK) { define_counter(cur_counter, info.event_code, info.symbol, info.long_descr); cur_counter++; } } while ((retval = PAPI_enum_event(&i, mask)) == PAPI_OK); } #endif /* _PAPI_EV_CODES_H__ */ eztrace-1.1-2/src/modules/pthread/000077500000000000000000000000001265506773700170575ustar00rootroot00000000000000eztrace-1.1-2/src/modules/pthread/Makefile.am000066400000000000000000000031021265506773700211070ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. TLCFLAGS=$(TL_CPPFLAGS) TLLDFLAGS=$(TL_LDFLAGS) TLLIBADD=$(TL_LIB) GTGCFLAGS=$(GTG_CPPFLAGS) GTGLDFLAGS=$(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD=$(GTG_LIB) lib_LTLIBRARIES = AM_CFLAGS = -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ -I$(top_srcdir)/src/pptrace if USE_PTHREAD lib_LTLIBRARIES += libeztrace-convert-pthread.la \ libeztrace-pthread.la \ libeztrace-autostart-pthread.la AM_CFLAGS += -W -Wall -Wextra endif # USE_PTHREAD libeztrace_convert_pthread_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) libeztrace_convert_pthread_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) libeztrace_convert_pthread_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_pthread_la_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace_convert_pthread_la_SOURCES = eztrace_convert_pthread.c libeztrace_pthread_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_pthread_la_LIBADD = -lm -lpthread $(TLLIBADD) libeztrace_pthread_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_pthread_la_SOURCES = pthread.c libeztrace_autostart_pthread_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_autostart_pthread_la_LIBADD = -lm -lpthread $(TLLIBADD) libeztrace_autostart_pthread_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_autostart_pthread_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra -DEZTRACE_AUTOSTART libeztrace_autostart_pthread_la_SOURCES = pthread.c noinst_HEADERS = pthread_ev_codes.h eztrace_convert_pthread.h eztrace-1.1-2/src/modules/pthread/Makefile.in000066400000000000000000000730121265506773700211270ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @USE_PTHREAD_TRUE@am__append_1 = libeztrace-convert-pthread.la \ @USE_PTHREAD_TRUE@ libeztrace-pthread.la \ @USE_PTHREAD_TRUE@ libeztrace-autostart-pthread.la @USE_PTHREAD_TRUE@am__append_2 = -W -Wall -Wextra subdir = src/modules/pthread ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(noinst_HEADERS) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(libdir)" LTLIBRARIES = $(lib_LTLIBRARIES) am__DEPENDENCIES_1 = am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) libeztrace_autostart_pthread_la_DEPENDENCIES = $(am__DEPENDENCIES_2) am_libeztrace_autostart_pthread_la_OBJECTS = \ libeztrace_autostart_pthread_la-pthread.lo libeztrace_autostart_pthread_la_OBJECTS = \ $(am_libeztrace_autostart_pthread_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libeztrace_autostart_pthread_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(libeztrace_autostart_pthread_la_CFLAGS) $(CFLAGS) \ $(libeztrace_autostart_pthread_la_LDFLAGS) $(LDFLAGS) -o $@ @USE_PTHREAD_TRUE@am_libeztrace_autostart_pthread_la_rpath = -rpath \ @USE_PTHREAD_TRUE@ $(libdir) am_libeztrace_convert_pthread_la_OBJECTS = \ libeztrace_convert_pthread_la-eztrace_convert_pthread.lo libeztrace_convert_pthread_la_OBJECTS = \ $(am_libeztrace_convert_pthread_la_OBJECTS) libeztrace_convert_pthread_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) \ $(libeztrace_convert_pthread_la_LDFLAGS) $(LDFLAGS) -o $@ @USE_PTHREAD_TRUE@am_libeztrace_convert_pthread_la_rpath = -rpath \ @USE_PTHREAD_TRUE@ $(libdir) libeztrace_pthread_la_DEPENDENCIES = $(am__DEPENDENCIES_2) am_libeztrace_pthread_la_OBJECTS = libeztrace_pthread_la-pthread.lo libeztrace_pthread_la_OBJECTS = $(am_libeztrace_pthread_la_OBJECTS) libeztrace_pthread_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_pthread_la_LDFLAGS) \ $(LDFLAGS) -o $@ @USE_PTHREAD_TRUE@am_libeztrace_pthread_la_rpath = -rpath $(libdir) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libeztrace_autostart_pthread_la_SOURCES) \ $(libeztrace_convert_pthread_la_SOURCES) \ $(libeztrace_pthread_la_SOURCES) DIST_SOURCES = $(libeztrace_autostart_pthread_la_SOURCES) \ $(libeztrace_convert_pthread_la_SOURCES) \ $(libeztrace_pthread_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac HEADERS = $(noinst_HEADERS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ TLCFLAGS = $(TL_CPPFLAGS) TLLDFLAGS = $(TL_LDFLAGS) TLLIBADD = $(TL_LIB) GTGCFLAGS = $(GTG_CPPFLAGS) GTGLDFLAGS = $(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD = $(GTG_LIB) lib_LTLIBRARIES = $(am__append_1) AM_CFLAGS = -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ -I$(top_srcdir)/src/pptrace $(am__append_2) libeztrace_convert_pthread_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) libeztrace_convert_pthread_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) libeztrace_convert_pthread_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_pthread_la_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace_convert_pthread_la_SOURCES = eztrace_convert_pthread.c libeztrace_pthread_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_pthread_la_LIBADD = -lm -lpthread $(TLLIBADD) libeztrace_pthread_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_pthread_la_SOURCES = pthread.c libeztrace_autostart_pthread_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_autostart_pthread_la_LIBADD = -lm -lpthread $(TLLIBADD) libeztrace_autostart_pthread_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_autostart_pthread_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra -DEZTRACE_AUTOSTART libeztrace_autostart_pthread_la_SOURCES = pthread.c noinst_HEADERS = pthread_ev_codes.h eztrace_convert_pthread.h all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/modules/pthread/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu src/modules/pthread/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ } uninstall-libLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ done clean-libLTLIBRARIES: -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) @list='$(lib_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libeztrace-autostart-pthread.la: $(libeztrace_autostart_pthread_la_OBJECTS) $(libeztrace_autostart_pthread_la_DEPENDENCIES) $(EXTRA_libeztrace_autostart_pthread_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_autostart_pthread_la_LINK) $(am_libeztrace_autostart_pthread_la_rpath) $(libeztrace_autostart_pthread_la_OBJECTS) $(libeztrace_autostart_pthread_la_LIBADD) $(LIBS) libeztrace-convert-pthread.la: $(libeztrace_convert_pthread_la_OBJECTS) $(libeztrace_convert_pthread_la_DEPENDENCIES) $(EXTRA_libeztrace_convert_pthread_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_convert_pthread_la_LINK) $(am_libeztrace_convert_pthread_la_rpath) $(libeztrace_convert_pthread_la_OBJECTS) $(libeztrace_convert_pthread_la_LIBADD) $(LIBS) libeztrace-pthread.la: $(libeztrace_pthread_la_OBJECTS) $(libeztrace_pthread_la_DEPENDENCIES) $(EXTRA_libeztrace_pthread_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_pthread_la_LINK) $(am_libeztrace_pthread_la_rpath) $(libeztrace_pthread_la_OBJECTS) $(libeztrace_pthread_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_autostart_pthread_la-pthread.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_pthread_la-eztrace_convert_pthread.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_pthread_la-pthread.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< libeztrace_autostart_pthread_la-pthread.lo: pthread.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_pthread_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_pthread_la_CFLAGS) $(CFLAGS) -MT libeztrace_autostart_pthread_la-pthread.lo -MD -MP -MF $(DEPDIR)/libeztrace_autostart_pthread_la-pthread.Tpo -c -o libeztrace_autostart_pthread_la-pthread.lo `test -f 'pthread.c' || echo '$(srcdir)/'`pthread.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_autostart_pthread_la-pthread.Tpo $(DEPDIR)/libeztrace_autostart_pthread_la-pthread.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='pthread.c' object='libeztrace_autostart_pthread_la-pthread.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_pthread_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_pthread_la_CFLAGS) $(CFLAGS) -c -o libeztrace_autostart_pthread_la-pthread.lo `test -f 'pthread.c' || echo '$(srcdir)/'`pthread.c libeztrace_convert_pthread_la-eztrace_convert_pthread.lo: eztrace_convert_pthread.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_pthread_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_pthread_la-eztrace_convert_pthread.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_pthread_la-eztrace_convert_pthread.Tpo -c -o libeztrace_convert_pthread_la-eztrace_convert_pthread.lo `test -f 'eztrace_convert_pthread.c' || echo '$(srcdir)/'`eztrace_convert_pthread.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_pthread_la-eztrace_convert_pthread.Tpo $(DEPDIR)/libeztrace_convert_pthread_la-eztrace_convert_pthread.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_pthread.c' object='libeztrace_convert_pthread_la-eztrace_convert_pthread.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_pthread_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_pthread_la-eztrace_convert_pthread.lo `test -f 'eztrace_convert_pthread.c' || echo '$(srcdir)/'`eztrace_convert_pthread.c libeztrace_pthread_la-pthread.lo: pthread.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_pthread_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_pthread_la-pthread.lo -MD -MP -MF $(DEPDIR)/libeztrace_pthread_la-pthread.Tpo -c -o libeztrace_pthread_la-pthread.lo `test -f 'pthread.c' || echo '$(srcdir)/'`pthread.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_pthread_la-pthread.Tpo $(DEPDIR)/libeztrace_pthread_la-pthread.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='pthread.c' object='libeztrace_pthread_la-pthread.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_pthread_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_pthread_la-pthread.lo `test -f 'pthread.c' || echo '$(srcdir)/'`pthread.c mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) $(HEADERS) installdirs: for dir in "$(DESTDIR)$(libdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-libLTLIBRARIES install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-libLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libLTLIBRARIES clean-libtool cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-libLTLIBRARIES install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-libLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/src/modules/pthread/eztrace_convert_pthread.c000066400000000000000000000513041265506773700241320ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include #include #include "eztrace_convert.h" #include "eztrace_convert_core.h" #include "pthread_ev_codes.h" #include "eztrace_list.h" #include "eztrace_stack.h" #include "eztrace_convert_pthread.h" /* add a hook in the thread structure in order to store information * about pending parallel sections */ struct pthread_thread_info_t *__register_thread_hook(int tid) { DECLARE_CUR_PROCESS(p_process); struct pthread_thread_info_t *p_info = (struct pthread_thread_info_t*) malloc(sizeof(struct pthread_thread_info_t)); p_info->p_thread = GET_THREAD_INFO(CUR_INDEX, tid); int i; for(i=0; iduration_acquire[i] = 0; p_info->start_acquire[i] = 0; p_info->duration_critical_section[i] = 0; } /* add the hook in the thread info structure */ ezt_hook_list_add(&p_info->p_thread->hooks, p_info, (uint8_t)EZTRACE_PTHREAD_EVENTS_ID); return p_info; } /* declare a var variable that points to the thread_info structure */ #define INIT_PTHREAD_THREAD_INFO(p_thread_info, var) \ struct pthread_thread_info_t *var = (struct pthread_thread_info_t*) \ ezt_hook_list_retrieve_data(&p_thread_info->hooks, (uint8_t)EZTRACE_PTHREAD_EVENTS_ID); \ if(!(var)) { \ var = __register_thread_hook(CUR_THREAD_ID); \ } /* Semaphore processing */ void handle_sem_post(void) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, SEMAPHORE); PTHREAD_CHANGE() addEvent(CURRENT, "E_LockStart", thread_id, lock_info->info); } void handle_start_sem_wait(void) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, SEMAPHORE); record_lock_start_acquire(lock_info, p_info); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Blocked_sem"); } void handle_stop_sem_wait(void) { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; int retval; GET_PARAM_PACKED_2(CUR_EV, lock_ptr, retval); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, SEMAPHORE); record_lock_acquired(lock_info, p_info); PTHREAD_CHANGE() popState(CURRENT, "ST_Thread", thread_id); PTHREAD_CHANGE() addEvent(CURRENT, "E_SemWait_Done", thread_id, lock_info->info); } /* Spinlock processing */ void handle_spin_lock_start() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, SPINLOCK); record_lock_start_acquire(lock_info, p_info); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Blocked_spin"); } void handle_spin_lock_stop() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; int retval; GET_PARAM_PACKED_2(CUR_EV, lock_ptr, retval); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, SPINLOCK); record_lock_acquired(lock_info, p_info); PTHREAD_CHANGE() popState(CURRENT, "ST_Thread", thread_id); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Critical_spin"); } void handle_spin_trylock() { FUNC_NAME; DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; int result; GET_PARAM_PACKED_2(CUR_EV, lock_ptr, result); if (result) { DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, SPINLOCK); record_lock_start_acquire(lock_info, p_info); record_lock_acquired(lock_info, p_info); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Critical_spin"); } } void handle_spin_unlock() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, SPINLOCK); record_lock_release(lock_info, p_info); // __check_lock_mismatch(lock_info, p_process, CUR_THREAD_ID); PTHREAD_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } /* Mutex processing */ void handle_mutex_trylock(int result) { FUNC_NAME; if (!result) return; app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, MUTEX); record_lock_acquired(lock_info, p_info); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Critical_mutex"); } void handle_mutex_lock_start() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, MUTEX); record_lock_start_acquire(lock_info, p_info); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Blocked_mutex"); } void handle_mutex_lock_stop() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; int retval; GET_PARAM_PACKED_2(CUR_EV, lock_ptr, retval); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, MUTEX); record_lock_acquired(lock_info, p_info); PTHREAD_CHANGE() popState(CURRENT, "ST_Thread", thread_id); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Critical_mutex"); } void handle_mutex_unlock() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, MUTEX); record_lock_release(lock_info, p_info); // __check_lock_mismatch(lock_info, p_process, CUR_THREAD_ID); PTHREAD_CHANGE() addEvent(CURRENT, "E_Mutex_Unlock", thread_id, lock_info->info); PTHREAD_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } /* Condition processing */ void handle_cond_signal() { FUNC_NAME; } void handle_cond_broadcast() { FUNC_NAME; } void handle_cond_start_wait() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, CONDITION); record_lock_start_acquire(lock_info, p_info); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Blocked_cond"); } void handle_cond_stop_wait() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, CONDITION); record_lock_acquired(lock_info, p_info); PTHREAD_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } /* RWLock processing */ void handle_rwlock_rdlock_start() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, RWLOCK); record_lock_start_acquire(lock_info, p_info); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Blocked_rwlock"); } void handle_rwlock_rdlock_stop() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, RWLOCK); record_lock_acquired(lock_info, p_info); PTHREAD_CHANGE() popState(CURRENT, "ST_Thread", thread_id); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Critical_rwlock"); } void handle_rwlock_wrlock_start() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, RWLOCK); record_lock_start_acquire(lock_info, p_info); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Blocked_rwlock"); } void handle_rwlock_wrlock_stop() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, RWLOCK); record_lock_acquired(lock_info, p_info); PTHREAD_CHANGE() popState(CURRENT, "ST_Thread", thread_id); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Critical_rwlock"); } void handle_rwlock_unlock() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, RWLOCK); record_lock_release(lock_info, p_info); // __check_lock_mismatch(lock_info, p_process, CUR_THREAD_ID); PTHREAD_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } void handle_barrier_start() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, BARRIER); record_lock_start_acquire(lock_info, p_info); PTHREAD_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "STV_Blocked_barrier"); } void handle_barrier_stop() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); DECLARE_CUR_PROCESS(p_process); DECLARE_CUR_THREAD(p_thread); INIT_PTHREAD_THREAD_INFO(p_thread, p_info); app_ptr lock_ptr; GET_PARAM_PACKED_1(CUR_EV, lock_ptr); struct pthread_lock_info_t *lock_info = NULL; GET_LOCK_INFO(lock_info, p_process, lock_ptr, BARRIER); record_lock_acquired(lock_info, p_info); record_lock_release(lock_info, p_info); PTHREAD_CHANGE() popState(CURRENT, "ST_Thread", thread_id); } int eztrace_convert_pthread_init() { if (get_mode() == EZTRACE_CONVERT) { addEventType("E_SemPost", "CT_Thread", "SemPost"); addEventType("E_SemWait_Done", "CT_Thread", "SemWait done"); addEventType("E_Mutex_Lock", "CT_Thread", "Mutex Lock"); addEventType("E_Mutex_Unlock", "CT_Thread", "Mutex Unlock"); addEventType("E_CondSignal", "CT_Thread", "Cond Signal"); addEventType("E_LockStart", "CT_Thread", "Waiting for a lock"); addEventType("E_LockStop", "CT_Thread", "Lock acquired"); addEntityValue("STV_Blocked_sem", "ST_Thread", "Blocked on a semaphore", GTG_RED); addEntityValue("STV_Blocked_spin", "ST_Thread", "Blocked on a spinlock", GTG_RED); addEntityValue("STV_Blocked_mutex", "ST_Thread", "Blocked on a mutex", GTG_RED); addEntityValue("STV_Blocked_condition", "ST_Thread", "Blocked on a condition", GTG_RED); addEntityValue("STV_Blocked_rwlock", "ST_Thread", "Blocked on a rwlock", GTG_RED); addEntityValue("STV_Blocked_barrier", "ST_Thread", "Blocked on a barrier", GTG_RED); addEntityValue("STV_Critical_sem", "ST_Thread", "Critical Section (semaphore)", GTG_GREEN); addEntityValue("STV_Critical_spin", "ST_Thread", "Critical Section (spinlock)", GTG_GREEN); addEntityValue("STV_Critical_mutex", "ST_Thread", "Critical Section (mutex)", GTG_GREEN); addEntityValue("STV_Critical_condition", "ST_Thread", "Critical Section (condition)", GTG_GREEN); addEntityValue("STV_Critical_rwlock", "ST_Thread", "Critical Section (rwlock)", GTG_GREEN); } return 0; } /* return 1 if the event was handled */ int handle_pthread_events(eztrace_event_t *ev) { if (!STARTED) return 0; switch (LITL_READ_GET_CODE(ev)) { /* PThread creation/destruction */ /* Semaphore */ case EZTRACE_SEM_POST: handle_sem_post(); break; case EZTRACE_SEM_START_WAIT: handle_start_sem_wait(); break; case EZTRACE_SEM_STOP_WAIT: handle_stop_sem_wait(); break; /* Spinlock */ case EZTRACE_SPIN_LOCK_START: handle_spin_lock_start(); break; case EZTRACE_SPIN_LOCK_STOP: handle_spin_lock_stop(); break; case EZTRACE_SPIN_TRYLOCK: handle_spin_trylock(); break; case EZTRACE_SPIN_UNLOCK: handle_spin_unlock(); break; /* Mutex */ case EZTRACE_MUTEX_TRYLOCK_SUCCESS: handle_mutex_trylock(1); break; case EZTRACE_MUTEX_TRYLOCK_FAIL: handle_mutex_trylock(0); break; case EZTRACE_MUTEX_LOCK_START: handle_mutex_lock_start(); break; case EZTRACE_MUTEX_LOCK_STOP: handle_mutex_lock_stop(); break; case EZTRACE_MUTEX_UNLOCK: handle_mutex_unlock(); break; /* Condition */ case EZTRACE_COND_SIGNAL: handle_cond_signal(); break; case EZTRACE_COND_BROADCAST: handle_cond_broadcast(); break; case EZTRACE_COND_START_WAIT: handle_cond_start_wait(); break; case EZTRACE_COND_STOP_WAIT: handle_cond_stop_wait(); break; /* RWLock */ case EZTRACE_RWLOCK_RDLOCK_START: handle_rwlock_rdlock_start(); break; case EZTRACE_RWLOCK_RDLOCK_STOP: handle_rwlock_rdlock_stop(); break; case EZTRACE_RWLOCK_WRLOCK_START: handle_rwlock_wrlock_start(); break; case EZTRACE_RWLOCK_WRLOCK_STOP: handle_rwlock_wrlock_stop(); break; case EZTRACE_RWLOCK_UNLOCK: handle_rwlock_unlock(); break; case EZTRACE_BARRIER_START: handle_barrier_start(); break; case EZTRACE_BARRIER_STOP: handle_barrier_stop(); break; default: return 0; } return 1; } int handle_pthread_stats(eztrace_event_t *ev) { recording_stats = 1; return handle_pthread_events(ev); } void print_pthread_stats() { printf("\nPThread:\n"); printf("-------\n"); /* todo: * add: * - min/max/average duration of critical sections * - min/max/average delay to get a lock */ int i; for (i = 0; i < NB_TRACES; i++) { struct process_info_t *p_process = GET_PROCESS_INFO(i); struct pthread_process_info_t *p_info = (struct pthread_process_info_t*) ezt_hook_list_retrieve_data( &p_process->hooks, (uint8_t) EZTRACE_PTHREAD_EVENTS_ID); if (!p_info) continue; uint32_t nb_acquire = 0; uint32_t nb_locks = 0; printf("%s:\n", p_process->container->name); ezt_stack_token_t *token; ezt_list_foreach(&p_info->lock_list, token) { struct pthread_lock_info_t * lock = (struct pthread_lock_info_t *) token->data; nb_acquire += lock->nb_acquire; nb_locks++; char lock_type[80]; __lock_type_to_str(lock_type, lock->lock); printf("\t%s 0x%p was acquired %d times.", lock_type, (void*)lock->ptr, lock->nb_acquire); if (lock->duration_critical_section) printf(" total duration of critical_sections: %lf ms.", lock->duration_critical_section); if (lock->duration_acquire) printf(" total time spent waiting: %lf ms.", lock->duration_acquire); printf("\n"); } printf("Total: %d locks acquired %d times\n", nb_locks, nb_acquire); __free_lock_info_list(p_info); } double total_duration_acquire[NB_LOCK_TYPES]; /* time spent in waiting for a lock */ double total_duration_critical_section[NB_LOCK_TYPES]; /* time spent in a critical section */ int l; for(l=0; lnb_children; j++) { struct eztrace_container_t* p_thread = p_cont->children[j]; struct thread_info_t *ptr = (struct thread_info_t*)(p_thread->container_info); struct pthread_thread_info_t *t_info = (struct pthread_thread_info_t*) ezt_hook_list_retrieve_data(&ptr->hooks, (uint8_t)EZTRACE_PTHREAD_EVENTS_ID); if(!t_info) continue; int l; int should_skip=1; for(l=0; lduration_acquire[l] || t_info->duration_critical_section[l]) { should_skip=0; } } if(should_skip) { continue; } printf("\nThread %s\n", p_thread->name); for(l=0; lduration_acquire[l]) { char lock_type[80]; __lock_type_to_str(lock_type, l); printf("\ttime spent waiting on a %s: %lf ms\n", lock_type, t_info->duration_acquire[l]); total_duration_acquire[l] += t_info->duration_acquire[l]; } if(t_info->duration_critical_section[l]) { char lock_type[80]; __lock_type_to_str(lock_type, l); printf("\ttime spent in a %s critical: %lf ms\n", lock_type, t_info->duration_critical_section[l]); total_duration_critical_section[l] += t_info->duration_critical_section[l]; } } } printf("\nTotal for %s\n", p_cont->name); int l; for(l=0; l static int recording_stats = 0; #define PTHREAD_CHANGE() if(!recording_stats) CHANGE() /* structure attached to each process */ struct pthread_process_info_t { struct process_info_t *p_process; /* pointer to the corresponding process */ struct ezt_list_t lock_list; /* list of struct pthread_lock_info_t */ }; enum lock_type_t { MUTEX=0, SPINLOCK=1, RWLOCK=2, SEMAPHORE=3, BARRIER=4, CONDITION=5, NB_LOCK_TYPES=6 }; /* structure that contains information on a lock(mutex, spinloc, etc.) */ struct pthread_lock_info_t { struct ezt_list_token_t token; /* token used for inserting this structure in the lock_list */ enum lock_type_t lock; /* type of lock */ app_ptr ptr; /* address of the lock in the application */ char* info; /* name of the lock */ /* statistics: */ uint32_t nb_acquire; /* number of lock_stop */ int last_owner_tid; /* tid of the last thread that acquired the lock */ float time_acquire; /* last time the lock was acquired */ float time_release; /* last time the lock was released */ double duration_critical_section; /* time spent in critical section */ double duration_acquire; /* time spent in waiting for a lock */ /* todo: improve statistics: * - compute min/max/average critical section duration * - record the time spent waiting for the lock */ }; struct pthread_thread_info_t { float start_acquire[NB_LOCK_TYPES]; /* date of the last start_lock event */ float duration_acquire[NB_LOCK_TYPES]; /* time spent in waiting for a lock */ float duration_critical_section[NB_LOCK_TYPES]; /* time spent in a critical section */ struct thread_info_t *p_thread; }; static void __lock_type_to_str(char *str, enum lock_type_t l) { switch (l) { case MUTEX: strcpy(str, "mutex"); break; case SPINLOCK: strcpy(str, "spinlock"); break; case RWLOCK: strcpy(str, "rwlock"); break; case SEMAPHORE: strcpy(str, "semaphore"); break; case BARRIER: strcpy(str, "barrier"); break; case CONDITION: strcpy(str, "condition"); break; default: strcpy(str, "<>"); }; } /* print a message that warns about a dangerous behavior. Thread 1 locked, but thread2 unlocked. * return 1 if this behavior is detected or 0 otherwise */ static int __check_lock_mismatch(struct pthread_lock_info_t *p_info, struct pthread_thread_info_t *p_thread) { int cur_tid = p_thread->p_thread->tid; if (p_info->last_owner_tid == cur_tid) return 0; char lock_type_str [80]; __lock_type_to_str(lock_type_str, p_info->lock); printf("Warning: t=%f - thread %d locked ", CURRENT, p_info->last_owner_tid); printf("%s %p, but thread %d unlocks it!\n", lock_type_str, (void*)p_info->ptr, cur_tid); return 1; } /* add a hook in the process structure in order to store information * about locks used by the process */ static struct pthread_process_info_t *__register_process_hook( struct process_info_t *p_process) { struct pthread_process_info_t *p_info = (struct pthread_process_info_t*) malloc( sizeof(struct pthread_process_info_t)); p_info->p_process = p_process; ezt_list_new(&p_info->lock_list); /* add the hook in the process info structure */ ezt_hook_list_add(&p_info->p_process->hooks, p_info, (uint8_t) EZTRACE_PTHREAD_EVENTS_ID); return p_info; } /* declare a pthread_process_info_t that corresponds to p_process */ #define INIT_PTHREAD_PROCESS_INFO(p_process, var) \ struct pthread_process_info_t *var = (struct pthread_process_info_t*) \ ezt_hook_list_retrieve_data(&p_process->hooks, (uint8_t)EZTRACE_PTHREAD_EVENTS_ID); \ if(!(var)) { \ var = __register_process_hook(p_process); \ } /* get the pthread_lock_info_t* lock_info that corresponds to lock_ptr * This initialize lock_info->info */ #define GET_LOCK_INFO(lock_info, p_process, lock_ptr, lock_type) \ do { \ INIT_PTHREAD_PROCESS_INFO(p_process, p_info); \ lock_info = __find_lock_info(&p_info->lock_list, lock_ptr); \ if(!lock_info) { \ lock_info = __new_lock_info(p_info, lock_ptr, lock_type); \ } \ }while(0) /* add the current duration of critical section (time_release-time_acquire) to the * sum of critical sections */ #define update_duration_critical_section(p_lock, p_info) \ do { \ p_lock->duration_critical_section += p_lock->time_release - p_lock->time_acquire; \ p_info->duration_critical_section[p_lock->lock] += p_lock->time_release - p_lock->time_acquire; \ } while(0) #define update_duration_acquire(p_lock, p_info) \ do{ \ p_lock->duration_acquire += p_lock->time_acquire - p_info->start_acquire[p_lock->lock]; \ p_info->duration_acquire[p_lock->lock] += p_lock->time_acquire - p_info->start_acquire[p_lock->lock]; \ } while(0) /* record informations on a lock start acquire event (for statistics) */ #define record_lock_start_acquire(p_lock, p_info) \ do { \ p_info->start_acquire[p_lock->lock] = CURRENT; \ } while(0) /* record informations on a lock acquire event (for statistics) */ #define record_lock_acquired(p_lock, p_info) \ do { \ p_lock->time_acquire = CURRENT; \ update_duration_acquire(p_lock, p_info); \ p_lock->nb_acquire++; \ p_lock->last_owner_tid = p_info->p_thread->tid; \ } while(0) /* record informations on a lock release event (for statistics) */ #define record_lock_release(p_lock, p_info) \ do { \ p_lock->time_release = CURRENT; \ update_duration_critical_section(p_lock, p_info); \ __check_lock_mismatch(p_lock, p_info); \ }while(0) /* Free the lock_info_list attached to a process * Since this also frees the locks info strings, this should not be called before * the trace is written to disk. */ static void __free_lock_info_list(struct pthread_process_info_t* p_info) { while (!ezt_list_empty(&p_info->lock_list)) { struct ezt_list_token_t *t = ezt_list_get_head(&(p_info->lock_list)); struct pthread_lock_info_t *p = (struct pthread_lock_info_t *) t->data; ezt_list_remove(t); if (p) { free(p->info); free(p); } } } /* create a new lock_info structure */ static struct pthread_lock_info_t* __new_lock_info(struct pthread_process_info_t* p_info, app_ptr ptr, enum lock_type_t lock_type) { struct pthread_lock_info_t* res = malloc(sizeof(struct pthread_lock_info_t)); int ret __attribute__ ((__unused__)); /* initialize the structure */ res->lock = lock_type; res->ptr = ptr; switch (lock_type) { case MUTEX: ret = asprintf(&res->info, "Mutex %p.", (void*)ptr); break; case SPINLOCK: ret = asprintf(&res->info, "Spinlock %p.", (void*)ptr); break; case RWLOCK: ret = asprintf(&res->info, "RWLock %p.", (void*)ptr); break; case SEMAPHORE: ret = asprintf(&res->info, "Semaphore %p.", (void*)ptr); break; case BARRIER: ret = asprintf(&res->info, "Barrier %p.", (void*)ptr); break; default: fprintf(stderr, "unknown lock type: %d\n", lock_type); } ret = asprintf(&res->info, "%s_ptr_%p", p_info->p_process->container->id, (void*) ptr); /* initialize statistics */ res->nb_acquire = 0; res->last_owner_tid = -1; res->duration_critical_section = 0; res->duration_acquire = 0; res->token.data = res; /* add the lock to the list of locks */ ezt_list_add(&p_info->lock_list, &res->token); return res; } /* find the lock_info that corresponds to ptr. * return NULL if not found */ static struct pthread_lock_info_t*__find_lock_info(struct ezt_list_t *lock_list, app_ptr ptr) { struct ezt_list_token_t *t = NULL; struct pthread_lock_info_t *p; ezt_list_foreach(lock_list, t) { p = (struct pthread_lock_info_t *) t->data; if (p->ptr == ptr) return p; } return NULL; } eztrace-1.1-2/src/modules/pthread/pthread.c000066400000000000000000000236161265506773700206620ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 /* or _BSD_SOURCE or _SVID_SOURCE */ #define _REENTRANT #include #include #include #include #include #include "pthread_ev_codes.h" #include "eztrace.h" #include "pptrace.h" /* set to 1 when all the hooks are set. * This is usefull in order to avoid recursive calls to mutex_lock for example */ static volatile int __pthread_initialized = 0; /* pointers to actual pthread functions */ int (*libpthread_mutex_lock)(pthread_mutex_t * mutex) = NULL; int (*libpthread_mutex_trylock)(pthread_mutex_t * mutex); int (*libpthread_mutex_unlock)(pthread_mutex_t * mutex); int (*libpthread_spin_lock)(pthread_spinlock_t * lock); int (*libpthread_spin_unlock)(pthread_spinlock_t * lock); int (*libpthread_spin_trylock)(pthread_spinlock_t * lock); int (*libpthread_barrier_wait)(pthread_barrier_t * barrier); int (*libpthread_sem_wait)(sem_t * sem); int (*libpthread_sem_post)(sem_t * sem); int (*libpthread_cond_init)(pthread_cond_t *__restrict __cond, __const pthread_condattr_t *__restrict __cond_attr); int (*libpthread_cond_wait)(pthread_cond_t * __restrict cond, pthread_mutex_t * __restrict mutex); int (*libpthread_cond_broadcast)(pthread_cond_t * cond); int (*libpthread_cond_signal)(pthread_cond_t * cond); int (*libpthread_cond_destroy)(pthread_cond_t *__cond); int (*libpthread_cond_timedwait)(pthread_cond_t *__restrict __cond, pthread_mutex_t *__restrict __mutex, __const struct timespec *__restrict __abstime); int (*libpthread_rwlock_rdlock)(pthread_rwlock_t * rwlock); int (*libpthread_rwlock_wrlock)(pthread_rwlock_t * rwlock); int (*libpthread_rwlock_unlock)(pthread_rwlock_t * rwlock); /* Mutex-related callbacks */ int pthread_mutex_lock(pthread_mutex_t * mutex) { FUNCTION_ENTRY; /* If the current file's constructor has not been called yet, this means that the application is being initialized and that there's only one thread. Thus, we do not to call mutex_lock for real. If you try to call mutex_lock in that case, you'll get a SIGSEVG since dlsym was not called yet for mutex_lock */ if (__pthread_initialized) { EZTRACE_EVENT_PACKED_1(EZTRACE_MUTEX_LOCK_START, (app_ptr)mutex); int ret = libpthread_mutex_lock(mutex); EZTRACE_EVENT_PACKED_2(EZTRACE_MUTEX_LOCK_STOP, (app_ptr)mutex, ret); return ret; } /* __pthread_initialized is set to 0. The application is initializing, so don't do anything */ return 0; } int pthread_mutex_trylock(pthread_mutex_t * mutex) { FUNCTION_ENTRY; if (__pthread_initialized) { int ret = libpthread_mutex_trylock(mutex); /* change #if 0 into #if 1 if you want to record each call to mutex_trylock (ie. not only successful calls) */ #if 0 EZTRACE_EVENT_PACKED_1(ret==1 ? EZTRACE_MUTEX_TRYLOCK_FAIL : EZTRACE_MUTEX_TRYLOCK_SUCCESS, (app_ptr)mutex); #else /* 0 */ if (!ret) { EZTRACE_EVENT_PACKED_1(EZTRACE_MUTEX_TRYLOCK_SUCCESS, (app_ptr)mutex); } #endif /* 0 */ return ret; } return 0; } int pthread_mutex_unlock(pthread_mutex_t * mutex) { FUNCTION_ENTRY; if (__pthread_initialized) { EZTRACE_EVENT_PACKED_1(EZTRACE_MUTEX_UNLOCK, (app_ptr)mutex); int ret = libpthread_mutex_unlock(mutex); return ret; } return 0; } /* Spinlock-related callbacks */ int pthread_spin_lock(pthread_spinlock_t * lock) { FUNCTION_ENTRY; if(!libpthread_spin_lock){ INTERCEPT("pthread_spin_lock", libpthread_spin_lock); } EZTRACE_EVENT_PACKED_1(EZTRACE_SPIN_LOCK_START, (app_ptr)lock); int ret = libpthread_spin_lock(lock); EZTRACE_EVENT_PACKED_2(EZTRACE_SPIN_LOCK_STOP, (app_ptr)lock, ret); return ret; } int pthread_spin_unlock(pthread_spinlock_t * lock) { FUNCTION_ENTRY; if(!libpthread_spin_unlock){ INTERCEPT("pthread_spin_unlock", libpthread_spin_unlock); } EZTRACE_EVENT_PACKED_1(EZTRACE_SPIN_UNLOCK, (app_ptr)lock); return libpthread_spin_unlock(lock); } int pthread_spin_trylock(pthread_spinlock_t * lock) { FUNCTION_ENTRY; if(!libpthread_spin_trylock){ INTERCEPT("pthread_spin_trylock", libpthread_spin_trylock); } int ret = libpthread_spin_trylock(lock); EZTRACE_EVENT_PACKED_2(EZTRACE_SPIN_TRYLOCK, (app_ptr)lock, ret); return ret; } /* Barrier-related callbacks */ int pthread_barrier_wait(pthread_barrier_t * barrier) { FUNCTION_ENTRY; if(!libpthread_barrier_wait){ INTERCEPT("pthread_barrier_wait", libpthread_barrier_wait); } EZTRACE_EVENT_PACKED_1(EZTRACE_BARRIER_START, barrier); int ret = libpthread_barrier_wait(barrier); EZTRACE_EVENT_PACKED_1(EZTRACE_BARRIER_STOP, barrier); return ret; } /* Semaphore-related callbacks */ int sem_wait(sem_t * sem) { FUNCTION_ENTRY; if(!libpthread_sem_wait){ INTERCEPT("sem_wait", libpthread_sem_wait); } EZTRACE_EVENT_PACKED_1(EZTRACE_SEM_START_WAIT, (app_ptr)sem); int ret = libpthread_sem_wait(sem); EZTRACE_EVENT_PACKED_2(EZTRACE_SEM_STOP_WAIT, (app_ptr)sem, ret); return ret; } int sem_post(sem_t * sem) { FUNCTION_ENTRY; if(!libpthread_sem_post){ INTERCEPT("sem_post", libpthread_sem_post); } EZTRACE_EVENT_PACKED_1(EZTRACE_SEM_POST, (app_ptr)sem); return libpthread_sem_post(sem); } /* Condition-related callbacks */ /* We don't actually need these (init, destroy) functions, but if we don't * catch these functions, it will lead to using somehow different implementations * (ie. cond_init from one implementation and cond_wait from another) that are * not compatible, resulting in data corruption :( */ int pthread_cond_init(pthread_cond_t *__restrict __cond, __const pthread_condattr_t *__restrict __cond_attr) { if (!libpthread_cond_init) { INTERCEPT("pthread_cond_init", libpthread_cond_init); } return libpthread_cond_init(__cond, __cond_attr); } int pthread_cond_destroy(pthread_cond_t *__cond) { if (!libpthread_cond_destroy) { INTERCEPT("pthread_cond_destroy", libpthread_cond_destroy); } return libpthread_cond_destroy(__cond); } int pthread_cond_wait(pthread_cond_t * __restrict cond, pthread_mutex_t * __restrict mutex) { if (!libpthread_cond_wait) { INTERCEPT("pthread_cond_wait", libpthread_cond_wait); } FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_1(EZTRACE_COND_START_WAIT, (app_ptr) cond); int ret = libpthread_cond_wait(cond, mutex); EZTRACE_EVENT_PACKED_1(EZTRACE_COND_STOP_WAIT, (app_ptr) cond); return ret; } int pthread_cond_timedwait(pthread_cond_t *__restrict __cond, pthread_mutex_t *__restrict __mutex, __const struct timespec *__restrict __abstime) { if (!libpthread_cond_timedwait) { INTERCEPT("pthread_cond_timedwait", libpthread_cond_timedwait); } FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_COND_START_WAIT); int ret = libpthread_cond_timedwait(__cond, __mutex, __abstime); /* todo: what if the timer expires ? */ EZTRACE_EVENT_PACKED_1(EZTRACE_COND_STOP_WAIT, (app_ptr) __cond); return ret; } int pthread_cond_broadcast(pthread_cond_t * cond) { if (!libpthread_cond_broadcast) { INTERCEPT("pthread_cond_broadcast", libpthread_cond_broadcast); } FUNCTION_ENTRY; return libpthread_cond_broadcast(cond); } int pthread_cond_signal(pthread_cond_t * cond) { if (!libpthread_cond_signal) { INTERCEPT("pthread_cond_signal", libpthread_cond_signal); } FUNCTION_ENTRY; return libpthread_cond_signal(cond); } /* RWLock-related callbacks */ int pthread_rwlock_rdlock(pthread_rwlock_t * rwlock) { if (!libpthread_rwlock_rdlock) { INTERCEPT("pthread_rwlock_rdlock", libpthread_rwlock_rdlock); } FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_1(EZTRACE_RWLOCK_RDLOCK_START, (app_ptr)rwlock); int ret = libpthread_rwlock_rdlock(rwlock); EZTRACE_EVENT_PACKED_1(EZTRACE_RWLOCK_RDLOCK_STOP, (app_ptr)rwlock); return ret; } int pthread_rwlock_wrlock(pthread_rwlock_t * rwlock) { if (!libpthread_rwlock_wrlock) { INTERCEPT("pthread_rwlock_wrlock", libpthread_rwlock_wrlock); } FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_1(EZTRACE_RWLOCK_WRLOCK_START, (app_ptr)rwlock); int ret = libpthread_rwlock_wrlock(rwlock); EZTRACE_EVENT_PACKED_1(EZTRACE_RWLOCK_WRLOCK_STOP, (app_ptr)rwlock); return ret; } int pthread_rwlock_unlock(pthread_rwlock_t * rwlock) { if (!libpthread_rwlock_unlock) { INTERCEPT("pthread_rwlock_unlock", libpthread_rwlock_unlock); } FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_1(EZTRACE_RWLOCK_UNLOCK, (app_ptr)rwlock); int ret = libpthread_rwlock_unlock(rwlock); return ret; } START_INTERCEPT_MODULE(pthread) INTERCEPT2("pthread_mutex_lock", libpthread_mutex_lock) INTERCEPT2("pthread_mutex_trylock", libpthread_mutex_trylock) INTERCEPT2("pthread_mutex_unlock", libpthread_mutex_unlock) INTERCEPT2("pthread_spin_lock", libpthread_spin_lock) INTERCEPT2("pthread_spin_unlock", libpthread_spin_unlock) INTERCEPT2("pthread_spin_trylock", libpthread_spin_trylock) INTERCEPT2("pthread_barrier_wait", libpthread_barrier_wait) INTERCEPT2("sem_wait", libpthread_sem_wait) INTERCEPT2("sem_post", libpthread_sem_post) INTERCEPT2("pthread_cond_wait", libpthread_cond_wait) INTERCEPT2("pthread_cond_timedwait", libpthread_cond_timedwait) INTERCEPT2("pthread_cond_broadcast", libpthread_cond_broadcast) INTERCEPT2("pthread_cond_signal", libpthread_cond_signal) INTERCEPT2("pthread_cond_init", libpthread_cond_init) INTERCEPT2("pthread_cond_destroy", libpthread_cond_destroy) INTERCEPT2("pthread_rwlock_rdlock", libpthread_rwlock_rdlock) INTERCEPT2("pthread_rwlock_wrlock", libpthread_rwlock_wrlock) INTERCEPT2("pthread_rwlock_unlock", libpthread_rwlock_unlock) END_INTERCEPT_MODULE(pthread) static void __pthread_init(void) __attribute__ ((constructor)); static void __pthread_init(void) { DYNAMIC_INTERCEPT_ALL_MODULE(pthread); #ifdef EZTRACE_AUTOSTART eztrace_start (); #endif __pthread_initialized = 1; } static void __pthread_conclude(void) __attribute__ ((destructor)); static void __pthread_conclude(void) { __pthread_initialized = 0; eztrace_stop(); } eztrace-1.1-2/src/modules/pthread/pthread_ev_codes.h000066400000000000000000000041231265506773700225260ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef __PTHREAD_EV_CODES_H__ #define __PTHREAD_EV_CODES_H__ #include "ev_codes.h" #define EZTRACE_PTHREAD_EVENTS_ID SYSTEM_MODULE_ID(0x02) #define EZTRACE_PTHREAD_PREFIX GENERATE_SYSTEM_MODULE_PREFIX(EZTRACE_PTHREAD_EVENTS_ID) /* semaphores */ #define EZTRACE_SEM_POST (EZTRACE_PTHREAD_PREFIX | 0x0010) #define EZTRACE_SEM_START_WAIT (EZTRACE_PTHREAD_PREFIX | 0x0011) #define EZTRACE_SEM_STOP_WAIT (EZTRACE_PTHREAD_PREFIX | 0x0012) /* spinlocks */ #define EZTRACE_SPIN_LOCK_START (EZTRACE_PTHREAD_PREFIX | 0x0020 ) #define EZTRACE_SPIN_LOCK_STOP (EZTRACE_PTHREAD_PREFIX | 0x0021 ) #define EZTRACE_SPIN_UNLOCK (EZTRACE_PTHREAD_PREFIX | 0x0022 ) #define EZTRACE_SPIN_TRYLOCK (EZTRACE_PTHREAD_PREFIX | 0x0023 ) /* mutexes */ #define EZTRACE_MUTEX_TRYLOCK_SUCCESS (EZTRACE_PTHREAD_PREFIX | 0x0030) #define EZTRACE_MUTEX_TRYLOCK_FAIL (EZTRACE_PTHREAD_PREFIX | 0x0031) #define EZTRACE_MUTEX_LOCK_START (EZTRACE_PTHREAD_PREFIX | 0x0033) #define EZTRACE_MUTEX_LOCK_STOP (EZTRACE_PTHREAD_PREFIX | 0x0034) #define EZTRACE_MUTEX_UNLOCK (EZTRACE_PTHREAD_PREFIX | 0x0035) /* conditions */ #define EZTRACE_COND_SIGNAL (EZTRACE_PTHREAD_PREFIX | 0x0040) #define EZTRACE_COND_BROADCAST (EZTRACE_PTHREAD_PREFIX | 0x0041) #define EZTRACE_COND_START_WAIT (EZTRACE_PTHREAD_PREFIX | 0x0042) #define EZTRACE_COND_STOP_WAIT (EZTRACE_PTHREAD_PREFIX | 0x0043) /* rwlocks */ #define EZTRACE_RWLOCK_RDLOCK_START (EZTRACE_PTHREAD_PREFIX | 0x0050) #define EZTRACE_RWLOCK_RDLOCK_STOP (EZTRACE_PTHREAD_PREFIX | 0x0051) #define EZTRACE_RWLOCK_WRLOCK_START (EZTRACE_PTHREAD_PREFIX | 0x0052) #define EZTRACE_RWLOCK_WRLOCK_STOP (EZTRACE_PTHREAD_PREFIX | 0x0053) #define EZTRACE_RWLOCK_UNLOCK (EZTRACE_PTHREAD_PREFIX | 0x0054) /* barriers */ #define EZTRACE_BARRIER_START (EZTRACE_PTHREAD_PREFIX | 0x0060) #define EZTRACE_BARRIER_STOP (EZTRACE_PTHREAD_PREFIX | 0x0061) #endif /* __PTHREAD_EV_CODES_H__ */ eztrace-1.1-2/src/modules/starpu/000077500000000000000000000000001265506773700167465ustar00rootroot00000000000000eztrace-1.1-2/src/modules/starpu/Makefile.am000066400000000000000000000032671265506773700210120ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. TLCFLAGS=$(TL_CPPFLAGS) TLLDFLAGS=$(TL_LDFLAGS) TLLIBADD=$(TL_LIB) GTGCFLAGS=$(GTG_CPPFLAGS) GTGLDFLAGS=$(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD=$(GTG_LIB) if USE_STARPU AM_CFLAGS = -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ -I$(top_srdir)/src/pptrace -I$(srcdir)/starpu-include \ -I$(STARPU_ROOT)/include/starpu/1.3 STARPU_VERSION= starpu-1.3 lib_LTLIBRARIES = libeztrace-convert-starpu.la \ libeztrace-starpu.la \ libeztrace-autostart-starpu.la libeztrace_convert_starpu_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) $(STARPU_CPPFLAGS) libeztrace_convert_starpu_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) $(STARPU_LDFLAGS) libeztrace_convert_starpu_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_starpu_la_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace_convert_starpu_la_SOURCES = eztrace_convert_starpu.c libeztrace_starpu_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(STARPU_CPPFLAGS) libeztrace_starpu_la_LIBADD = -lm $(TLLIBADD) $(STARPU_LDFLAGS) libeztrace_starpu_la_LDFLAGS = --no-undefined $(TLLDFLAGS) -Wl,-Bsymbolic libeztrace_starpu_la_SOURCES = starpu.c libeztrace_autostart_starpu_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(STARPU_CPPFLAGS) libeztrace_autostart_starpu_la_LIBADD = -lm -lpthread $(TLLIBADD) $(STARPU_LDFLAGS) libeztrace_autostart_starpu_la_LDFLAGS = --no-undefined $(TLLDFLAGS) -Wl,-Bsymbolic libeztrace_autostart_starpu_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra -DEZTRACE_AUTOSTART libeztrace_autostart_starpu_la_SOURCES = starpu.c noinst_HEADERS = starpu_ev_codes.h eztrace_convert_starpu.h endif #USE_STARPU eztrace-1.1-2/src/modules/starpu/Makefile.in000066400000000000000000000743761265506773700210340ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = src/modules/starpu ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__noinst_HEADERS_DIST) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(libdir)" LTLIBRARIES = $(lib_LTLIBRARIES) am__DEPENDENCIES_1 = am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) @USE_STARPU_TRUE@libeztrace_autostart_starpu_la_DEPENDENCIES = \ @USE_STARPU_TRUE@ $(am__DEPENDENCIES_2) $(am__DEPENDENCIES_1) am__libeztrace_autostart_starpu_la_SOURCES_DIST = starpu.c @USE_STARPU_TRUE@am_libeztrace_autostart_starpu_la_OBJECTS = \ @USE_STARPU_TRUE@ libeztrace_autostart_starpu_la-starpu.lo libeztrace_autostart_starpu_la_OBJECTS = \ $(am_libeztrace_autostart_starpu_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libeztrace_autostart_starpu_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(libeztrace_autostart_starpu_la_CFLAGS) $(CFLAGS) \ $(libeztrace_autostart_starpu_la_LDFLAGS) $(LDFLAGS) -o $@ @USE_STARPU_TRUE@am_libeztrace_autostart_starpu_la_rpath = -rpath \ @USE_STARPU_TRUE@ $(libdir) am__libeztrace_convert_starpu_la_SOURCES_DIST = \ eztrace_convert_starpu.c @USE_STARPU_TRUE@am_libeztrace_convert_starpu_la_OBJECTS = libeztrace_convert_starpu_la-eztrace_convert_starpu.lo libeztrace_convert_starpu_la_OBJECTS = \ $(am_libeztrace_convert_starpu_la_OBJECTS) libeztrace_convert_starpu_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_convert_starpu_la_LDFLAGS) \ $(LDFLAGS) -o $@ @USE_STARPU_TRUE@am_libeztrace_convert_starpu_la_rpath = -rpath \ @USE_STARPU_TRUE@ $(libdir) @USE_STARPU_TRUE@libeztrace_starpu_la_DEPENDENCIES = \ @USE_STARPU_TRUE@ $(am__DEPENDENCIES_2) $(am__DEPENDENCIES_1) am__libeztrace_starpu_la_SOURCES_DIST = starpu.c @USE_STARPU_TRUE@am_libeztrace_starpu_la_OBJECTS = \ @USE_STARPU_TRUE@ libeztrace_starpu_la-starpu.lo libeztrace_starpu_la_OBJECTS = $(am_libeztrace_starpu_la_OBJECTS) libeztrace_starpu_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_starpu_la_LDFLAGS) \ $(LDFLAGS) -o $@ @USE_STARPU_TRUE@am_libeztrace_starpu_la_rpath = -rpath $(libdir) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libeztrace_autostart_starpu_la_SOURCES) \ $(libeztrace_convert_starpu_la_SOURCES) \ $(libeztrace_starpu_la_SOURCES) DIST_SOURCES = $(am__libeztrace_autostart_starpu_la_SOURCES_DIST) \ $(am__libeztrace_convert_starpu_la_SOURCES_DIST) \ $(am__libeztrace_starpu_la_SOURCES_DIST) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__noinst_HEADERS_DIST = starpu_ev_codes.h eztrace_convert_starpu.h HEADERS = $(noinst_HEADERS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ TLCFLAGS = $(TL_CPPFLAGS) TLLDFLAGS = $(TL_LDFLAGS) TLLIBADD = $(TL_LIB) GTGCFLAGS = $(GTG_CPPFLAGS) GTGLDFLAGS = $(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD = $(GTG_LIB) @USE_STARPU_TRUE@AM_CFLAGS = -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ @USE_STARPU_TRUE@ -I$(top_srdir)/src/pptrace -I$(srcdir)/starpu-include \ @USE_STARPU_TRUE@ -I$(STARPU_ROOT)/include/starpu/1.3 @USE_STARPU_TRUE@STARPU_VERSION = starpu-1.3 @USE_STARPU_TRUE@lib_LTLIBRARIES = libeztrace-convert-starpu.la \ @USE_STARPU_TRUE@ libeztrace-starpu.la \ @USE_STARPU_TRUE@ libeztrace-autostart-starpu.la @USE_STARPU_TRUE@libeztrace_convert_starpu_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) $(STARPU_CPPFLAGS) @USE_STARPU_TRUE@libeztrace_convert_starpu_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) $(STARPU_LDFLAGS) @USE_STARPU_TRUE@libeztrace_convert_starpu_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) @USE_STARPU_TRUE@libeztrace_convert_starpu_la_DEPENDENCIES = $(GTGDEPENDENCIES) @USE_STARPU_TRUE@libeztrace_convert_starpu_la_SOURCES = eztrace_convert_starpu.c @USE_STARPU_TRUE@libeztrace_starpu_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(STARPU_CPPFLAGS) @USE_STARPU_TRUE@libeztrace_starpu_la_LIBADD = -lm $(TLLIBADD) $(STARPU_LDFLAGS) @USE_STARPU_TRUE@libeztrace_starpu_la_LDFLAGS = --no-undefined $(TLLDFLAGS) -Wl,-Bsymbolic @USE_STARPU_TRUE@libeztrace_starpu_la_SOURCES = starpu.c @USE_STARPU_TRUE@libeztrace_autostart_starpu_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(STARPU_CPPFLAGS) @USE_STARPU_TRUE@libeztrace_autostart_starpu_la_LIBADD = -lm -lpthread $(TLLIBADD) $(STARPU_LDFLAGS) @USE_STARPU_TRUE@libeztrace_autostart_starpu_la_LDFLAGS = --no-undefined $(TLLDFLAGS) -Wl,-Bsymbolic @USE_STARPU_TRUE@libeztrace_autostart_starpu_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra -DEZTRACE_AUTOSTART @USE_STARPU_TRUE@libeztrace_autostart_starpu_la_SOURCES = starpu.c @USE_STARPU_TRUE@noinst_HEADERS = starpu_ev_codes.h eztrace_convert_starpu.h all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/modules/starpu/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu src/modules/starpu/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ } uninstall-libLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ done clean-libLTLIBRARIES: -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) @list='$(lib_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libeztrace-autostart-starpu.la: $(libeztrace_autostart_starpu_la_OBJECTS) $(libeztrace_autostart_starpu_la_DEPENDENCIES) $(EXTRA_libeztrace_autostart_starpu_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_autostart_starpu_la_LINK) $(am_libeztrace_autostart_starpu_la_rpath) $(libeztrace_autostart_starpu_la_OBJECTS) $(libeztrace_autostart_starpu_la_LIBADD) $(LIBS) libeztrace-convert-starpu.la: $(libeztrace_convert_starpu_la_OBJECTS) $(libeztrace_convert_starpu_la_DEPENDENCIES) $(EXTRA_libeztrace_convert_starpu_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_convert_starpu_la_LINK) $(am_libeztrace_convert_starpu_la_rpath) $(libeztrace_convert_starpu_la_OBJECTS) $(libeztrace_convert_starpu_la_LIBADD) $(LIBS) libeztrace-starpu.la: $(libeztrace_starpu_la_OBJECTS) $(libeztrace_starpu_la_DEPENDENCIES) $(EXTRA_libeztrace_starpu_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_starpu_la_LINK) $(am_libeztrace_starpu_la_rpath) $(libeztrace_starpu_la_OBJECTS) $(libeztrace_starpu_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_autostart_starpu_la-starpu.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_starpu_la-eztrace_convert_starpu.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_starpu_la-starpu.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< libeztrace_autostart_starpu_la-starpu.lo: starpu.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_starpu_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_starpu_la_CFLAGS) $(CFLAGS) -MT libeztrace_autostart_starpu_la-starpu.lo -MD -MP -MF $(DEPDIR)/libeztrace_autostart_starpu_la-starpu.Tpo -c -o libeztrace_autostart_starpu_la-starpu.lo `test -f 'starpu.c' || echo '$(srcdir)/'`starpu.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_autostart_starpu_la-starpu.Tpo $(DEPDIR)/libeztrace_autostart_starpu_la-starpu.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='starpu.c' object='libeztrace_autostart_starpu_la-starpu.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_starpu_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_starpu_la_CFLAGS) $(CFLAGS) -c -o libeztrace_autostart_starpu_la-starpu.lo `test -f 'starpu.c' || echo '$(srcdir)/'`starpu.c libeztrace_convert_starpu_la-eztrace_convert_starpu.lo: eztrace_convert_starpu.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_starpu_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_starpu_la-eztrace_convert_starpu.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_starpu_la-eztrace_convert_starpu.Tpo -c -o libeztrace_convert_starpu_la-eztrace_convert_starpu.lo `test -f 'eztrace_convert_starpu.c' || echo '$(srcdir)/'`eztrace_convert_starpu.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_starpu_la-eztrace_convert_starpu.Tpo $(DEPDIR)/libeztrace_convert_starpu_la-eztrace_convert_starpu.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_starpu.c' object='libeztrace_convert_starpu_la-eztrace_convert_starpu.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_starpu_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_starpu_la-eztrace_convert_starpu.lo `test -f 'eztrace_convert_starpu.c' || echo '$(srcdir)/'`eztrace_convert_starpu.c libeztrace_starpu_la-starpu.lo: starpu.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_starpu_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_starpu_la-starpu.lo -MD -MP -MF $(DEPDIR)/libeztrace_starpu_la-starpu.Tpo -c -o libeztrace_starpu_la-starpu.lo `test -f 'starpu.c' || echo '$(srcdir)/'`starpu.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_starpu_la-starpu.Tpo $(DEPDIR)/libeztrace_starpu_la-starpu.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='starpu.c' object='libeztrace_starpu_la-starpu.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_starpu_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_starpu_la-starpu.lo `test -f 'starpu.c' || echo '$(srcdir)/'`starpu.c mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) $(HEADERS) installdirs: for dir in "$(DESTDIR)$(libdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-libLTLIBRARIES install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-libLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libLTLIBRARIES clean-libtool cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-libLTLIBRARIES install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-libLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/src/modules/starpu/eztrace_convert_starpu.c000066400000000000000000002332021265506773700237070ustar00rootroot00000000000000/* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include "eztrace_convert.h" #include "eztrace_convert_macros.h" #include "starpu_ev_codes.h" //#define FUNC_NAME printf("%s\n", __FUNCTION__); /* This structure contains information about the source of the starpu link */ struct starpu_link_source { char* source; /* The thread which submitted the task */ varPrec time; /* date at which the task is submitted */ struct starpu_task* task; /* Address of the task being submitted */ }; /* This list contains information about the source of the starpu link */ struct ezt_list_t starpu_link_source_list; /* This structure contains the duration of a particular task */ struct starpu_task_duration { double start_time; struct starpu_task* task; /* Address of the task being executed */ }; /* This structure contains the durations of tasks of the same type */ struct starpu_task_type_stats { double min_time; double max_time; double ave_time; int nb_tasks; void* task_type; struct ezt_list_t starpu_task_duration_list; /* This list contains duration statistics for a particular task type */ }; /* This list contains duration statistics for a particular task type */ struct ezt_list_t starpu_task_type_stats_list; char *jobName = NULL; #define GET_PARAM_RAW_1(p_ev, arg1) do { \ litl_read_get_param_1(p_ev, arg1); \ } while(0) typedef struct s_nameList { char *name; struct s_nameList *next; } nameList; nameList *nameL = NULL; nameList *savePtr; nameList *nameExec = NULL; nameList *execPtr; static struct ezt_list_token_t* __find_matching_link_source(struct starpu_task * task) { struct ezt_list_token_t *t = NULL; struct starpu_link_source *r; ezt_list_foreach(&starpu_link_source_list, t) { r = (struct starpu_link_source *) t->data; if(r->task == task) return t; } return t; } static struct ezt_list_token_t* __find_matching_task(app_ptr task, struct ezt_list_t *starpu_task_duration_list) { struct ezt_list_token_t *t = NULL; struct starpu_task_duration *r; ezt_list_foreach(starpu_task_duration_list, t) { r = (struct starpu_task_duration *) t->data; if((app_ptr)r->task == task) return t; } return t; } static struct ezt_list_token_t* __find_matching_task_type(app_ptr task_type) { struct ezt_list_token_t *t = NULL; struct starpu_task_type_stats *r; ezt_list_foreach(&starpu_task_type_stats_list, t) { r = (struct starpu_task_type_stats *) t->data; if((app_ptr)r->task_type == task_type) return t; } return t; } int eztrace_convert_starpu_init(); int handle_starpu_events(eztrace_event_t *ev); // Internals void handleEZTRACE_starpu__starpu_driver_start_job(); void handleEZTRACE_starpu__starpu_driver_end_job() ; // API void handleEZTRACE_starpu_starpu_cublas_init_41() ; void handleEZTRACE_starpu_starpu_cublas_init_42() ; void handleEZTRACE_starpu_starpu_cublas_shutdown_43() ; void handleEZTRACE_starpu_starpu_cublas_shutdown_44() ; void handleEZTRACE_starpu_starpu_init_47() ; void handleEZTRACE_starpu_starpu_init_48() ; void handleEZTRACE_starpu_starpu_pause_49() ; void handleEZTRACE_starpu_starpu_pause_50() ; void handleEZTRACE_starpu_starpu_resume_51() ; void handleEZTRACE_starpu_starpu_resume_52() ; void handleEZTRACE_starpu_starpu_shutdown_53() ; void handleEZTRACE_starpu_starpu_shutdown_54() ; void handleEZTRACE_starpu_starpu_data_unregister_79() ; void handleEZTRACE_starpu_starpu_data_unregister_80() ; void handleEZTRACE_starpu_starpu_data_unregister_no_coherency_81() ; void handleEZTRACE_starpu_starpu_data_unregister_no_coherency_82() ; void handleEZTRACE_starpu_starpu_data_unregister_submit_83() ; void handleEZTRACE_starpu_starpu_data_unregister_submit_84() ; void handleEZTRACE_starpu_starpu_data_invalidate_85() ; void handleEZTRACE_starpu_starpu_data_invalidate_86() ; void handleEZTRACE_starpu_starpu_data_invalidate_submit_87() ; void handleEZTRACE_starpu_starpu_data_invalidate_submit_88() ; void handleEZTRACE_starpu_starpu_data_acquire_91() ; void handleEZTRACE_starpu_starpu_data_acquire_92() ; void handleEZTRACE_starpu_starpu_data_acquire_on_node_93() ; void handleEZTRACE_starpu_starpu_data_acquire_on_node_94() ; void handleEZTRACE_starpu_starpu_data_acquire_cb_95() ; void handleEZTRACE_starpu_starpu_data_acquire_cb_96() ; void handleEZTRACE_starpu_starpu_data_acquire_on_node_cb_97() ; void handleEZTRACE_starpu_starpu_data_acquire_on_node_cb_98() ; void handleEZTRACE_starpu_starpu_data_release_99() ; void handleEZTRACE_starpu_starpu_data_release_100() ; void handleEZTRACE_starpu_starpu_data_release_on_node_101() ; void handleEZTRACE_starpu_starpu_data_release_on_node_102() ; void handleEZTRACE_starpu_starpu_malloc_on_node_183() ; void handleEZTRACE_starpu_starpu_malloc_on_node_184() ; void handleEZTRACE_starpu_starpu_free_on_node_185() ; void handleEZTRACE_starpu_starpu_free_on_node_186() ; void handleEZTRACE_starpu_starpu_mpi_isend_311() ; void handleEZTRACE_starpu_starpu_mpi_isend_312() ; void handleEZTRACE_starpu_starpu_mpi_irecv_313() ; void handleEZTRACE_starpu_starpu_mpi_irecv_314() ; void handleEZTRACE_starpu_starpu_mpi_send_315() ; void handleEZTRACE_starpu_starpu_mpi_send_316() ; void handleEZTRACE_starpu_starpu_mpi_recv_317() ; void handleEZTRACE_starpu_starpu_mpi_recv_318() ; void handleEZTRACE_starpu_starpu_mpi_isend_detached_319() ; void handleEZTRACE_starpu_starpu_mpi_isend_detached_320() ; void handleEZTRACE_starpu_starpu_mpi_irecv_detached_321() ; void handleEZTRACE_starpu_starpu_mpi_irecv_detached_322() ; void handleEZTRACE_starpu_starpu_mpi_wait_323() ; void handleEZTRACE_starpu_starpu_mpi_wait_324() ; void handleEZTRACE_starpu_starpu_mpi_test_325() ; void handleEZTRACE_starpu_starpu_mpi_test_326() ; void handleEZTRACE_starpu_starpu_mpi_barrier_327() ; void handleEZTRACE_starpu_starpu_mpi_barrier_328() ; void handleEZTRACE_starpu_starpu_mpi_init_329() ; void handleEZTRACE_starpu_starpu_mpi_init_330() ; void handleEZTRACE_starpu_starpu_mpi_initialize_331() ; void handleEZTRACE_starpu_starpu_mpi_initialize_332() ; void handleEZTRACE_starpu_starpu_mpi_initialize_extended_333() ; void handleEZTRACE_starpu_starpu_mpi_initialize_extended_334() ; void handleEZTRACE_starpu_starpu_mpi_shutdown_335() ; void handleEZTRACE_starpu_starpu_mpi_shutdown_336() ; void handleEZTRACE_starpu_starpu_mpi_get_data_on_node_337() ; void handleEZTRACE_starpu_starpu_mpi_get_data_on_node_338() ; void handleEZTRACE_starpu_starpu_mpi_get_data_on_node_detached_339() ; void handleEZTRACE_starpu_starpu_mpi_get_data_on_node_detached_340() ; void handleEZTRACE_starpu_starpu_mpi_redux_data_341() ; void handleEZTRACE_starpu_starpu_mpi_redux_data_342() ; void handleEZTRACE_starpu_starpu_mpi_scatter_detached_343() ; void handleEZTRACE_starpu_starpu_mpi_scatter_detached_344() ; void handleEZTRACE_starpu_starpu_mpi_gather_detached_345() ; void handleEZTRACE_starpu_starpu_mpi_gather_detached_346() ; void handleEZTRACE_starpu_starpu_mpi_isend_detached_unlock_tag_347() ; void handleEZTRACE_starpu_starpu_mpi_isend_detached_unlock_tag_348() ; void handleEZTRACE_starpu_starpu_mpi_irecv_detached_unlock_tag_349() ; void handleEZTRACE_starpu_starpu_mpi_irecv_detached_unlock_tag_350() ; void handleEZTRACE_starpu_starpu_mpi_isend_array_detached_unlock_tag_351() ; void handleEZTRACE_starpu_starpu_mpi_isend_array_detached_unlock_tag_352() ; void handleEZTRACE_starpu_starpu_mpi_irecv_array_detached_unlock_tag_353() ; void handleEZTRACE_starpu_starpu_mpi_irecv_array_detached_unlock_tag_354() ; void handleEZTRACE_starpu_starpu_mpi_comm_amounts_retrieve_355() ; void handleEZTRACE_starpu_starpu_mpi_comm_amounts_retrieve_356() ; void handleEZTRACE_starpu_starpu_mpi_cache_flush_357() ; void handleEZTRACE_starpu_starpu_mpi_cache_flush_358() ; void handleEZTRACE_starpu_starpu_mpi_cache_flush_all_data_359() ; void handleEZTRACE_starpu_starpu_mpi_cache_flush_all_data_360() ; void handleEZTRACE_starpu_starpu_mpi_data_register_361() ; void handleEZTRACE_starpu_starpu_mpi_data_register_362() ; void handleEZTRACE_starpu_starpu_sched_ctx_add_workers_411() ; void handleEZTRACE_starpu_starpu_sched_ctx_add_workers_412() ; void handleEZTRACE_starpu_starpu_sched_ctx_remove_workers_413() ; void handleEZTRACE_starpu_starpu_sched_ctx_remove_workers_414() ; void handleEZTRACE_starpu_starpu_sched_ctx_delete_415() ; void handleEZTRACE_starpu_starpu_sched_ctx_delete_416() ; void handleEZTRACE_starpu_starpu_sched_ctx_set_inheritor_417() ; void handleEZTRACE_starpu_starpu_sched_ctx_set_inheritor_418() ; void handleEZTRACE_starpu_starpu_sched_ctx_set_context_419() ; void handleEZTRACE_starpu_starpu_sched_ctx_set_context_420() ; void handleEZTRACE_starpu_starpu_sched_ctx_get_context_421() ; void handleEZTRACE_starpu_starpu_sched_ctx_get_context_422() ; void handleEZTRACE_starpu_starpu_sched_ctx_stop_task_submission_423() ; void handleEZTRACE_starpu_starpu_sched_ctx_stop_task_submission_424() ; void handleEZTRACE_starpu_starpu_sched_ctx_finished_submit_425() ; void handleEZTRACE_starpu_starpu_sched_ctx_finished_submit_426() ; void handleEZTRACE_starpu_starpu_sched_ctx_create_worker_collection_461() ; void handleEZTRACE_starpu_starpu_sched_ctx_create_worker_collection_462() ; void handleEZTRACE_starpu_starpu_sched_ctx_delete_worker_collection_463() ; void handleEZTRACE_starpu_starpu_sched_ctx_delete_worker_collection_464() ; void handleEZTRACE_starpu_starpu_sched_ctx_get_worker_collection_465() ; void handleEZTRACE_starpu_starpu_sched_ctx_get_worker_collection_466() ; void handleEZTRACE_starpu_starpu_prefetch_task_input_on_node_495() ; void handleEZTRACE_starpu_starpu_prefetch_task_input_on_node_496() ; void handleEZTRACE_starpu_starpu_malloc_521() ; void handleEZTRACE_starpu_starpu_malloc_522() ; void handleEZTRACE_starpu_starpu_free_523() ; void handleEZTRACE_starpu_starpu_free_524() ; void handleEZTRACE_starpu_starpu_malloc_flags_525() ; void handleEZTRACE_starpu_starpu_malloc_flags_526() ; void handleEZTRACE_starpu_starpu_free_flags_527() ; void handleEZTRACE_starpu_starpu_free_flags_528() ; void handleEZTRACE_starpu_starpu_tag_wait_537() ; void handleEZTRACE_starpu_starpu_tag_wait_538() ; void handleEZTRACE_starpu_starpu_tag_wait_array_539() ; void handleEZTRACE_starpu_starpu_tag_wait_array_540() ; void handleEZTRACE_starpu_starpu_tag_notify_from_apps_541() ; void handleEZTRACE_starpu_starpu_tag_notify_from_apps_542() ; void handleEZTRACE_starpu_starpu_task_init_547() ; void handleEZTRACE_starpu_starpu_task_init_548() ; void handleEZTRACE_starpu_starpu_task_clean_549() ; void handleEZTRACE_starpu_starpu_task_clean_550() ; void handleEZTRACE_starpu_starpu_task_create_551() ; void handleEZTRACE_starpu_starpu_task_create_552() ; void handleEZTRACE_starpu_starpu_task_destroy_553() ; void handleEZTRACE_starpu_starpu_task_destroy_554() ; void handleEZTRACE_starpu_starpu_task_submit_555() ; void handleEZTRACE_starpu_starpu_task_submit_556() ; void handleEZTRACE_starpu_starpu_task_submit_to_ctx_557() ; void handleEZTRACE_starpu_starpu_task_submit_to_ctx_558() ; void handleEZTRACE_starpu_starpu_task_wait_559() ; void handleEZTRACE_starpu_starpu_task_wait_560() ; void handleEZTRACE_starpu_starpu_task_wait_for_all_561() ; void handleEZTRACE_starpu_starpu_task_wait_for_all_562() ; void handleEZTRACE_starpu_starpu_task_wait_for_all_in_ctx_563() ; void handleEZTRACE_starpu_starpu_task_wait_for_all_in_ctx_564() ; void handleEZTRACE_starpu_starpu_task_wait_for_no_ready_565() ; void handleEZTRACE_starpu_starpu_task_wait_for_no_ready_566() ; void handleEZTRACE_starpu_starpu_task_nready_567() ; void handleEZTRACE_starpu_starpu_task_nready_568() ; void handleEZTRACE_starpu_starpu_task_nsubmitted_569() ; void handleEZTRACE_starpu_starpu_task_nsubmitted_570() ; void handleEZTRACE_starpu_starpu_task_dup_581() ; void handleEZTRACE_starpu_starpu_task_dup_582() ; void handleEZTRACE_starpu_starpu_task_bundle_create_587() ; void handleEZTRACE_starpu_starpu_task_bundle_create_588() ; void handleEZTRACE_starpu_starpu_task_bundle_insert_589() ; void handleEZTRACE_starpu_starpu_task_bundle_insert_590() ; void handleEZTRACE_starpu_starpu_task_bundle_remove_591() ; void handleEZTRACE_starpu_starpu_task_bundle_remove_592() ; void handleEZTRACE_starpu_starpu_task_bundle_close_593() ; void handleEZTRACE_starpu_starpu_task_bundle_close_594() ; void handleEZTRACE_starpu_starpu_create_sync_task_595() ; void handleEZTRACE_starpu_starpu_create_sync_task_596() ; void handleEZTRACE_starpu_starpu_execute_on_each_worker_691() ; void handleEZTRACE_starpu_starpu_execute_on_each_worker_692() ; void handleEZTRACE_starpu_starpu_execute_on_each_worker_ex_693() ; void handleEZTRACE_starpu_starpu_execute_on_each_worker_ex_694() ; void handleEZTRACE_starpu_starpu_execute_on_specific_workers_695() ; void handleEZTRACE_starpu_starpu_execute_on_specific_workers_696() ; void handleEZTRACE_starpu_starpu_data_cpy_697() ; void handleEZTRACE_starpu_starpu_data_cpy_698() ; /* Constructor of the plugin. * This function registers the current module to eztrace_convert */ struct eztrace_convert_module starpu_module; void libinit(void) __attribute__ ((constructor)); void libinit(void) { starpu_module.api_version = EZTRACE_API_VERSION; /* Specify the initialization function. * This function will be called once all the plugins are loaded * and the trace is started. * This function usually declared StateTypes, LinkTypes, etc. */ starpu_module.init = eztrace_convert_starpu_init; /* Specify the function to call for handling an event */ starpu_module.handle = handle_starpu_events; /* Specify the module prefix */ starpu_module.module_prefix = starpu_EVENTS_ID; asprintf(&starpu_module.name, "starpu"); asprintf(&starpu_module.description, "module for StarPU framework"); starpu_module.token.data = &starpu_module; /* Register the module to eztrace_convert */ eztrace_convert_register_module(&starpu_module); //printf("module starpu loaded\n"); } void libfinalize(void) __attribute__ ((destructor)); void libfinalize(void) { //printf("unloading module starpu\n"); } /* * This function will be called once all the plugins are loaded * and the trace is started. * This function usually declared StateTypes, LinkTypes, etc. */ int eztrace_convert_starpu_init() { if (get_mode() == EZTRACE_CONVERT) { addContType("CT_Scheduler", "CT_Program", "Scheduler"); // addContainer(0.00000, "CT_Sched", "CT_Scheduler", "C_Prog", "Scheduler", "0"); addVarType("starpu_VAR__0", "submitted task", "CT_Process"); // Internals // addEntityValue("starpu_STATE_0", "ST_Thread", "Executing a task", GTG_GREEN); // API addEntityValue("starpu_STATE_20", "ST_Thread", "starpu_cublas_init", GTG_DARKGREY); addEntityValue("starpu_STATE_21", "ST_Thread", "starpu_cublas_shutdown", GTG_DARKGREY); addEntityValue("starpu_STATE_23", "ST_Thread", "starpu_init", GTG_DARKGREY); addEntityValue("starpu_STATE_24", "ST_Thread", "starpu_pause", GTG_DARKGREY); addEntityValue("starpu_STATE_25", "ST_Thread", "starpu_resume", GTG_DARKGREY); addEntityValue("starpu_STATE_26", "ST_Thread", "starpu_shutdown", GTG_DARKGREY); addEntityValue("starpu_STATE_39", "ST_Thread", "starpu_data_unregister", GTG_DARKGREY); addEntityValue("starpu_STATE_40", "ST_Thread", "starpu_data_unregister_no_coherency", GTG_DARKGREY); addEntityValue("starpu_STATE_41", "ST_Thread", "starpu_data_unregister_submit", GTG_DARKGREY); addEntityValue("starpu_STATE_42", "ST_Thread", "starpu_data_invalidate", GTG_DARKGREY); addEntityValue("starpu_STATE_43", "ST_Thread", "starpu_data_invalidate_submit", GTG_DARKGREY); addEntityValue("starpu_STATE_45", "ST_Thread", "starpu_data_acquire", GTG_DARKGREY); addEntityValue("starpu_STATE_46", "ST_Thread", "starpu_data_acquire_on_node", GTG_DARKGREY); addEntityValue("starpu_STATE_47", "ST_Thread", "starpu_data_acquire_cb", GTG_DARKGREY); addEntityValue("starpu_STATE_48", "ST_Thread", "starpu_data_acquire_on_node_cb", GTG_DARKGREY); addEntityValue("starpu_STATE_49", "ST_Thread", "starpu_data_release", GTG_DARKGREY); addEntityValue("starpu_STATE_50", "ST_Thread", "starpu_data_release_on_node", GTG_DARKGREY); addEntityValue("starpu_STATE_52", "ST_Thread", "starpu_data_request_allocation", GTG_DARKGREY); addEntityValue("starpu_STATE_91", "ST_Thread", "starpu_malloc_on_node", GTG_DARKGREY); addEntityValue("starpu_STATE_92", "ST_Thread", "starpu_free_on_node", GTG_DARKGREY); addEntityValue("starpu_STATE_155", "ST_Thread", "starpu_mpi_isend", GTG_DARKGREY); addEntityValue("starpu_STATE_156", "ST_Thread", "starpu_mpi_irecv", GTG_DARKGREY); addEntityValue("starpu_STATE_157", "ST_Thread", "starpu_mpi_send", GTG_DARKGREY); addEntityValue("starpu_STATE_158", "ST_Thread", "starpu_mpi_recv", GTG_DARKGREY); addEntityValue("starpu_STATE_159", "ST_Thread", "starpu_mpi_isend_detached", GTG_DARKGREY); addEntityValue("starpu_STATE_160", "ST_Thread", "starpu_mpi_irecv_detached", GTG_DARKGREY); addEntityValue("starpu_STATE_161", "ST_Thread", "starpu_mpi_wait", GTG_DARKGREY); addEntityValue("starpu_STATE_162", "ST_Thread", "starpu_mpi_test", GTG_DARKGREY); addEntityValue("starpu_STATE_163", "ST_Thread", "starpu_mpi_barrier", GTG_DARKGREY); addEntityValue("starpu_STATE_164", "ST_Thread", "starpu_mpi_init", GTG_DARKGREY); addEntityValue("starpu_STATE_165", "ST_Thread", "starpu_mpi_initialize", GTG_DARKGREY); addEntityValue("starpu_STATE_166", "ST_Thread", "starpu_mpi_initialize_extended", GTG_DARKGREY); addEntityValue("starpu_STATE_167", "ST_Thread", "starpu_mpi_shutdown", GTG_DARKGREY); addEntityValue("starpu_STATE_168", "ST_Thread", "starpu_mpi_get_data_on_node", GTG_DARKGREY); addEntityValue("starpu_STATE_169", "ST_Thread", "starpu_mpi_get_data_on_node_detached", GTG_DARKGREY); addEntityValue("starpu_STATE_170", "ST_Thread", "starpu_mpi_redux_data", GTG_DARKGREY); addEntityValue("starpu_STATE_171", "ST_Thread", "starpu_mpi_scatter_detached", GTG_DARKGREY); addEntityValue("starpu_STATE_172", "ST_Thread", "starpu_mpi_gather_detached", GTG_DARKGREY); addEntityValue("starpu_STATE_173", "ST_Thread", "starpu_mpi_isend_detached_unlock_tag", GTG_DARKGREY); addEntityValue("starpu_STATE_174", "ST_Thread", "starpu_mpi_irecv_detached_unlock_tag", GTG_DARKGREY); addEntityValue("starpu_STATE_175", "ST_Thread", "starpu_mpi_isend_array_detached_unlock_tag", GTG_DARKGREY); addEntityValue("starpu_STATE_176", "ST_Thread", "starpu_mpi_irecv_array_detached_unlock_tag", GTG_DARKGREY); addEntityValue("starpu_STATE_177", "ST_Thread", "starpu_mpi_comm_amounts_retrieve", GTG_DARKGREY); addEntityValue("starpu_STATE_178", "ST_Thread", "starpu_mpi_cache_flush", GTG_DARKGREY); addEntityValue("starpu_STATE_179", "ST_Thread", "starpu_mpi_cache_flush_all_data", GTG_DARKGREY); addEntityValue("starpu_STATE_180", "ST_Thread", "starpu_mpi_data_register", GTG_DARKGREY); addEntityValue("starpu_STATE_205", "ST_Thread", "starpu_sched_ctx_add_workers", GTG_DARKGREY); addEntityValue("starpu_STATE_206", "ST_Thread", "starpu_sched_ctx_remove_workers", GTG_DARKGREY); addEntityValue("starpu_STATE_207", "ST_Thread", "starpu_sched_ctx_delete", GTG_DARKGREY); addEntityValue("starpu_STATE_208", "ST_Thread", "starpu_sched_ctx_set_inheritor", GTG_DARKGREY); addEntityValue("starpu_STATE_209", "ST_Thread", "starpu_sched_ctx_set_context", GTG_DARKGREY); addEntityValue("starpu_STATE_210", "ST_Thread", "starpu_sched_ctx_get_context", GTG_DARKGREY); addEntityValue("starpu_STATE_211", "ST_Thread", "starpu_sched_ctx_stop_task_submission", GTG_DARKGREY); addEntityValue("starpu_STATE_212", "ST_Thread", "starpu_sched_ctx_finished_submit", GTG_DARKGREY); addEntityValue("starpu_STATE_230", "ST_Thread", "starpu_sched_ctx_create_worker_collection", GTG_DARKGREY); addEntityValue("starpu_STATE_231", "ST_Thread", "starpu_sched_ctx_delete_worker_collection", GTG_DARKGREY); addEntityValue("starpu_STATE_232", "ST_Thread", "starpu_sched_ctx_get_worker_collection", GTG_DARKGREY); addEntityValue("starpu_STATE_247", "ST_Thread", "starpu_prefetch_task_input_on_node", GTG_DARKGREY); addEntityValue("starpu_STATE_260", "ST_Thread", "starpu_malloc", GTG_DARKGREY); addEntityValue("starpu_STATE_261", "ST_Thread", "starpu_free", GTG_DARKGREY); addEntityValue("starpu_STATE_262", "ST_Thread", "starpu_malloc_flags", GTG_DARKGREY); addEntityValue("starpu_STATE_263", "ST_Thread", "starpu_free_flags", GTG_DARKGREY); addEntityValue("starpu_STATE_268", "ST_Thread", "starpu_tag_wait", GTG_DARKGREY); addEntityValue("starpu_STATE_269", "ST_Thread", "starpu_tag_wait_array", GTG_DARKGREY); addEntityValue("starpu_STATE_270", "ST_Thread", "starpu_tag_notify_from_apps", GTG_DARKGREY); addEntityValue("starpu_STATE_273", "ST_Thread", "starpu_task_init", GTG_DARKGREY); addEntityValue("starpu_STATE_274", "ST_Thread", "starpu_task_clean", GTG_DARKGREY); addEntityValue("starpu_STATE_275", "ST_Thread", "starpu_task_create", GTG_DARKGREY); addEntityValue("starpu_STATE_276", "ST_Thread", "starpu_task_destroy", GTG_DARKGREY); addEntityValue("starpu_STATE_277", "ST_Thread", "starpu_task_submit", GTG_DARKGREY); addEntityValue("starpu_STATE_278", "ST_Thread", "starpu_task_submit_to_ctx", GTG_DARKGREY); addEntityValue("starpu_STATE_279", "ST_Thread", "starpu_task_wait", GTG_DARKGREY); addEntityValue("starpu_STATE_280", "ST_Thread", "starpu_task_wait_for_all", GTG_DARKGREY); addEntityValue("starpu_STATE_281", "ST_Thread", "starpu_task_wait_for_all_in_ctx", GTG_DARKGREY); addEntityValue("starpu_STATE_282", "ST_Thread", "starpu_task_wait_for_no_ready", GTG_DARKGREY); addEntityValue("starpu_STATE_283", "ST_Thread", "starpu_task_nready", GTG_DARKGREY); addEntityValue("starpu_STATE_284", "ST_Thread", "starpu_task_nsubmitted", GTG_DARKGREY); addEntityValue("starpu_STATE_290", "ST_Thread", "starpu_task_dup", GTG_DARKGREY); addEntityValue("starpu_STATE_293", "ST_Thread", "starpu_task_bundle_create", GTG_DARKGREY); addEntityValue("starpu_STATE_294", "ST_Thread", "starpu_task_bundle_insert", GTG_DARKGREY); addEntityValue("starpu_STATE_295", "ST_Thread", "starpu_task_bundle_remove", GTG_DARKGREY); addEntityValue("starpu_STATE_296", "ST_Thread", "starpu_task_bundle_close", GTG_DARKGREY); addEntityValue("starpu_STATE_297", "ST_Thread", "starpu_create_sync_task", GTG_DARKGREY); addEntityValue("starpu_STATE_345", "ST_Thread", "starpu_execute_on_each_worker", GTG_DARKGREY); addEntityValue("starpu_STATE_346", "ST_Thread", "starpu_execute_on_each_worker_ex", GTG_DARKGREY); addEntityValue("starpu_STATE_347", "ST_Thread", "starpu_execute_on_specific_workers", GTG_DARKGREY); addEntityValue("starpu_STATE_348", "ST_Thread", "starpu_data_cpy", GTG_DARKGREY); } ezt_list_new(&starpu_link_source_list); ezt_list_new(&starpu_task_type_stats_list); } /* This function is called by eztrace_convert for each event to * handle. * It shall return 1 if the event was handled successfully or * 0 otherwise. */ int handle_starpu_events(eztrace_event_t *ev) { switch (LITL_READ_GET_CODE(ev)) { case EZTRACE_starpu__starpu_driver_start_job: handleEZTRACE_starpu__starpu_driver_start_job(); break; case EZTRACE_starpu__starpu_driver_end_job: handleEZTRACE_starpu__starpu_driver_end_job(); break; case EZTRACE_starpu_starpu_cublas_init_41: handleEZTRACE_starpu_starpu_cublas_init_41(); break; case EZTRACE_starpu_starpu_cublas_init_42: handleEZTRACE_starpu_starpu_cublas_init_42(); break; case EZTRACE_starpu_starpu_cublas_shutdown_43: handleEZTRACE_starpu_starpu_cublas_shutdown_43(); break; case EZTRACE_starpu_starpu_cublas_shutdown_44: handleEZTRACE_starpu_starpu_cublas_shutdown_44(); break; case EZTRACE_starpu_starpu_init_47: handleEZTRACE_starpu_starpu_init_47(); break; case EZTRACE_starpu_starpu_init_48: handleEZTRACE_starpu_starpu_init_48(); break; case EZTRACE_starpu_starpu_pause_49: handleEZTRACE_starpu_starpu_pause_49(); break; case EZTRACE_starpu_starpu_pause_50: handleEZTRACE_starpu_starpu_pause_50(); break; case EZTRACE_starpu_starpu_resume_51: handleEZTRACE_starpu_starpu_resume_51(); break; case EZTRACE_starpu_starpu_resume_52: handleEZTRACE_starpu_starpu_resume_52(); break; case EZTRACE_starpu_starpu_shutdown_53: handleEZTRACE_starpu_starpu_shutdown_53(); break; case EZTRACE_starpu_starpu_shutdown_54: handleEZTRACE_starpu_starpu_shutdown_54(); break; case EZTRACE_starpu_starpu_data_unregister_79: handleEZTRACE_starpu_starpu_data_unregister_79(); break; case EZTRACE_starpu_starpu_data_unregister_80: handleEZTRACE_starpu_starpu_data_unregister_80(); break; case EZTRACE_starpu_starpu_data_unregister_no_coherency_81: handleEZTRACE_starpu_starpu_data_unregister_no_coherency_81(); break; case EZTRACE_starpu_starpu_data_unregister_no_coherency_82: handleEZTRACE_starpu_starpu_data_unregister_no_coherency_82(); break; case EZTRACE_starpu_starpu_data_unregister_submit_83: handleEZTRACE_starpu_starpu_data_unregister_submit_83(); break; case EZTRACE_starpu_starpu_data_unregister_submit_84: handleEZTRACE_starpu_starpu_data_unregister_submit_84(); break; case EZTRACE_starpu_starpu_data_invalidate_85: handleEZTRACE_starpu_starpu_data_invalidate_85(); break; case EZTRACE_starpu_starpu_data_invalidate_86: handleEZTRACE_starpu_starpu_data_invalidate_86(); break; case EZTRACE_starpu_starpu_data_invalidate_submit_87: handleEZTRACE_starpu_starpu_data_invalidate_submit_87(); break; case EZTRACE_starpu_starpu_data_invalidate_submit_88: handleEZTRACE_starpu_starpu_data_invalidate_submit_88(); break; case EZTRACE_starpu_starpu_data_acquire_91: handleEZTRACE_starpu_starpu_data_acquire_91(); break; case EZTRACE_starpu_starpu_data_acquire_92: handleEZTRACE_starpu_starpu_data_acquire_92(); break; case EZTRACE_starpu_starpu_data_acquire_on_node_93: handleEZTRACE_starpu_starpu_data_acquire_on_node_93(); break; case EZTRACE_starpu_starpu_data_acquire_on_node_94: handleEZTRACE_starpu_starpu_data_acquire_on_node_94(); break; case EZTRACE_starpu_starpu_data_acquire_cb_95: handleEZTRACE_starpu_starpu_data_acquire_cb_95(); break; case EZTRACE_starpu_starpu_data_acquire_cb_96: handleEZTRACE_starpu_starpu_data_acquire_cb_96(); break; case EZTRACE_starpu_starpu_data_acquire_on_node_cb_97: handleEZTRACE_starpu_starpu_data_acquire_on_node_cb_97(); break; case EZTRACE_starpu_starpu_data_acquire_on_node_cb_98: handleEZTRACE_starpu_starpu_data_acquire_on_node_cb_98(); break; case EZTRACE_starpu_starpu_data_release_99: handleEZTRACE_starpu_starpu_data_release_99(); break; case EZTRACE_starpu_starpu_data_release_100: handleEZTRACE_starpu_starpu_data_release_100(); break; case EZTRACE_starpu_starpu_data_release_on_node_101: handleEZTRACE_starpu_starpu_data_release_on_node_101(); break; case EZTRACE_starpu_starpu_data_release_on_node_102: handleEZTRACE_starpu_starpu_data_release_on_node_102(); break; case EZTRACE_starpu_starpu_malloc_on_node_183: handleEZTRACE_starpu_starpu_malloc_on_node_183(); break; case EZTRACE_starpu_starpu_malloc_on_node_184: handleEZTRACE_starpu_starpu_malloc_on_node_184(); break; case EZTRACE_starpu_starpu_free_on_node_185: handleEZTRACE_starpu_starpu_free_on_node_185(); break; case EZTRACE_starpu_starpu_free_on_node_186: handleEZTRACE_starpu_starpu_free_on_node_186(); break; case EZTRACE_starpu_starpu_mpi_isend_311: handleEZTRACE_starpu_starpu_mpi_isend_311(); break; case EZTRACE_starpu_starpu_mpi_isend_312: handleEZTRACE_starpu_starpu_mpi_isend_312(); break; case EZTRACE_starpu_starpu_mpi_irecv_313: handleEZTRACE_starpu_starpu_mpi_irecv_313(); break; case EZTRACE_starpu_starpu_mpi_irecv_314: handleEZTRACE_starpu_starpu_mpi_irecv_314(); break; case EZTRACE_starpu_starpu_mpi_send_315: handleEZTRACE_starpu_starpu_mpi_send_315(); break; case EZTRACE_starpu_starpu_mpi_send_316: handleEZTRACE_starpu_starpu_mpi_send_316(); break; case EZTRACE_starpu_starpu_mpi_recv_317: handleEZTRACE_starpu_starpu_mpi_recv_317(); break; case EZTRACE_starpu_starpu_mpi_recv_318: handleEZTRACE_starpu_starpu_mpi_recv_318(); break; case EZTRACE_starpu_starpu_mpi_isend_detached_319: handleEZTRACE_starpu_starpu_mpi_isend_detached_319(); break; case EZTRACE_starpu_starpu_mpi_isend_detached_320: handleEZTRACE_starpu_starpu_mpi_isend_detached_320(); break; case EZTRACE_starpu_starpu_mpi_irecv_detached_321: handleEZTRACE_starpu_starpu_mpi_irecv_detached_321(); break; case EZTRACE_starpu_starpu_mpi_irecv_detached_322: handleEZTRACE_starpu_starpu_mpi_irecv_detached_322(); break; case EZTRACE_starpu_starpu_mpi_wait_323: handleEZTRACE_starpu_starpu_mpi_wait_323(); break; case EZTRACE_starpu_starpu_mpi_wait_324: handleEZTRACE_starpu_starpu_mpi_wait_324(); break; case EZTRACE_starpu_starpu_mpi_test_325: handleEZTRACE_starpu_starpu_mpi_test_325(); break; case EZTRACE_starpu_starpu_mpi_test_326: handleEZTRACE_starpu_starpu_mpi_test_326(); break; case EZTRACE_starpu_starpu_mpi_barrier_327: handleEZTRACE_starpu_starpu_mpi_barrier_327(); break; case EZTRACE_starpu_starpu_mpi_barrier_328: handleEZTRACE_starpu_starpu_mpi_barrier_328(); break; case EZTRACE_starpu_starpu_mpi_init_329: handleEZTRACE_starpu_starpu_mpi_init_329(); break; case EZTRACE_starpu_starpu_mpi_init_330: handleEZTRACE_starpu_starpu_mpi_init_330(); break; case EZTRACE_starpu_starpu_mpi_initialize_331: handleEZTRACE_starpu_starpu_mpi_initialize_331(); break; case EZTRACE_starpu_starpu_mpi_initialize_332: handleEZTRACE_starpu_starpu_mpi_initialize_332(); break; case EZTRACE_starpu_starpu_mpi_initialize_extended_333: handleEZTRACE_starpu_starpu_mpi_initialize_extended_333(); break; case EZTRACE_starpu_starpu_mpi_initialize_extended_334: handleEZTRACE_starpu_starpu_mpi_initialize_extended_334(); break; case EZTRACE_starpu_starpu_mpi_shutdown_335: handleEZTRACE_starpu_starpu_mpi_shutdown_335(); break; case EZTRACE_starpu_starpu_mpi_shutdown_336: handleEZTRACE_starpu_starpu_mpi_shutdown_336(); break; case EZTRACE_starpu_starpu_mpi_get_data_on_node_337: handleEZTRACE_starpu_starpu_mpi_get_data_on_node_337(); break; case EZTRACE_starpu_starpu_mpi_get_data_on_node_338: handleEZTRACE_starpu_starpu_mpi_get_data_on_node_338(); break; case EZTRACE_starpu_starpu_mpi_get_data_on_node_detached_339: handleEZTRACE_starpu_starpu_mpi_get_data_on_node_detached_339(); break; case EZTRACE_starpu_starpu_mpi_get_data_on_node_detached_340: handleEZTRACE_starpu_starpu_mpi_get_data_on_node_detached_340(); break; case EZTRACE_starpu_starpu_mpi_redux_data_341: handleEZTRACE_starpu_starpu_mpi_redux_data_341(); break; case EZTRACE_starpu_starpu_mpi_redux_data_342: handleEZTRACE_starpu_starpu_mpi_redux_data_342(); break; case EZTRACE_starpu_starpu_mpi_scatter_detached_343: handleEZTRACE_starpu_starpu_mpi_scatter_detached_343(); break; case EZTRACE_starpu_starpu_mpi_scatter_detached_344: handleEZTRACE_starpu_starpu_mpi_scatter_detached_344(); break; case EZTRACE_starpu_starpu_mpi_gather_detached_345: handleEZTRACE_starpu_starpu_mpi_gather_detached_345(); break; case EZTRACE_starpu_starpu_mpi_gather_detached_346: handleEZTRACE_starpu_starpu_mpi_gather_detached_346(); break; case EZTRACE_starpu_starpu_mpi_isend_detached_unlock_tag_347: handleEZTRACE_starpu_starpu_mpi_isend_detached_unlock_tag_347(); break; case EZTRACE_starpu_starpu_mpi_isend_detached_unlock_tag_348: handleEZTRACE_starpu_starpu_mpi_isend_detached_unlock_tag_348(); break; case EZTRACE_starpu_starpu_mpi_irecv_detached_unlock_tag_349: handleEZTRACE_starpu_starpu_mpi_irecv_detached_unlock_tag_349(); break; case EZTRACE_starpu_starpu_mpi_irecv_detached_unlock_tag_350: handleEZTRACE_starpu_starpu_mpi_irecv_detached_unlock_tag_350(); break; case EZTRACE_starpu_starpu_mpi_isend_array_detached_unlock_tag_351: handleEZTRACE_starpu_starpu_mpi_isend_array_detached_unlock_tag_351(); break; case EZTRACE_starpu_starpu_mpi_isend_array_detached_unlock_tag_352: handleEZTRACE_starpu_starpu_mpi_isend_array_detached_unlock_tag_352(); break; case EZTRACE_starpu_starpu_mpi_irecv_array_detached_unlock_tag_353: handleEZTRACE_starpu_starpu_mpi_irecv_array_detached_unlock_tag_353(); break; case EZTRACE_starpu_starpu_mpi_irecv_array_detached_unlock_tag_354: handleEZTRACE_starpu_starpu_mpi_irecv_array_detached_unlock_tag_354(); break; case EZTRACE_starpu_starpu_mpi_comm_amounts_retrieve_355: handleEZTRACE_starpu_starpu_mpi_comm_amounts_retrieve_355(); break; case EZTRACE_starpu_starpu_mpi_comm_amounts_retrieve_356: handleEZTRACE_starpu_starpu_mpi_comm_amounts_retrieve_356(); break; case EZTRACE_starpu_starpu_mpi_cache_flush_357: handleEZTRACE_starpu_starpu_mpi_cache_flush_357(); break; case EZTRACE_starpu_starpu_mpi_cache_flush_358: handleEZTRACE_starpu_starpu_mpi_cache_flush_358(); break; case EZTRACE_starpu_starpu_mpi_cache_flush_all_data_359: handleEZTRACE_starpu_starpu_mpi_cache_flush_all_data_359(); break; case EZTRACE_starpu_starpu_mpi_cache_flush_all_data_360: handleEZTRACE_starpu_starpu_mpi_cache_flush_all_data_360(); break; case EZTRACE_starpu_starpu_mpi_data_register_361: handleEZTRACE_starpu_starpu_mpi_data_register_361(); break; case EZTRACE_starpu_starpu_mpi_data_register_362: handleEZTRACE_starpu_starpu_mpi_data_register_362(); break; case EZTRACE_starpu_starpu_sched_ctx_add_workers_411: handleEZTRACE_starpu_starpu_sched_ctx_add_workers_411(); break; case EZTRACE_starpu_starpu_sched_ctx_add_workers_412: handleEZTRACE_starpu_starpu_sched_ctx_add_workers_412(); break; case EZTRACE_starpu_starpu_sched_ctx_remove_workers_413: handleEZTRACE_starpu_starpu_sched_ctx_remove_workers_413(); break; case EZTRACE_starpu_starpu_sched_ctx_remove_workers_414: handleEZTRACE_starpu_starpu_sched_ctx_remove_workers_414(); break; case EZTRACE_starpu_starpu_sched_ctx_delete_415: handleEZTRACE_starpu_starpu_sched_ctx_delete_415(); break; case EZTRACE_starpu_starpu_sched_ctx_delete_416: handleEZTRACE_starpu_starpu_sched_ctx_delete_416(); break; case EZTRACE_starpu_starpu_sched_ctx_set_inheritor_417: handleEZTRACE_starpu_starpu_sched_ctx_set_inheritor_417(); break; case EZTRACE_starpu_starpu_sched_ctx_set_inheritor_418: handleEZTRACE_starpu_starpu_sched_ctx_set_inheritor_418(); break; case EZTRACE_starpu_starpu_sched_ctx_set_context_419: handleEZTRACE_starpu_starpu_sched_ctx_set_context_419(); break; case EZTRACE_starpu_starpu_sched_ctx_set_context_420: handleEZTRACE_starpu_starpu_sched_ctx_set_context_420(); break; case EZTRACE_starpu_starpu_sched_ctx_get_context_421: handleEZTRACE_starpu_starpu_sched_ctx_get_context_421(); break; case EZTRACE_starpu_starpu_sched_ctx_get_context_422: handleEZTRACE_starpu_starpu_sched_ctx_get_context_422(); break; case EZTRACE_starpu_starpu_sched_ctx_stop_task_submission_423: handleEZTRACE_starpu_starpu_sched_ctx_stop_task_submission_423(); break; case EZTRACE_starpu_starpu_sched_ctx_stop_task_submission_424: handleEZTRACE_starpu_starpu_sched_ctx_stop_task_submission_424(); break; case EZTRACE_starpu_starpu_sched_ctx_finished_submit_425: handleEZTRACE_starpu_starpu_sched_ctx_finished_submit_425(); break; case EZTRACE_starpu_starpu_sched_ctx_finished_submit_426: handleEZTRACE_starpu_starpu_sched_ctx_finished_submit_426(); break; case EZTRACE_starpu_starpu_sched_ctx_create_worker_collection_461: handleEZTRACE_starpu_starpu_sched_ctx_create_worker_collection_461(); break; case EZTRACE_starpu_starpu_sched_ctx_create_worker_collection_462: handleEZTRACE_starpu_starpu_sched_ctx_create_worker_collection_462(); break; case EZTRACE_starpu_starpu_sched_ctx_delete_worker_collection_463: handleEZTRACE_starpu_starpu_sched_ctx_delete_worker_collection_463(); break; case EZTRACE_starpu_starpu_sched_ctx_delete_worker_collection_464: handleEZTRACE_starpu_starpu_sched_ctx_delete_worker_collection_464(); break; case EZTRACE_starpu_starpu_sched_ctx_get_worker_collection_465: handleEZTRACE_starpu_starpu_sched_ctx_get_worker_collection_465(); break; case EZTRACE_starpu_starpu_sched_ctx_get_worker_collection_466: handleEZTRACE_starpu_starpu_sched_ctx_get_worker_collection_466(); break; case EZTRACE_starpu_starpu_prefetch_task_input_on_node_495: handleEZTRACE_starpu_starpu_prefetch_task_input_on_node_495(); break; case EZTRACE_starpu_starpu_prefetch_task_input_on_node_496: handleEZTRACE_starpu_starpu_prefetch_task_input_on_node_496(); break; case EZTRACE_starpu_starpu_malloc_521: handleEZTRACE_starpu_starpu_malloc_521(); break; case EZTRACE_starpu_starpu_malloc_522: handleEZTRACE_starpu_starpu_malloc_522(); break; case EZTRACE_starpu_starpu_free_523: handleEZTRACE_starpu_starpu_free_523(); break; case EZTRACE_starpu_starpu_free_524: handleEZTRACE_starpu_starpu_free_524(); break; case EZTRACE_starpu_starpu_malloc_flags_525: handleEZTRACE_starpu_starpu_malloc_flags_525(); break; case EZTRACE_starpu_starpu_malloc_flags_526: handleEZTRACE_starpu_starpu_malloc_flags_526(); break; case EZTRACE_starpu_starpu_free_flags_527: handleEZTRACE_starpu_starpu_free_flags_527(); break; case EZTRACE_starpu_starpu_free_flags_528: handleEZTRACE_starpu_starpu_free_flags_528(); break; case EZTRACE_starpu_starpu_tag_wait_537: handleEZTRACE_starpu_starpu_tag_wait_537(); break; case EZTRACE_starpu_starpu_tag_wait_538: handleEZTRACE_starpu_starpu_tag_wait_538(); break; case EZTRACE_starpu_starpu_tag_wait_array_539: handleEZTRACE_starpu_starpu_tag_wait_array_539(); break; case EZTRACE_starpu_starpu_tag_wait_array_540: handleEZTRACE_starpu_starpu_tag_wait_array_540(); break; case EZTRACE_starpu_starpu_tag_notify_from_apps_541: handleEZTRACE_starpu_starpu_tag_notify_from_apps_541(); break; case EZTRACE_starpu_starpu_tag_notify_from_apps_542: handleEZTRACE_starpu_starpu_tag_notify_from_apps_542(); break; case EZTRACE_starpu_starpu_task_init_547: handleEZTRACE_starpu_starpu_task_init_547(); break; case EZTRACE_starpu_starpu_task_init_548: handleEZTRACE_starpu_starpu_task_init_548(); break; case EZTRACE_starpu_starpu_task_clean_549: handleEZTRACE_starpu_starpu_task_clean_549(); break; case EZTRACE_starpu_starpu_task_clean_550: handleEZTRACE_starpu_starpu_task_clean_550(); break; case EZTRACE_starpu_starpu_task_create_551: handleEZTRACE_starpu_starpu_task_create_551(); break; case EZTRACE_starpu_starpu_task_create_552: handleEZTRACE_starpu_starpu_task_create_552(); break; case EZTRACE_starpu_starpu_task_destroy_553: handleEZTRACE_starpu_starpu_task_destroy_553(); break; case EZTRACE_starpu_starpu_task_destroy_554: handleEZTRACE_starpu_starpu_task_destroy_554(); break; case EZTRACE_starpu_starpu_task_submit_555: handleEZTRACE_starpu_starpu_task_submit_555(); break; case EZTRACE_starpu_starpu_task_submit_556: handleEZTRACE_starpu_starpu_task_submit_556(); break; case EZTRACE_starpu_starpu_task_submit_to_ctx_557: handleEZTRACE_starpu_starpu_task_submit_to_ctx_557(); break; case EZTRACE_starpu_starpu_task_submit_to_ctx_558: handleEZTRACE_starpu_starpu_task_submit_to_ctx_558(); break; case EZTRACE_starpu_starpu_task_wait_559: handleEZTRACE_starpu_starpu_task_wait_559(); break; case EZTRACE_starpu_starpu_task_wait_560: handleEZTRACE_starpu_starpu_task_wait_560(); break; case EZTRACE_starpu_starpu_task_wait_for_all_561: handleEZTRACE_starpu_starpu_task_wait_for_all_561(); break; case EZTRACE_starpu_starpu_task_wait_for_all_562: handleEZTRACE_starpu_starpu_task_wait_for_all_562(); break; case EZTRACE_starpu_starpu_task_wait_for_all_in_ctx_563: handleEZTRACE_starpu_starpu_task_wait_for_all_in_ctx_563(); break; case EZTRACE_starpu_starpu_task_wait_for_all_in_ctx_564: handleEZTRACE_starpu_starpu_task_wait_for_all_in_ctx_564(); break; case EZTRACE_starpu_starpu_task_wait_for_no_ready_565: handleEZTRACE_starpu_starpu_task_wait_for_no_ready_565(); break; case EZTRACE_starpu_starpu_task_wait_for_no_ready_566: handleEZTRACE_starpu_starpu_task_wait_for_no_ready_566(); break; case EZTRACE_starpu_starpu_task_nready_567: handleEZTRACE_starpu_starpu_task_nready_567(); break; case EZTRACE_starpu_starpu_task_nready_568: handleEZTRACE_starpu_starpu_task_nready_568(); break; case EZTRACE_starpu_starpu_task_nsubmitted_569: handleEZTRACE_starpu_starpu_task_nsubmitted_569(); break; case EZTRACE_starpu_starpu_task_nsubmitted_570: handleEZTRACE_starpu_starpu_task_nsubmitted_570(); break; case EZTRACE_starpu_starpu_task_dup_581: handleEZTRACE_starpu_starpu_task_dup_581(); break; case EZTRACE_starpu_starpu_task_dup_582: handleEZTRACE_starpu_starpu_task_dup_582(); break; case EZTRACE_starpu_starpu_task_bundle_create_587: handleEZTRACE_starpu_starpu_task_bundle_create_587(); break; case EZTRACE_starpu_starpu_task_bundle_create_588: handleEZTRACE_starpu_starpu_task_bundle_create_588(); break; case EZTRACE_starpu_starpu_task_bundle_insert_589: handleEZTRACE_starpu_starpu_task_bundle_insert_589(); break; case EZTRACE_starpu_starpu_task_bundle_insert_590: handleEZTRACE_starpu_starpu_task_bundle_insert_590(); break; case EZTRACE_starpu_starpu_task_bundle_remove_591: handleEZTRACE_starpu_starpu_task_bundle_remove_591(); break; case EZTRACE_starpu_starpu_task_bundle_remove_592: handleEZTRACE_starpu_starpu_task_bundle_remove_592(); break; case EZTRACE_starpu_starpu_task_bundle_close_593: handleEZTRACE_starpu_starpu_task_bundle_close_593(); break; case EZTRACE_starpu_starpu_task_bundle_close_594: handleEZTRACE_starpu_starpu_task_bundle_close_594(); break; case EZTRACE_starpu_starpu_create_sync_task_595: handleEZTRACE_starpu_starpu_create_sync_task_595(); break; case EZTRACE_starpu_starpu_create_sync_task_596: handleEZTRACE_starpu_starpu_create_sync_task_596(); break; case EZTRACE_starpu_starpu_execute_on_each_worker_691: handleEZTRACE_starpu_starpu_execute_on_each_worker_691(); break; case EZTRACE_starpu_starpu_execute_on_each_worker_692: handleEZTRACE_starpu_starpu_execute_on_each_worker_692(); break; case EZTRACE_starpu_starpu_execute_on_each_worker_ex_693: handleEZTRACE_starpu_starpu_execute_on_each_worker_ex_693(); break; case EZTRACE_starpu_starpu_execute_on_each_worker_ex_694: handleEZTRACE_starpu_starpu_execute_on_each_worker_ex_694(); break; case EZTRACE_starpu_starpu_execute_on_specific_workers_695: handleEZTRACE_starpu_starpu_execute_on_specific_workers_695(); break; case EZTRACE_starpu_starpu_execute_on_specific_workers_696: handleEZTRACE_starpu_starpu_execute_on_specific_workers_696(); break; case EZTRACE_starpu_starpu_data_cpy_697: handleEZTRACE_starpu_starpu_data_cpy_697(); break; case EZTRACE_starpu_starpu_data_cpy_698: handleEZTRACE_starpu_starpu_data_cpy_698(); break; default: /* The event was not handled */ return 0; } return 1; } // Internals void handleEZTRACE_starpu__starpu_driver_start_job() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); char *proc = calloc(1, sizeof(char) * 9); sprintf(proc, "CT_SP#%i", CUR_RANK); CHANGE() subVar (CURRENT, "starpu_VAR__0", proc, (varPrec) 1); // CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_0"); // free(proc); } void handleEZTRACE_starpu__starpu_driver_end_job() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); // CHANGE() popState (CURRENT, "ST_Thread", thread_id); } //API void handleEZTRACE_starpu_starpu_cublas_init_41() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_20"); } void handleEZTRACE_starpu_starpu_cublas_init_42() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_cublas_shutdown_43() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_21"); } void handleEZTRACE_starpu_starpu_cublas_shutdown_44() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_init_47() { FUNC_NAME; char *proc = calloc(1, sizeof(char) * 5); char *procCpt = calloc(1, sizeof(char) * 9); DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_23"); sprintf(procCpt,"CT_SP#%i", CUR_RANK); sprintf(proc,"P#%i", CUR_RANK); addContainer(0.00000, procCpt, "CT_Scheduler", proc, "Task queue ", "0"); CHANGE() setVar (CURRENT, "starpu_VAR__0", procCpt, 0); } void handleEZTRACE_starpu_starpu_init_48() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_pause_49() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_24"); } void handleEZTRACE_starpu_starpu_pause_50() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_resume_51() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_25"); } void handleEZTRACE_starpu_starpu_resume_52() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_shutdown_53() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_26"); } void handleEZTRACE_starpu_starpu_shutdown_54() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_data_unregister_79() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_39"); } void handleEZTRACE_starpu_starpu_data_unregister_80() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_data_unregister_no_coherency_81() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_40"); } void handleEZTRACE_starpu_starpu_data_unregister_no_coherency_82() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_data_unregister_submit_83() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_41"); } void handleEZTRACE_starpu_starpu_data_unregister_submit_84() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_data_invalidate_85() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_42"); } void handleEZTRACE_starpu_starpu_data_invalidate_86() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_data_invalidate_submit_87() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_43"); } void handleEZTRACE_starpu_starpu_data_invalidate_submit_88() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_data_acquire_91() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_45"); } void handleEZTRACE_starpu_starpu_data_acquire_92() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_data_acquire_on_node_93() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_46"); } void handleEZTRACE_starpu_starpu_data_acquire_on_node_94() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_data_acquire_cb_95() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_47"); } void handleEZTRACE_starpu_starpu_data_acquire_cb_96() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_data_acquire_on_node_cb_97() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_48"); } void handleEZTRACE_starpu_starpu_data_acquire_on_node_cb_98() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_data_release_99() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_49"); } void handleEZTRACE_starpu_starpu_data_release_100() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_data_release_on_node_101() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_50"); } void handleEZTRACE_starpu_starpu_data_release_on_node_102() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_malloc_on_node_183() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_91"); } void handleEZTRACE_starpu_starpu_malloc_on_node_184() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_free_on_node_185() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_92"); } void handleEZTRACE_starpu_starpu_free_on_node_186() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_isend_311() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_155"); } void handleEZTRACE_starpu_starpu_mpi_isend_312() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_irecv_313() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_156"); } void handleEZTRACE_starpu_starpu_mpi_irecv_314() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_send_315() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_157"); } void handleEZTRACE_starpu_starpu_mpi_send_316() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_recv_317() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_158"); } void handleEZTRACE_starpu_starpu_mpi_recv_318() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_isend_detached_319() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_159"); } void handleEZTRACE_starpu_starpu_mpi_isend_detached_320() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_irecv_detached_321() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_160"); } void handleEZTRACE_starpu_starpu_mpi_irecv_detached_322() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_wait_323() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_161"); } void handleEZTRACE_starpu_starpu_mpi_wait_324() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_test_325() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_162"); } void handleEZTRACE_starpu_starpu_mpi_test_326() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_barrier_327() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_163"); } void handleEZTRACE_starpu_starpu_mpi_barrier_328() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_init_329() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_164"); } void handleEZTRACE_starpu_starpu_mpi_init_330() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_initialize_331() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_165"); } void handleEZTRACE_starpu_starpu_mpi_initialize_332() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_initialize_extended_333() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_166"); } void handleEZTRACE_starpu_starpu_mpi_initialize_extended_334() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_shutdown_335() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_167"); } void handleEZTRACE_starpu_starpu_mpi_shutdown_336() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_get_data_on_node_337() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_168"); } void handleEZTRACE_starpu_starpu_mpi_get_data_on_node_338() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_get_data_on_node_detached_339() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_169"); } void handleEZTRACE_starpu_starpu_mpi_get_data_on_node_detached_340() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_redux_data_341() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_170"); } void handleEZTRACE_starpu_starpu_mpi_redux_data_342() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_scatter_detached_343() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_171"); } void handleEZTRACE_starpu_starpu_mpi_scatter_detached_344() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_gather_detached_345() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_172"); } void handleEZTRACE_starpu_starpu_mpi_gather_detached_346() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_isend_detached_unlock_tag_347() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_173"); } void handleEZTRACE_starpu_starpu_mpi_isend_detached_unlock_tag_348() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_irecv_detached_unlock_tag_349() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_174"); } void handleEZTRACE_starpu_starpu_mpi_irecv_detached_unlock_tag_350() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_isend_array_detached_unlock_tag_351() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_175"); } void handleEZTRACE_starpu_starpu_mpi_isend_array_detached_unlock_tag_352() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_irecv_array_detached_unlock_tag_353() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_176"); } void handleEZTRACE_starpu_starpu_mpi_irecv_array_detached_unlock_tag_354() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_comm_amounts_retrieve_355() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_177"); } void handleEZTRACE_starpu_starpu_mpi_comm_amounts_retrieve_356() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_cache_flush_357() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_178"); } void handleEZTRACE_starpu_starpu_mpi_cache_flush_358() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_cache_flush_all_data_359() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_179"); } void handleEZTRACE_starpu_starpu_mpi_cache_flush_all_data_360() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_mpi_data_register_361() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_180"); } void handleEZTRACE_starpu_starpu_mpi_data_register_362() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_sched_ctx_add_workers_411() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_205"); } void handleEZTRACE_starpu_starpu_sched_ctx_add_workers_412() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_sched_ctx_remove_workers_413() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_206"); } void handleEZTRACE_starpu_starpu_sched_ctx_remove_workers_414() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_sched_ctx_delete_415() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_207"); } void handleEZTRACE_starpu_starpu_sched_ctx_delete_416() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_sched_ctx_set_inheritor_417() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_208"); } void handleEZTRACE_starpu_starpu_sched_ctx_set_inheritor_418() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_sched_ctx_set_context_419() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_209"); } void handleEZTRACE_starpu_starpu_sched_ctx_set_context_420() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_sched_ctx_get_context_421() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_210"); } void handleEZTRACE_starpu_starpu_sched_ctx_get_context_422() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_sched_ctx_stop_task_submission_423() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_211"); } void handleEZTRACE_starpu_starpu_sched_ctx_stop_task_submission_424() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_sched_ctx_finished_submit_425() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_212"); } void handleEZTRACE_starpu_starpu_sched_ctx_finished_submit_426() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_sched_ctx_create_worker_collection_461() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_230"); } void handleEZTRACE_starpu_starpu_sched_ctx_create_worker_collection_462() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_sched_ctx_delete_worker_collection_463() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_231"); } void handleEZTRACE_starpu_starpu_sched_ctx_delete_worker_collection_464() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_sched_ctx_get_worker_collection_465() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_232"); } void handleEZTRACE_starpu_starpu_sched_ctx_get_worker_collection_466() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_prefetch_task_input_on_node_495() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_247"); } void handleEZTRACE_starpu_starpu_prefetch_task_input_on_node_496() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_malloc_521() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_260"); } void handleEZTRACE_starpu_starpu_malloc_522() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_free_523() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_261"); } void handleEZTRACE_starpu_starpu_free_524() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_malloc_flags_525() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_262"); } void handleEZTRACE_starpu_starpu_malloc_flags_526() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_free_flags_527() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_263"); } void handleEZTRACE_starpu_starpu_free_flags_528() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_tag_wait_537() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_268"); } void handleEZTRACE_starpu_starpu_tag_wait_538() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_tag_wait_array_539() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_269"); } void handleEZTRACE_starpu_starpu_tag_wait_array_540() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_tag_notify_from_apps_541() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_270"); } void handleEZTRACE_starpu_starpu_tag_notify_from_apps_542() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_init_547() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_273"); } void handleEZTRACE_starpu_starpu_task_init_548() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_clean_549() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_274"); } void handleEZTRACE_starpu_starpu_task_clean_550() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_create_551() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_275"); } void handleEZTRACE_starpu_starpu_task_create_552() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_destroy_553() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_276"); } void handleEZTRACE_starpu_starpu_task_destroy_554() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_submit_555() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_277"); } void handleEZTRACE_starpu_starpu_task_submit_556() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); char *proc = calloc(1, sizeof(char) * 9); sprintf(proc, "CT_SP#%i", CUR_RANK); CHANGE() addVar (CURRENT, "starpu_VAR__0", proc, (varPrec) 1); CHANGE() popState (CURRENT, "ST_Thread", thread_id); // free(proc); } void handleEZTRACE_starpu_starpu_task_submit_to_ctx_557() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_278"); } void handleEZTRACE_starpu_starpu_task_submit_to_ctx_558() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_wait_559() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_279"); } void handleEZTRACE_starpu_starpu_task_wait_560() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_wait_for_all_561() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_280"); } void handleEZTRACE_starpu_starpu_task_wait_for_all_562() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_wait_for_all_in_ctx_563() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_281"); } void handleEZTRACE_starpu_starpu_task_wait_for_all_in_ctx_564() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_wait_for_no_ready_565() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_282"); } void handleEZTRACE_starpu_starpu_task_wait_for_no_ready_566() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_nready_567() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_283"); } void handleEZTRACE_starpu_starpu_task_nready_568() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_nsubmitted_569() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_284"); } void handleEZTRACE_starpu_starpu_task_nsubmitted_570() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_dup_581() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_290"); } void handleEZTRACE_starpu_starpu_task_dup_582() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_bundle_create_587() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_293"); } void handleEZTRACE_starpu_starpu_task_bundle_create_588() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_bundle_insert_589() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_294"); } void handleEZTRACE_starpu_starpu_task_bundle_insert_590() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_bundle_remove_591() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_295"); } void handleEZTRACE_starpu_starpu_task_bundle_remove_592() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_task_bundle_close_593() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_296"); } void handleEZTRACE_starpu_starpu_task_bundle_close_594() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_create_sync_task_595() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_297"); } void handleEZTRACE_starpu_starpu_create_sync_task_596() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_execute_on_each_worker_691() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_345"); } void handleEZTRACE_starpu_starpu_execute_on_each_worker_692() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_execute_on_each_worker_ex_693() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_346"); } void handleEZTRACE_starpu_starpu_execute_on_each_worker_ex_694() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_execute_on_specific_workers_695() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_347"); } void handleEZTRACE_starpu_starpu_execute_on_specific_workers_696() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } void handleEZTRACE_starpu_starpu_data_cpy_697() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState (CURRENT, "ST_Thread", thread_id, "starpu_STATE_348"); } void handleEZTRACE_starpu_starpu_data_cpy_698() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState (CURRENT, "ST_Thread", thread_id); } eztrace-1.1-2/src/modules/starpu/eztrace_convert_starpu.h000066400000000000000000000002661265506773700237160ustar00rootroot00000000000000/* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include "eztrace_convert.h" static int recording_stats = 0; eztrace-1.1-2/src/modules/starpu/starpu.c000066400000000000000000001277561265506773700204520ustar00rootroot00000000000000/* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include "eztrace.h" #include "eztrace_sampling.h" #include "starpu_ev_codes.h" #include "starpu.h" #ifdef USE_MPI #include "starpu_mpi.h" #endif #include "starpu_opencl.h" // Internals void (*lib_starpu_driver_start_job) (void *args, void *j, void *codelet_start, int rank, int profiling); void (*lib_starpu_driver_end_job) (void * args, void *j, void *perf_arch, void *codelet_end, int rank, int profiling); // API void (*libstarpu_cublas_init) (); void (*libstarpu_cublas_shutdown) (); int (*libstarpu_init) (struct starpu_conf* conf); void (*libstarpu_pause) (); void (*libstarpu_resume) (); void (*libstarpu_shutdown) (); void (*libstarpu_data_unregister) (starpu_data_handle_t handle); void (*libstarpu_data_unregister_no_coherency) (starpu_data_handle_t handle); void (*libstarpu_data_unregister_submit) (starpu_data_handle_t handle); void (*libstarpu_data_invalidate) (starpu_data_handle_t handle); void (*libstarpu_data_invalidate_submit) (starpu_data_handle_t handle); int (*libstarpu_data_acquire) (starpu_data_handle_t handle, enum starpu_data_access_mode mode); int (*libstarpu_data_acquire_on_node) (starpu_data_handle_t handle, int node, enum starpu_data_access_mode mode); int (*libstarpu_data_acquire_cb) (starpu_data_handle_t handle, enum starpu_data_access_mode mode, void (* callback), void *arg); int (*libstarpu_data_acquire_on_node_cb) (starpu_data_handle_t handle, int node, enum starpu_data_access_mode mode, void (* callback), void *arg); void (*libstarpu_data_release) (starpu_data_handle_t handle); void (*libstarpu_data_release_on_node) (starpu_data_handle_t handle, int node); int (*libstarpu_data_request_allocation) (starpu_data_handle_t handle, unsigned node); uintptr_t (*libstarpu_malloc_on_node) (unsigned dst_node, size_t size); void (*libstarpu_free_on_node) (unsigned dst_node, uintptr_t addr, size_t size); #ifdef USE_MPI int (*libstarpu_mpi_isend) (starpu_data_handle_t data_handle, starpu_mpi_req* req, int dest, int mpi_tag, MPI_Comm comm); int (*libstarpu_mpi_irecv) (starpu_data_handle_t data_handle, starpu_mpi_req* req, int source, int mpi_tag, MPI_Comm comm); int (*libstarpu_mpi_send) (starpu_data_handle_t data_handle, int dest, int mpi_tag, MPI_Comm comm); int (*libstarpu_mpi_recv) (starpu_data_handle_t data_handle, int source, int mpi_tag, MPI_Comm comm, MPI_Status* status); int (*libstarpu_mpi_isend_detached) (starpu_data_handle_t data_handle, int dest, int mpi_tag, MPI_Comm comm, void (* callback)(void *arg), void *arg); int (*libstarpu_mpi_irecv_detached) (starpu_data_handle_t data_handle, int source, int mpi_tag, MPI_Comm comm, void (* callback)(void *arg), void *arg); int (*libstarpu_mpi_wait) (starpu_mpi_req* req, MPI_Status* status); int (*libstarpu_mpi_test) (starpu_mpi_req* req, int* flag, MPI_Status* status); int (*libstarpu_mpi_barrier) (MPI_Comm comm); int (*libstarpu_mpi_init) (int* argc, char*** argv, int initialize_mpi); int (*libstarpu_mpi_initialize) (); int (*libstarpu_mpi_initialize_extended) (int* rank, int* world_size); int (*libstarpu_mpi_shutdown) (); void (*libstarpu_mpi_get_data_on_node) (MPI_Comm comm, starpu_data_handle_t data_handle, int node); void (*libstarpu_mpi_get_data_on_node_detached) (MPI_Comm comm, starpu_data_handle_t data_handle, int node, void (* callback)(void *arg), void *arg); void (*libstarpu_mpi_redux_data) (MPI_Comm comm, starpu_data_handle_t data_handle); int (*libstarpu_mpi_scatter_detached) (starpu_data_handle_t* data_handles, int count, int root, MPI_Comm comm, void (* scallback)(void *arg), void *arg,void (*rcallback)(void *), void *rarg); int (*libstarpu_mpi_gather_detached) (starpu_data_handle_t* data_handles, int count, int root, MPI_Comm comm, void (* scallback)(void *arg), void *arg, void (*rcallback)(void *), void *rarg); int (*libstarpu_mpi_isend_detached_unlock_tag) (starpu_data_handle_t data_handle, int dest, int mpi_tag, MPI_Comm comm, starpu_tag_t tag); int (*libstarpu_mpi_irecv_detached_unlock_tag) (starpu_data_handle_t data_handle, int source, int mpi_tag, MPI_Comm comm, starpu_tag_t tag); int (*libstarpu_mpi_isend_array_detached_unlock_tag) (unsigned array_size, starpu_data_handle_t* data_handle, int* dest, int* mpi_tag, MPI_Comm* comm, starpu_tag_t tag); int (*libstarpu_mpi_irecv_array_detached_unlock_tag) (unsigned array_size, starpu_data_handle_t* data_handle, int* source, int* mpi_tag, MPI_Comm* comm, starpu_tag_t tag); void (*libstarpu_mpi_comm_amounts_retrieve) (size_t* comm_amounts); void (*libstarpu_mpi_cache_flush) (MPI_Comm comm, starpu_data_handle_t data_handle); void (*libstarpu_mpi_cache_flush_all_data) (MPI_Comm comm); #endif USE_MPI #ifndef HAVE_STARPU_MPI_DATA_REGISTER_COMM void (*libstarpu_mpi_data_register) (starpu_data_handle_t data_handle, int tag, int rank); #else void (*libstarpu_mpi_data_register_comm) (starpu_data_handle_t data_handle, int tag, int rank, MPI_Comm comm); #endif void (*libstarpu_sched_ctx_add_workers) (int* workerids_ctx, int nworkers_ctx, unsigned sched_ctx_id); void (*libstarpu_sched_ctx_remove_workers) (int* workerids_ctx, int nworkers_ctx, unsigned sched_ctx_id); void (*libstarpu_sched_ctx_delete) (unsigned sched_ctx_id); void (*libstarpu_sched_ctx_set_inheritor) (unsigned sched_ctx_id, unsigned inheritor); void (*libstarpu_sched_ctx_set_context) (unsigned* sched_ctx_id); unsigned (*libstarpu_sched_ctx_get_context) (); void (*libstarpu_sched_ctx_stop_task_submission) (); void (*libstarpu_sched_ctx_finished_submit) (unsigned sched_ctx_id); struct starpu_worker_collection * (*libstarpu_sched_ctx_create_worker_collection) (unsigned sched_ctx_id, enum starpu_worker_collection_type type); void (*libstarpu_sched_ctx_delete_worker_collection) (unsigned sched_ctx_id); struct starpu_worker_collection * (*libstarpu_sched_ctx_get_worker_collection) (unsigned sched_ctx_id); int (*libstarpu_prefetch_task_input_on_node) (struct starpu_task* task, unsigned node); int (*libstarpu_malloc) (void** A, size_t dim); int (*libstarpu_free) (void* A); int (*libstarpu_malloc_flags) (void** A, size_t dim, int flags); int (*libstarpu_free_flags) (void* A, size_t dim, int flags); int (*libstarpu_tag_wait) (starpu_tag_t id); int (*libstarpu_tag_wait_array) (unsigned ntags, starpu_tag_t* id); void (*libstarpu_tag_notify_from_apps) (starpu_tag_t id); void (*libstarpu_task_init) (struct starpu_task* task); void (*libstarpu_task_clean) (struct starpu_task* task); struct starpu_task * (*libstarpu_task_create) (); void (*libstarpu_task_destroy) (struct starpu_task* task); int (*libstarpu_task_submit) (struct starpu_task* task); int (*libstarpu_task_submit_to_ctx) (struct starpu_task* task, unsigned sched_ctx_id); int (*libstarpu_task_wait) (struct starpu_task* task); int (*libstarpu_task_wait_for_all) (); int (*libstarpu_task_wait_for_all_in_ctx) (unsigned sched_ctx_id); int (*libstarpu_task_wait_for_no_ready) (); int (*libstarpu_task_nready) (); int (*libstarpu_task_nsubmitted) (); struct starpu_task * (*libstarpu_task_dup) (struct starpu_task* task); void (*libstarpu_task_bundle_create) (starpu_task_bundle_t* bundle); int (*libstarpu_task_bundle_insert) (starpu_task_bundle_t bundle, struct starpu_task* task); int (*libstarpu_task_bundle_remove) (starpu_task_bundle_t bundle, struct starpu_task* task); void (*libstarpu_task_bundle_close) (starpu_task_bundle_t bundle); void (*libstarpu_create_sync_task) (starpu_tag_t sync_tag, unsigned ndeps, starpu_tag_t* deps, void (* callback)(void *), void *callback_arg); void (*libstarpu_execute_on_each_worker) (void (* func)(void *), void *arg, uint32_t where); void (*libstarpu_execute_on_each_worker_ex) (void (* func)(void *), void *arg, uint32_t where, const char * name); void (*libstarpu_execute_on_specific_workers) (void (* func)(void*), void * arg, unsigned num_workers, unsigned * workers, const char * name); int (*libstarpu_data_cpy) (starpu_data_handle_t dst_handle, starpu_data_handle_t src_handle, int asynchronous, void (* callback_func)(void*), void *callback_arg); void _starpu_driver_start_job (void *args, void *j, void *codelet_start, int rank, int profiling) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0(EZTRACE_starpu__starpu_driver_start_job); lib_starpu_driver_start_job (args, j, codelet_start, rank, profiling); } void _starpu_driver_end_job (void* args, void* j, void* perf_arch, void *codelet_end, int rank, int profiling) { FUNCTION_ENTRY; EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu__starpu_driver_end_job); lib_starpu_driver_end_job (args, j, perf_arch, codelet_end, rank, profiling); } void starpu_cublas_init () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_cublas_init_41); libstarpu_cublas_init (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_cublas_init_42); } void starpu_cublas_shutdown () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_cublas_shutdown_43); libstarpu_cublas_shutdown (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_cublas_shutdown_44); } int starpu_init (struct starpu_conf* conf) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_init_47, conf); int ret = libstarpu_init (conf); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_init_48, conf); return ret; } void starpu_pause () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_pause_49); libstarpu_pause (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_pause_50); } void starpu_resume () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_resume_51); libstarpu_resume (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_resume_52); } void starpu_shutdown () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_shutdown_53); libstarpu_shutdown (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_shutdown_54); } void starpu_data_unregister (starpu_data_handle_t handle) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_data_unregister_79, handle); libstarpu_data_unregister (handle); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_data_unregister_80, handle); } void starpu_data_unregister_no_coherency (starpu_data_handle_t handle) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_data_unregister_no_coherency_81, handle); libstarpu_data_unregister_no_coherency (handle); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_data_unregister_no_coherency_82, handle); } void starpu_data_unregister_submit (starpu_data_handle_t handle) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_data_unregister_submit_83, handle); libstarpu_data_unregister_submit (handle); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_data_unregister_submit_84, handle); } void starpu_data_invalidate (starpu_data_handle_t handle) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_data_invalidate_85, handle); libstarpu_data_invalidate (handle); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_data_invalidate_86, handle); } void starpu_data_invalidate_submit (starpu_data_handle_t handle) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_data_invalidate_submit_87, handle); libstarpu_data_invalidate_submit (handle); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_data_invalidate_submit_88, handle); } int starpu_data_acquire (starpu_data_handle_t handle, enum starpu_data_access_mode mode) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_data_acquire_91, handle, mode); int ret = libstarpu_data_acquire (handle, mode); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_data_acquire_92, handle, mode); return ret; } int starpu_data_acquire_on_node (starpu_data_handle_t handle, int node, enum starpu_data_access_mode mode) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_data_acquire_on_node_93, handle, node, mode); int ret = libstarpu_data_acquire_on_node (handle, node, mode); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_data_acquire_on_node_94, handle, node, mode); return ret; } int starpu_data_acquire_cb (starpu_data_handle_t handle, enum starpu_data_access_mode mode, void (* callback)(void *), void *arg) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_data_acquire_cb_95, handle, mode, callback, arg); int ret = libstarpu_data_acquire_cb (handle, mode, callback, arg); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_data_acquire_cb_96, handle, mode, callback, arg); return ret; } int starpu_data_acquire_on_node_cb (starpu_data_handle_t handle, int node, enum starpu_data_access_mode mode, void (* callback)(void *), void *arg) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_5(EZTRACE_starpu_starpu_data_acquire_on_node_cb_97, handle, node, mode, callback, arg); int ret = libstarpu_data_acquire_on_node_cb (handle, node, mode, callback, arg); EZTRACE_EVENT_PACKED_5(EZTRACE_starpu_starpu_data_acquire_on_node_cb_98, handle, node, mode, callback, arg); return ret; } void starpu_data_release (starpu_data_handle_t handle) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_data_release_99, handle); libstarpu_data_release (handle); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_data_release_100, handle); } void starpu_data_release_on_node (starpu_data_handle_t handle, int node) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_data_release_on_node_101, handle, node); libstarpu_data_release_on_node (handle, node); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_data_release_on_node_102, handle, node); } int starpu_data_request_allocation (starpu_data_handle_t handle, unsigned node) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_data_request_allocation_105, handle, node); int ret = libstarpu_data_request_allocation (handle, node); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_data_request_allocation_106, handle, node); return ret; } uintptr_t starpu_malloc_on_node (unsigned dst_node, size_t size) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_malloc_on_node_183, dst_node, size); uintptr_t ret = libstarpu_malloc_on_node (dst_node, size); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_malloc_on_node_184, dst_node, size); return ret; } void starpu_free_on_node (unsigned dst_node, uintptr_t addr, size_t size) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_free_on_node_185, dst_node, addr, size); libstarpu_free_on_node (dst_node, addr, size); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_free_on_node_186, dst_node, addr, size); } #ifdef USE_MPI int starpu_mpi_isend (starpu_data_handle_t data_handle, starpu_mpi_req* req, int dest, int mpi_tag, MPI_Comm comm) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_isend_311, data_handle, req, dest, mpi_tag); int ret = libstarpu_mpi_isend (data_handle, req, dest, mpi_tag, comm); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_isend_312, data_handle, req, dest, mpi_tag); return ret; } int starpu_mpi_irecv (starpu_data_handle_t data_handle, starpu_mpi_req* req, int source, int mpi_tag, MPI_Comm comm) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_irecv_313, data_handle, req, source, mpi_tag); int ret = libstarpu_mpi_irecv (data_handle, req, source, mpi_tag, comm); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_irecv_314, data_handle, req, source, mpi_tag); return ret; } int starpu_mpi_send (starpu_data_handle_t data_handle, int dest, int mpi_tag, MPI_Comm comm) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_send_315, data_handle, dest, mpi_tag, comm); int ret = libstarpu_mpi_send (data_handle, dest, mpi_tag, comm); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_send_316, data_handle, dest, mpi_tag, comm); return ret; } int starpu_mpi_recv (starpu_data_handle_t data_handle, int source, int mpi_tag, MPI_Comm comm, MPI_Status* status) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_recv_317, data_handle, source, mpi_tag, comm); int ret = libstarpu_mpi_recv (data_handle, source, mpi_tag, comm, status); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_recv_318, data_handle, source, mpi_tag, comm); return ret; } int starpu_mpi_isend_detached (starpu_data_handle_t data_handle, int dest, int mpi_tag, MPI_Comm comm, void (* callback)(void *arg), void *arg) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_isend_detached_319, data_handle, dest, mpi_tag, comm); int ret = libstarpu_mpi_isend_detached (data_handle, dest, mpi_tag, comm, callback, arg); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_isend_detached_320, data_handle, dest, mpi_tag, comm); return ret; } int starpu_mpi_irecv_detached (starpu_data_handle_t data_handle, int source, int mpi_tag, MPI_Comm comm, void (* callback)(void *arg), void *arg) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_irecv_detached_321, data_handle, source, mpi_tag, comm); int ret = libstarpu_mpi_irecv_detached (data_handle, source, mpi_tag, comm, callback, arg); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_irecv_detached_322, data_handle, source, mpi_tag, comm); return ret; } int starpu_mpi_wait (starpu_mpi_req* req, MPI_Status* status) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_mpi_wait_323, req, status); int ret = libstarpu_mpi_wait (req, status); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_mpi_wait_324, req, status); return ret; } int starpu_mpi_test (starpu_mpi_req* req, int* flag, MPI_Status* status) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_mpi_test_325, req, flag, status); int ret = libstarpu_mpi_test (req, flag, status); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_mpi_test_326, req, flag, status); return ret; } int starpu_mpi_barrier (MPI_Comm comm) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_mpi_barrier_327, comm); int ret = libstarpu_mpi_barrier (comm); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_mpi_barrier_328, comm); return ret; } int starpu_mpi_init (int* argc, char*** argv, int initialize_mpi) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_mpi_init_329, argc, argv, initialize_mpi); int ret = libstarpu_mpi_init (argc, argv, initialize_mpi); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_mpi_init_330, argc, argv, initialize_mpi); return ret; } int starpu_mpi_initialize () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_mpi_initialize_331); int ret = libstarpu_mpi_initialize (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_mpi_initialize_332); return ret; } int starpu_mpi_initialize_extended (int* rank, int* world_size) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_mpi_initialize_extended_333, rank, world_size); int ret = libstarpu_mpi_initialize_extended (rank, world_size); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_mpi_initialize_extended_334, rank, world_size); return ret; } int starpu_mpi_shutdown () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_mpi_shutdown_335); int ret = libstarpu_mpi_shutdown (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_mpi_shutdown_336); return ret; } void starpu_mpi_get_data_on_node (MPI_Comm comm, starpu_data_handle_t data_handle, int node) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_mpi_get_data_on_node_337, comm, data_handle, node); libstarpu_mpi_get_data_on_node (comm, data_handle, node); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_mpi_get_data_on_node_338, comm, data_handle, node); } void starpu_mpi_get_data_on_node_detached (MPI_Comm comm, starpu_data_handle_t data_handle, int node, void (* callback)(void *arg), void *arg) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_mpi_get_data_on_node_detached_339, comm, data_handle, node); libstarpu_mpi_get_data_on_node_detached (comm, data_handle, node, callback, arg); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_mpi_get_data_on_node_detached_340, comm, data_handle, node); } void starpu_mpi_redux_data (MPI_Comm comm, starpu_data_handle_t data_handle) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_mpi_redux_data_341, comm, data_handle); libstarpu_mpi_redux_data (comm, data_handle); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_mpi_redux_data_342, comm, data_handle); } int starpu_mpi_scatter_detached (starpu_data_handle_t* data_handles, int count, int root, MPI_Comm comm, void (* scallback)(void *arg), void *arg, void (*rcallback)(void *), void *rarg) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_scatter_detached_343, data_handles, count, root, comm); int ret = libstarpu_mpi_scatter_detached (data_handles, count, root, comm, scallback, arg, rcallback, rarg); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_scatter_detached_344, data_handles, count, root, comm); return ret; } int starpu_mpi_gather_detached (starpu_data_handle_t* data_handles, int count, int root, MPI_Comm comm, void (* scallback)(void *arg), void *arg, void (*rcallback)(void *), void *rarg) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_gather_detached_345, data_handles, count, root, comm); int ret = libstarpu_mpi_gather_detached (data_handles, count, root, comm, scallback, arg, rcallback, rarg); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_gather_detached_346, data_handles, count, root, comm); return ret; } int starpu_mpi_isend_detached_unlock_tag (starpu_data_handle_t data_handle, int dest, int mpi_tag, MPI_Comm comm, starpu_tag_t tag) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_isend_detached_unlock_tag_347, data_handle, dest, mpi_tag, comm); int ret = libstarpu_mpi_isend_detached_unlock_tag (data_handle, dest, mpi_tag, comm, tag); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_isend_detached_unlock_tag_348, data_handle, dest, mpi_tag, comm); return ret; } int starpu_mpi_irecv_detached_unlock_tag (starpu_data_handle_t data_handle, int source, int mpi_tag, MPI_Comm comm, starpu_tag_t tag) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_irecv_detached_unlock_tag_349, data_handle, source, mpi_tag, comm); int ret = libstarpu_mpi_irecv_detached_unlock_tag (data_handle, source, mpi_tag, comm, tag); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_irecv_detached_unlock_tag_350, data_handle, source, mpi_tag, comm); return ret; } int starpu_mpi_isend_array_detached_unlock_tag (unsigned array_size, starpu_data_handle_t* data_handle, int* dest, int* mpi_tag, MPI_Comm* comm, starpu_tag_t tag) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_isend_array_detached_unlock_tag_351, array_size, data_handle, dest, mpi_tag); int ret = libstarpu_mpi_isend_array_detached_unlock_tag (array_size, data_handle, dest, mpi_tag, comm, tag); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_isend_array_detached_unlock_tag_352, array_size, data_handle, dest, mpi_tag); return ret; } int starpu_mpi_irecv_array_detached_unlock_tag (unsigned array_size, starpu_data_handle_t* data_handle, int* source, int* mpi_tag, MPI_Comm* comm, starpu_tag_t tag) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_irecv_array_detached_unlock_tag_353, array_size, data_handle, source, mpi_tag); int ret = libstarpu_mpi_irecv_array_detached_unlock_tag (array_size, data_handle, source, mpi_tag, comm, tag); EZTRACE_EVENT_PACKED_4 (EZTRACE_starpu_starpu_mpi_irecv_array_detached_unlock_tag_354, array_size, data_handle, source, mpi_tag); return ret; } void starpu_mpi_comm_amounts_retrieve (size_t* comm_amounts) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_mpi_comm_amounts_retrieve_355, comm_amounts); libstarpu_mpi_comm_amounts_retrieve (comm_amounts); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_mpi_comm_amounts_retrieve_356, comm_amounts); } void starpu_mpi_cache_flush (MPI_Comm comm, starpu_data_handle_t data_handle) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_mpi_cache_flush_357, comm, data_handle); libstarpu_mpi_cache_flush (comm, data_handle); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_mpi_cache_flush_358, comm, data_handle); } void starpu_mpi_cache_flush_all_data (MPI_Comm comm) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_mpi_cache_flush_all_data_359, comm); libstarpu_mpi_cache_flush_all_data (comm); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_mpi_cache_flush_all_data_360, comm); } #endif #ifndef HAVE_STARPU_MPI_DATA_REGISTER_COMM void starpu_mpi_data_register (starpu_data_handle_t data_handle, int tag, int rank) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_mpi_data_register_361); libstarpu_mpi_data_register (data_handle, tag, rank); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_mpi_data_register_362); } #else void starpu_mpi_data_register_comm(starpu_data_handle_t data_handle, int tag, int rank, MPI_Comm comm) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_mpi_data_register_361); libstarpu_mpi_data_register_comm (data_handle, tag, rank, comm); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_mpi_data_register_362); } #endif void starpu_sched_ctx_add_workers (int* workerids_ctx, int nworkers_ctx, unsigned sched_ctx_id) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_sched_ctx_add_workers_411, workerids_ctx, nworkers_ctx, sched_ctx_id); libstarpu_sched_ctx_add_workers (workerids_ctx, nworkers_ctx, sched_ctx_id); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_sched_ctx_add_workers_412, workerids_ctx, nworkers_ctx, sched_ctx_id); } void starpu_sched_ctx_remove_workers (int* workerids_ctx, int nworkers_ctx, unsigned sched_ctx_id) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_sched_ctx_remove_workers_413, workerids_ctx, nworkers_ctx, sched_ctx_id); libstarpu_sched_ctx_remove_workers (workerids_ctx, nworkers_ctx, sched_ctx_id); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_sched_ctx_remove_workers_414, workerids_ctx, nworkers_ctx, sched_ctx_id); } void starpu_sched_ctx_delete (unsigned sched_ctx_id) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_sched_ctx_delete_415, sched_ctx_id); libstarpu_sched_ctx_delete (sched_ctx_id); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_sched_ctx_delete_416, sched_ctx_id); } void starpu_sched_ctx_set_inheritor (unsigned sched_ctx_id, unsigned inheritor) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_sched_ctx_set_inheritor_417, sched_ctx_id, inheritor); libstarpu_sched_ctx_set_inheritor (sched_ctx_id, inheritor); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_sched_ctx_set_inheritor_418, sched_ctx_id, inheritor); } void starpu_sched_ctx_set_context (unsigned* sched_ctx_id) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_sched_ctx_set_context_419, sched_ctx_id); libstarpu_sched_ctx_set_context (sched_ctx_id); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_sched_ctx_set_context_420, sched_ctx_id); } unsigned starpu_sched_ctx_get_context () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_sched_ctx_get_context_421); unsigned ret = libstarpu_sched_ctx_get_context (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_sched_ctx_get_context_422); return ret; } void starpu_sched_ctx_stop_task_submission () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_sched_ctx_stop_task_submission_423); libstarpu_sched_ctx_stop_task_submission (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_sched_ctx_stop_task_submission_424); } void starpu_sched_ctx_finished_submit (unsigned sched_ctx_id) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_sched_ctx_finished_submit_425, sched_ctx_id); libstarpu_sched_ctx_finished_submit (sched_ctx_id); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_sched_ctx_finished_submit_426, sched_ctx_id); } struct starpu_worker_collection * starpu_sched_ctx_create_worker_collection (unsigned sched_ctx_id, enum starpu_worker_collection_type type) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_sched_ctx_create_worker_collection_461, sched_ctx_id, type); struct starpu_worker_collection * ret = libstarpu_sched_ctx_create_worker_collection (sched_ctx_id, type); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_sched_ctx_create_worker_collection_462, sched_ctx_id, type); return ret; } void starpu_sched_ctx_delete_worker_collection (unsigned sched_ctx_id) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_sched_ctx_delete_worker_collection_463, sched_ctx_id); libstarpu_sched_ctx_delete_worker_collection (sched_ctx_id); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_sched_ctx_delete_worker_collection_464, sched_ctx_id); } struct starpu_worker_collection * starpu_sched_ctx_get_worker_collection (unsigned sched_ctx_id) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_sched_ctx_get_worker_collection_465, sched_ctx_id); struct starpu_worker_collection * ret = libstarpu_sched_ctx_get_worker_collection (sched_ctx_id); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_sched_ctx_get_worker_collection_466, sched_ctx_id); return ret; } int starpu_prefetch_task_input_on_node (struct starpu_task* task, unsigned node) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_prefetch_task_input_on_node_495, task, node); int ret = libstarpu_prefetch_task_input_on_node (task, node); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_prefetch_task_input_on_node_496, task, node); return ret; } int starpu_malloc (void** A, size_t dim) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_malloc_521, A, dim); int ret = libstarpu_malloc (A, dim); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_malloc_522, A, dim); return ret; } int starpu_free (void* A) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_free_523, A); int ret = libstarpu_free (A); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_free_524, A); return ret; } int starpu_malloc_flags (void** A, size_t dim, int flags) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_malloc_flags_525, A, dim, flags); int ret = libstarpu_malloc_flags (A, dim, flags); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_malloc_flags_526, A, dim, flags); return ret; } int starpu_free_flags (void* A, size_t dim, int flags) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_free_flags_527, A, dim, flags); int ret = libstarpu_free_flags (A, dim, flags); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_free_flags_528, A, dim, flags); return ret; } int starpu_tag_wait (starpu_tag_t id) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_tag_wait_537, id); int ret = libstarpu_tag_wait (id); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_tag_wait_538, id); return ret; } int starpu_tag_wait_array (unsigned ntags, starpu_tag_t* id) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_tag_wait_array_539, ntags, id); int ret = libstarpu_tag_wait_array (ntags, id); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_tag_wait_array_540, ntags, id); return ret; } void starpu_tag_notify_from_apps (starpu_tag_t id) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_tag_notify_from_apps_541, id); libstarpu_tag_notify_from_apps (id); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_tag_notify_from_apps_542, id); } void starpu_task_init (struct starpu_task* task) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_init_547, task); libstarpu_task_init (task); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_init_548, task); } void starpu_task_clean (struct starpu_task* task) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_clean_549, task); libstarpu_task_clean (task); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_clean_550, task); } struct starpu_task * starpu_task_create () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_task_create_551); struct starpu_task * ret = libstarpu_task_create (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_task_create_552); return ret; } void starpu_task_destroy (struct starpu_task* task) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_destroy_553, task); libstarpu_task_destroy (task); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_destroy_554, task); } int starpu_task_submit (struct starpu_task* task) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_submit_555, task); int ret = libstarpu_task_submit (task); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_submit_556, task); return ret; } int starpu_task_submit_to_ctx (struct starpu_task* task, unsigned sched_ctx_id) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_task_submit_to_ctx_557, task, sched_ctx_id); int ret = libstarpu_task_submit_to_ctx (task, sched_ctx_id); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_task_submit_to_ctx_558, task, sched_ctx_id); return ret; } int starpu_task_wait (struct starpu_task* task) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_wait_559, task); int ret = libstarpu_task_wait (task); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_wait_560, task); return ret; } int starpu_task_wait_for_all () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_task_wait_for_all_561); int ret = libstarpu_task_wait_for_all (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_task_wait_for_all_562); return ret; } int starpu_task_wait_for_all_in_ctx (unsigned sched_ctx_id) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_wait_for_all_in_ctx_563, sched_ctx_id); int ret = libstarpu_task_wait_for_all_in_ctx (sched_ctx_id); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_wait_for_all_in_ctx_564, sched_ctx_id); return ret; } int starpu_task_wait_for_no_ready () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_task_wait_for_no_ready_565); int ret = libstarpu_task_wait_for_no_ready (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_task_wait_for_no_ready_566); return ret; } int starpu_task_nready () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_task_nready_567); int ret = libstarpu_task_nready (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_task_nready_568); return ret; } int starpu_task_nsubmitted () { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_task_nsubmitted_569); int ret = libstarpu_task_nsubmitted (); EZTRACE_EVENT_PACKED_0 (EZTRACE_starpu_starpu_task_nsubmitted_570); return ret; } struct starpu_task * starpu_task_dup (struct starpu_task* task) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_dup_581, task); struct starpu_task * ret = libstarpu_task_dup (task); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_dup_582, task); return ret; } void starpu_task_bundle_create (starpu_task_bundle_t* bundle) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_bundle_create_587, bundle); libstarpu_task_bundle_create (bundle); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_bundle_create_588, bundle); } int starpu_task_bundle_insert (starpu_task_bundle_t bundle, struct starpu_task* task) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_task_bundle_insert_589, bundle, task); int ret = libstarpu_task_bundle_insert (bundle, task); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_task_bundle_insert_590, bundle, task); return ret; } int starpu_task_bundle_remove (starpu_task_bundle_t bundle, struct starpu_task* task) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_task_bundle_remove_591, bundle, task); int ret = libstarpu_task_bundle_remove (bundle, task); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_task_bundle_remove_592, bundle, task); return ret; } void starpu_task_bundle_close (starpu_task_bundle_t bundle) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_bundle_close_593, bundle); libstarpu_task_bundle_close (bundle); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_task_bundle_close_594, bundle); } void starpu_create_sync_task (starpu_tag_t sync_tag, unsigned ndeps, starpu_tag_t* deps, void (* callback)(void *), void *callback_arg) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_create_sync_task_595, sync_tag, ndeps, deps); libstarpu_create_sync_task (sync_tag, ndeps, deps, callback, callback_arg); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_create_sync_task_596, sync_tag, ndeps, deps); } void starpu_execute_on_each_worker (void (* func)(void *), void *arg, uint32_t where) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_execute_on_each_worker_691, where); libstarpu_execute_on_each_worker (func, arg, where); EZTRACE_EVENT_PACKED_1 (EZTRACE_starpu_starpu_execute_on_each_worker_692, where); } void starpu_execute_on_each_worker_ex (void (* func)(void *), void *arg, uint32_t where, const char * name) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_execute_on_each_worker_ex_693, where, name); libstarpu_execute_on_each_worker_ex (func, arg, where, name); EZTRACE_EVENT_PACKED_2 (EZTRACE_starpu_starpu_execute_on_each_worker_ex_694, where, name); } void starpu_execute_on_specific_workers (void (* func)(void*), void * arg, unsigned num_workers, unsigned * workers, const char * name) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_execute_on_specific_workers_695, num_workers, workers, name); libstarpu_execute_on_specific_workers (func, arg, num_workers, workers, name); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_execute_on_specific_workers_696, num_workers, workers, name); } int starpu_data_cpy (starpu_data_handle_t dst_handle, starpu_data_handle_t src_handle, int asynchronous, void (* callback_func)(void*), void *callback_arg) { FUNCTION_ENTRY EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_data_cpy_697, dst_handle, src_handle, asynchronous); int ret = libstarpu_data_cpy (dst_handle, src_handle, asynchronous, callback_func, callback_arg); EZTRACE_EVENT_PACKED_3 (EZTRACE_starpu_starpu_data_cpy_698, dst_handle, src_handle, asynchronous); return ret; } START_INTERCEPT_MODULE(starpu) INTERCEPT2("_starpu_driver_start_job", lib_starpu_driver_start_job) INTERCEPT2("_starpu_driver_end_job", lib_starpu_driver_end_job) INTERCEPT2("starpu_cublas_init", libstarpu_cublas_init) INTERCEPT2("starpu_cublas_shutdown", libstarpu_cublas_shutdown) INTERCEPT2("starpu_init", libstarpu_init) INTERCEPT2("starpu_pause", libstarpu_pause) INTERCEPT2("starpu_resume", libstarpu_resume) INTERCEPT2("starpu_shutdown", libstarpu_shutdown) INTERCEPT2("starpu_data_unregister", libstarpu_data_unregister) INTERCEPT2("starpu_data_unregister_no_coherency", libstarpu_data_unregister_no_coherency) INTERCEPT2("starpu_data_unregister_submit", libstarpu_data_unregister_submit) INTERCEPT2("starpu_data_invalidate", libstarpu_data_invalidate) INTERCEPT2("starpu_data_invalidate_submit", libstarpu_data_invalidate_submit) INTERCEPT2("starpu_data_acquire", libstarpu_data_acquire) INTERCEPT2("starpu_data_acquire_on_node", libstarpu_data_acquire_on_node) INTERCEPT2("starpu_data_acquire_cb", libstarpu_data_acquire_cb) INTERCEPT2("starpu_data_acquire_on_node_cb", libstarpu_data_acquire_on_node_cb) INTERCEPT2("starpu_data_release", libstarpu_data_release) INTERCEPT2("starpu_data_release_on_node", libstarpu_data_release_on_node) INTERCEPT2("starpu_data_request_allocation", libstarpu_data_request_allocation) INTERCEPT2("starpu_malloc_on_node", libstarpu_malloc_on_node) INTERCEPT2("starpu_free_on_node", libstarpu_free_on_node) INTERCEPT2("starpu_mpi_isend", libstarpu_mpi_isend) INTERCEPT2("starpu_mpi_irecv", libstarpu_mpi_irecv) INTERCEPT2("starpu_mpi_send", libstarpu_mpi_send) INTERCEPT2("starpu_mpi_recv", libstarpu_mpi_recv) INTERCEPT2("starpu_mpi_isend_detached", libstarpu_mpi_isend_detached) INTERCEPT2("starpu_mpi_irecv_detached", libstarpu_mpi_irecv_detached) INTERCEPT2("starpu_mpi_wait", libstarpu_mpi_wait) INTERCEPT2("starpu_mpi_test", libstarpu_mpi_test) INTERCEPT2("starpu_mpi_barrier", libstarpu_mpi_barrier) INTERCEPT2("starpu_mpi_init", libstarpu_mpi_init) INTERCEPT2("starpu_mpi_initialize", libstarpu_mpi_initialize) INTERCEPT2("starpu_mpi_initialize_extended", libstarpu_mpi_initialize_extended) INTERCEPT2("starpu_mpi_shutdown", libstarpu_mpi_shutdown) INTERCEPT2("starpu_mpi_get_data_on_node", libstarpu_mpi_get_data_on_node) INTERCEPT2("starpu_mpi_get_data_on_node_detached", libstarpu_mpi_get_data_on_node_detached) INTERCEPT2("starpu_mpi_redux_data", libstarpu_mpi_redux_data) INTERCEPT2("starpu_mpi_scatter_detached", libstarpu_mpi_scatter_detached) INTERCEPT2("starpu_mpi_gather_detached", libstarpu_mpi_gather_detached) INTERCEPT2("starpu_mpi_isend_detached_unlock_tag", libstarpu_mpi_isend_detached_unlock_tag) INTERCEPT2("starpu_mpi_irecv_detached_unlock_tag", libstarpu_mpi_irecv_detached_unlock_tag) INTERCEPT2("starpu_mpi_isend_array_detached_unlock_tag", libstarpu_mpi_isend_array_detached_unlock_tag) INTERCEPT2("starpu_mpi_irecv_array_detached_unlock_tag", libstarpu_mpi_irecv_array_detached_unlock_tag) INTERCEPT2("starpu_mpi_comm_amounts_retrieve", libstarpu_mpi_comm_amounts_retrieve) INTERCEPT2("starpu_mpi_cache_flush", libstarpu_mpi_cache_flush) INTERCEPT2("starpu_mpi_cache_flush_all_data", libstarpu_mpi_cache_flush_all_data) #ifndef HAVE_STARPU_MPI_DATA_REGISTER_COMM INTERCEPT2("starpu_mpi_data_register", libstarpu_mpi_data_register) #else INTERCEPT2("starpu_mpi_data_register_comm", libstarpu_mpi_data_register_comm) #endif INTERCEPT2("starpu_sched_ctx_add_workers", libstarpu_sched_ctx_add_workers) INTERCEPT2("starpu_sched_ctx_remove_workers", libstarpu_sched_ctx_remove_workers) INTERCEPT2("starpu_sched_ctx_delete", libstarpu_sched_ctx_delete) INTERCEPT2("starpu_sched_ctx_set_inheritor", libstarpu_sched_ctx_set_inheritor) INTERCEPT2("starpu_sched_ctx_set_context", libstarpu_sched_ctx_set_context) INTERCEPT2("starpu_sched_ctx_get_context", libstarpu_sched_ctx_get_context) INTERCEPT2("starpu_sched_ctx_stop_task_submission", libstarpu_sched_ctx_stop_task_submission) INTERCEPT2("starpu_sched_ctx_finished_submit", libstarpu_sched_ctx_finished_submit) INTERCEPT2("starpu_sched_ctx_create_worker_collection", libstarpu_sched_ctx_create_worker_collection) INTERCEPT2("starpu_sched_ctx_delete_worker_collection", libstarpu_sched_ctx_delete_worker_collection) INTERCEPT2("starpu_sched_ctx_get_worker_collection", libstarpu_sched_ctx_get_worker_collection) INTERCEPT2("starpu_prefetch_task_input_on_node", libstarpu_prefetch_task_input_on_node) INTERCEPT2("starpu_malloc", libstarpu_malloc) INTERCEPT2("starpu_free", libstarpu_free) INTERCEPT2("starpu_malloc_flags", libstarpu_malloc_flags) INTERCEPT2("starpu_free_flags", libstarpu_free_flags) INTERCEPT2("starpu_tag_wait", libstarpu_tag_wait) INTERCEPT2("starpu_tag_wait_array", libstarpu_tag_wait_array) INTERCEPT2("starpu_task_init", libstarpu_task_init) INTERCEPT2("starpu_task_clean", libstarpu_task_clean) INTERCEPT2("starpu_task_create", libstarpu_task_create) INTERCEPT2("starpu_task_destroy", libstarpu_task_destroy) INTERCEPT2("starpu_task_submit", libstarpu_task_submit) INTERCEPT2("starpu_task_submit_to_ctx", libstarpu_task_submit_to_ctx) INTERCEPT2("starpu_task_wait", libstarpu_task_wait) INTERCEPT2("starpu_task_wait_for_all", libstarpu_task_wait_for_all) INTERCEPT2("starpu_task_wait_for_all_in_ctx", libstarpu_task_wait_for_all_in_ctx) INTERCEPT2("starpu_task_wait_for_no_ready", libstarpu_task_wait_for_no_ready) INTERCEPT2("starpu_task_nready", libstarpu_task_nready) INTERCEPT2("starpu_task_nsubmitted", libstarpu_task_nsubmitted) INTERCEPT2("starpu_task_dup", libstarpu_task_dup) INTERCEPT2("starpu_task_bundle_create", libstarpu_task_bundle_create) INTERCEPT2("starpu_task_bundle_insert", libstarpu_task_bundle_insert) INTERCEPT2("starpu_task_bundle_remove", libstarpu_task_bundle_remove) INTERCEPT2("starpu_task_bundle_close", libstarpu_task_bundle_close) INTERCEPT2("starpu_create_sync_task", libstarpu_create_sync_task) INTERCEPT2("starpu_execute_on_each_worker", libstarpu_execute_on_each_worker) INTERCEPT2("starpu_execute_on_each_worker_ex", libstarpu_execute_on_each_worker_ex) INTERCEPT2("starpu_execute_on_specific_workers", libstarpu_execute_on_specific_workers) INTERCEPT2("starpu_data_cpy", libstarpu_data_cpy) INTERCEPT2("starpu_tag_notify_from_apps", libstarpu_tag_notify_from_apps) END_INTERCEPT_MODULE(starpu) static void __starpu_init (void) __attribute__ ((constructor)); /* Initialize the current library */ static void __starpu_init (void) { DYNAMIC_INTERCEPT_ALL_MODULE(starpu); /* start event recording */ #ifdef EZTRACE_AUTOSTART eztrace_start (); #endif } static void __starpu_conclude (void) __attribute__ ((destructor)); static void __starpu_conclude (void) { /* stop event recording */ eztrace_stop (); } eztrace-1.1-2/src/modules/starpu/starpu_ev_codes.h000066400000000000000000000347771265506773700223260ustar00rootroot00000000000000/* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #ifndef __starpu_EV_CODES_H__ #define __starpu_EV_CODES_H__ /* This file defines the event codes that are used by the example * module. */ #include "ev_codes.h" /* 7-bits event codes prefix. This identifies the module and thus should be * unique. * The 0x0? prefix is reserved for eztrace internal use. Thus you can * use any prefix between 0x80 and 0xff. */ #define starpu_EVENTS_ID 0x10 #define EZTRACE_STARPU_EVENTS_ID SYSTEM_MODULE_ID(starpu_EVENTS_ID) #define starpu_PREFIX GENERATE_SYSTEM_MODULE_PREFIX(EZTRACE_STARPU_EVENTS_ID) /* Define various event codes used by the example module * The 2 most significant bytes should correspond to the module id, * as below: */ // Internals #define EZTRACE_starpu__starpu_driver_start_job (starpu_PREFIX | 0x0002) #define EZTRACE_starpu__starpu_driver_end_job (starpu_PREFIX | 0x0004) // API #define EZTRACE_starpu_starpu_cublas_init_41 (starpu_PREFIX | 0x29) #define EZTRACE_starpu_starpu_cublas_init_42 (starpu_PREFIX | 0x2a) #define EZTRACE_starpu_starpu_cublas_shutdown_43 (starpu_PREFIX | 0x2b) #define EZTRACE_starpu_starpu_cublas_shutdown_44 (starpu_PREFIX | 0x2c) #define EZTRACE_starpu_starpu_init_47 (starpu_PREFIX | 0x2f) #define EZTRACE_starpu_starpu_init_48 (starpu_PREFIX | 0x30) #define EZTRACE_starpu_starpu_pause_49 (starpu_PREFIX | 0x31) #define EZTRACE_starpu_starpu_pause_50 (starpu_PREFIX | 0x32) #define EZTRACE_starpu_starpu_resume_51 (starpu_PREFIX | 0x33) #define EZTRACE_starpu_starpu_resume_52 (starpu_PREFIX | 0x34) #define EZTRACE_starpu_starpu_shutdown_53 (starpu_PREFIX | 0x35) #define EZTRACE_starpu_starpu_shutdown_54 (starpu_PREFIX | 0x36) #define EZTRACE_starpu_starpu_data_unregister_79 (starpu_PREFIX | 0x4f) #define EZTRACE_starpu_starpu_data_unregister_80 (starpu_PREFIX | 0x50) #define EZTRACE_starpu_starpu_data_unregister_no_coherency_81 (starpu_PREFIX | 0x51) #define EZTRACE_starpu_starpu_data_unregister_no_coherency_82 (starpu_PREFIX | 0x52) #define EZTRACE_starpu_starpu_data_unregister_submit_83 (starpu_PREFIX | 0x53) #define EZTRACE_starpu_starpu_data_unregister_submit_84 (starpu_PREFIX | 0x54) #define EZTRACE_starpu_starpu_data_invalidate_85 (starpu_PREFIX | 0x55) #define EZTRACE_starpu_starpu_data_invalidate_86 (starpu_PREFIX | 0x56) #define EZTRACE_starpu_starpu_data_invalidate_submit_87 (starpu_PREFIX | 0x57) #define EZTRACE_starpu_starpu_data_invalidate_submit_88 (starpu_PREFIX | 0x58) #define EZTRACE_starpu_starpu_data_acquire_91 (starpu_PREFIX | 0x5b) #define EZTRACE_starpu_starpu_data_acquire_92 (starpu_PREFIX | 0x5c) #define EZTRACE_starpu_starpu_data_acquire_on_node_93 (starpu_PREFIX | 0x5d) #define EZTRACE_starpu_starpu_data_acquire_on_node_94 (starpu_PREFIX | 0x5e) #define EZTRACE_starpu_starpu_data_acquire_cb_95 (starpu_PREFIX | 0x5f) #define EZTRACE_starpu_starpu_data_acquire_cb_96 (starpu_PREFIX | 0x60) #define EZTRACE_starpu_starpu_data_acquire_on_node_cb_97 (starpu_PREFIX | 0x61) #define EZTRACE_starpu_starpu_data_acquire_on_node_cb_98 (starpu_PREFIX | 0x62) #define EZTRACE_starpu_starpu_data_release_99 (starpu_PREFIX | 0x63) #define EZTRACE_starpu_starpu_data_release_100 (starpu_PREFIX | 0x64) #define EZTRACE_starpu_starpu_data_release_on_node_101 (starpu_PREFIX | 0x65) #define EZTRACE_starpu_starpu_data_release_on_node_102 (starpu_PREFIX | 0x66) #define EZTRACE_starpu_starpu_data_request_allocation_105 (starpu_PREFIX | 0x69) #define EZTRACE_starpu_starpu_data_request_allocation_106 (starpu_PREFIX | 0x6a) #define EZTRACE_starpu_starpu_malloc_on_node_183 (starpu_PREFIX | 0xb7) #define EZTRACE_starpu_starpu_malloc_on_node_184 (starpu_PREFIX | 0xb8) #define EZTRACE_starpu_starpu_free_on_node_185 (starpu_PREFIX | 0xb9) #define EZTRACE_starpu_starpu_free_on_node_186 (starpu_PREFIX | 0xba) #define EZTRACE_starpu_starpu_mpi_isend_311 (starpu_PREFIX | 0x137) #define EZTRACE_starpu_starpu_mpi_isend_312 (starpu_PREFIX | 0x138) #define EZTRACE_starpu_starpu_mpi_irecv_313 (starpu_PREFIX | 0x139) #define EZTRACE_starpu_starpu_mpi_irecv_314 (starpu_PREFIX | 0x13a) #define EZTRACE_starpu_starpu_mpi_send_315 (starpu_PREFIX | 0x13b) #define EZTRACE_starpu_starpu_mpi_send_316 (starpu_PREFIX | 0x13c) #define EZTRACE_starpu_starpu_mpi_recv_317 (starpu_PREFIX | 0x13d) #define EZTRACE_starpu_starpu_mpi_recv_318 (starpu_PREFIX | 0x13e) #define EZTRACE_starpu_starpu_mpi_isend_detached_319 (starpu_PREFIX | 0x13f) #define EZTRACE_starpu_starpu_mpi_isend_detached_320 (starpu_PREFIX | 0x140) #define EZTRACE_starpu_starpu_mpi_irecv_detached_321 (starpu_PREFIX | 0x141) #define EZTRACE_starpu_starpu_mpi_irecv_detached_322 (starpu_PREFIX | 0x142) #define EZTRACE_starpu_starpu_mpi_wait_323 (starpu_PREFIX | 0x143) #define EZTRACE_starpu_starpu_mpi_wait_324 (starpu_PREFIX | 0x144) #define EZTRACE_starpu_starpu_mpi_test_325 (starpu_PREFIX | 0x145) #define EZTRACE_starpu_starpu_mpi_test_326 (starpu_PREFIX | 0x146) #define EZTRACE_starpu_starpu_mpi_barrier_327 (starpu_PREFIX | 0x147) #define EZTRACE_starpu_starpu_mpi_barrier_328 (starpu_PREFIX | 0x148) #define EZTRACE_starpu_starpu_mpi_init_329 (starpu_PREFIX | 0x149) #define EZTRACE_starpu_starpu_mpi_init_330 (starpu_PREFIX | 0x14a) #define EZTRACE_starpu_starpu_mpi_initialize_331 (starpu_PREFIX | 0x14b) #define EZTRACE_starpu_starpu_mpi_initialize_332 (starpu_PREFIX | 0x14c) #define EZTRACE_starpu_starpu_mpi_initialize_extended_333 (starpu_PREFIX | 0x14d) #define EZTRACE_starpu_starpu_mpi_initialize_extended_334 (starpu_PREFIX | 0x14e) #define EZTRACE_starpu_starpu_mpi_shutdown_335 (starpu_PREFIX | 0x14f) #define EZTRACE_starpu_starpu_mpi_shutdown_336 (starpu_PREFIX | 0x150) #define EZTRACE_starpu_starpu_mpi_get_data_on_node_337 (starpu_PREFIX | 0x151) #define EZTRACE_starpu_starpu_mpi_get_data_on_node_338 (starpu_PREFIX | 0x152) #define EZTRACE_starpu_starpu_mpi_get_data_on_node_detached_339 (starpu_PREFIX | 0x153) #define EZTRACE_starpu_starpu_mpi_get_data_on_node_detached_340 (starpu_PREFIX | 0x154) #define EZTRACE_starpu_starpu_mpi_redux_data_341 (starpu_PREFIX | 0x155) #define EZTRACE_starpu_starpu_mpi_redux_data_342 (starpu_PREFIX | 0x156) #define EZTRACE_starpu_starpu_mpi_scatter_detached_343 (starpu_PREFIX | 0x157) #define EZTRACE_starpu_starpu_mpi_scatter_detached_344 (starpu_PREFIX | 0x158) #define EZTRACE_starpu_starpu_mpi_gather_detached_345 (starpu_PREFIX | 0x159) #define EZTRACE_starpu_starpu_mpi_gather_detached_346 (starpu_PREFIX | 0x15a) #define EZTRACE_starpu_starpu_mpi_isend_detached_unlock_tag_347 (starpu_PREFIX | 0x15b) #define EZTRACE_starpu_starpu_mpi_isend_detached_unlock_tag_348 (starpu_PREFIX | 0x15c) #define EZTRACE_starpu_starpu_mpi_irecv_detached_unlock_tag_349 (starpu_PREFIX | 0x15d) #define EZTRACE_starpu_starpu_mpi_irecv_detached_unlock_tag_350 (starpu_PREFIX | 0x15e) #define EZTRACE_starpu_starpu_mpi_isend_array_detached_unlock_tag_351 (starpu_PREFIX | 0x15f) #define EZTRACE_starpu_starpu_mpi_isend_array_detached_unlock_tag_352 (starpu_PREFIX | 0x160) #define EZTRACE_starpu_starpu_mpi_irecv_array_detached_unlock_tag_353 (starpu_PREFIX | 0x161) #define EZTRACE_starpu_starpu_mpi_irecv_array_detached_unlock_tag_354 (starpu_PREFIX | 0x162) #define EZTRACE_starpu_starpu_mpi_comm_amounts_retrieve_355 (starpu_PREFIX | 0x163) #define EZTRACE_starpu_starpu_mpi_comm_amounts_retrieve_356 (starpu_PREFIX | 0x164) #define EZTRACE_starpu_starpu_mpi_cache_flush_357 (starpu_PREFIX | 0x165) #define EZTRACE_starpu_starpu_mpi_cache_flush_358 (starpu_PREFIX | 0x166) #define EZTRACE_starpu_starpu_mpi_cache_flush_all_data_359 (starpu_PREFIX | 0x167) #define EZTRACE_starpu_starpu_mpi_cache_flush_all_data_360 (starpu_PREFIX | 0x168) #define EZTRACE_starpu_starpu_mpi_data_register_361 (starpu_PREFIX | 0x169) #define EZTRACE_starpu_starpu_mpi_data_register_362 (starpu_PREFIX | 0x16a) #define EZTRACE_starpu_starpu_sched_ctx_add_workers_411 (starpu_PREFIX | 0x19b) #define EZTRACE_starpu_starpu_sched_ctx_add_workers_412 (starpu_PREFIX | 0x19c) #define EZTRACE_starpu_starpu_sched_ctx_remove_workers_413 (starpu_PREFIX | 0x19d) #define EZTRACE_starpu_starpu_sched_ctx_remove_workers_414 (starpu_PREFIX | 0x19e) #define EZTRACE_starpu_starpu_sched_ctx_delete_415 (starpu_PREFIX | 0x19f) #define EZTRACE_starpu_starpu_sched_ctx_delete_416 (starpu_PREFIX | 0x1a0) #define EZTRACE_starpu_starpu_sched_ctx_set_inheritor_417 (starpu_PREFIX | 0x1a1) #define EZTRACE_starpu_starpu_sched_ctx_set_inheritor_418 (starpu_PREFIX | 0x1a2) #define EZTRACE_starpu_starpu_sched_ctx_set_context_419 (starpu_PREFIX | 0x1a3) #define EZTRACE_starpu_starpu_sched_ctx_set_context_420 (starpu_PREFIX | 0x1a4) #define EZTRACE_starpu_starpu_sched_ctx_get_context_421 (starpu_PREFIX | 0x1a5) #define EZTRACE_starpu_starpu_sched_ctx_get_context_422 (starpu_PREFIX | 0x1a6) #define EZTRACE_starpu_starpu_sched_ctx_stop_task_submission_423 (starpu_PREFIX | 0x1a7) #define EZTRACE_starpu_starpu_sched_ctx_stop_task_submission_424 (starpu_PREFIX | 0x1a8) #define EZTRACE_starpu_starpu_sched_ctx_finished_submit_425 (starpu_PREFIX | 0x1a9) #define EZTRACE_starpu_starpu_sched_ctx_finished_submit_426 (starpu_PREFIX | 0x1aa) #define EZTRACE_starpu_starpu_sched_ctx_create_worker_collection_461 (starpu_PREFIX | 0x1cd) #define EZTRACE_starpu_starpu_sched_ctx_create_worker_collection_462 (starpu_PREFIX | 0x1ce) #define EZTRACE_starpu_starpu_sched_ctx_delete_worker_collection_463 (starpu_PREFIX | 0x1cf) #define EZTRACE_starpu_starpu_sched_ctx_delete_worker_collection_464 (starpu_PREFIX | 0x1d0) #define EZTRACE_starpu_starpu_sched_ctx_get_worker_collection_465 (starpu_PREFIX | 0x1d1) #define EZTRACE_starpu_starpu_sched_ctx_get_worker_collection_466 (starpu_PREFIX | 0x1d2) #define EZTRACE_starpu_starpu_prefetch_task_input_on_node_495 (starpu_PREFIX | 0x1ef) #define EZTRACE_starpu_starpu_prefetch_task_input_on_node_496 (starpu_PREFIX | 0x1f0) #define EZTRACE_starpu_starpu_malloc_521 (starpu_PREFIX | 0x209) #define EZTRACE_starpu_starpu_malloc_522 (starpu_PREFIX | 0x20a) #define EZTRACE_starpu_starpu_free_523 (starpu_PREFIX | 0x20b) #define EZTRACE_starpu_starpu_free_524 (starpu_PREFIX | 0x20c) #define EZTRACE_starpu_starpu_malloc_flags_525 (starpu_PREFIX | 0x20d) #define EZTRACE_starpu_starpu_malloc_flags_526 (starpu_PREFIX | 0x20e) #define EZTRACE_starpu_starpu_free_flags_527 (starpu_PREFIX | 0x20f) #define EZTRACE_starpu_starpu_free_flags_528 (starpu_PREFIX | 0x210) #define EZTRACE_starpu_starpu_tag_wait_537 (starpu_PREFIX | 0x219) #define EZTRACE_starpu_starpu_tag_wait_538 (starpu_PREFIX | 0x21a) #define EZTRACE_starpu_starpu_tag_wait_array_539 (starpu_PREFIX | 0x21b) #define EZTRACE_starpu_starpu_tag_wait_array_540 (starpu_PREFIX | 0x21c) #define EZTRACE_starpu_starpu_tag_notify_from_apps_541 (starpu_PREFIX | 0x21d) #define EZTRACE_starpu_starpu_tag_notify_from_apps_542 (starpu_PREFIX | 0x21e) #define EZTRACE_starpu_starpu_task_init_547 (starpu_PREFIX | 0x223) #define EZTRACE_starpu_starpu_task_init_548 (starpu_PREFIX | 0x224) #define EZTRACE_starpu_starpu_task_clean_549 (starpu_PREFIX | 0x225) #define EZTRACE_starpu_starpu_task_clean_550 (starpu_PREFIX | 0x226) #define EZTRACE_starpu_starpu_task_create_551 (starpu_PREFIX | 0x227) #define EZTRACE_starpu_starpu_task_create_552 (starpu_PREFIX | 0x228) #define EZTRACE_starpu_starpu_task_destroy_553 (starpu_PREFIX | 0x229) #define EZTRACE_starpu_starpu_task_destroy_554 (starpu_PREFIX | 0x22a) #define EZTRACE_starpu_starpu_task_submit_555 (starpu_PREFIX | 0x22b) #define EZTRACE_starpu_starpu_task_submit_556 (starpu_PREFIX | 0x22c) #define EZTRACE_starpu_starpu_task_submit_to_ctx_557 (starpu_PREFIX | 0x22d) #define EZTRACE_starpu_starpu_task_submit_to_ctx_558 (starpu_PREFIX | 0x22e) #define EZTRACE_starpu_starpu_task_wait_559 (starpu_PREFIX | 0x22f) #define EZTRACE_starpu_starpu_task_wait_560 (starpu_PREFIX | 0x230) #define EZTRACE_starpu_starpu_task_wait_for_all_561 (starpu_PREFIX | 0x231) #define EZTRACE_starpu_starpu_task_wait_for_all_562 (starpu_PREFIX | 0x232) #define EZTRACE_starpu_starpu_task_wait_for_all_in_ctx_563 (starpu_PREFIX | 0x233) #define EZTRACE_starpu_starpu_task_wait_for_all_in_ctx_564 (starpu_PREFIX | 0x234) #define EZTRACE_starpu_starpu_task_wait_for_no_ready_565 (starpu_PREFIX | 0x235) #define EZTRACE_starpu_starpu_task_wait_for_no_ready_566 (starpu_PREFIX | 0x236) #define EZTRACE_starpu_starpu_task_nready_567 (starpu_PREFIX | 0x237) #define EZTRACE_starpu_starpu_task_nready_568 (starpu_PREFIX | 0x238) #define EZTRACE_starpu_starpu_task_nsubmitted_569 (starpu_PREFIX | 0x239) #define EZTRACE_starpu_starpu_task_nsubmitted_570 (starpu_PREFIX | 0x23a) #define EZTRACE_starpu_starpu_codelet_init_571 (starpu_PREFIX | 0x23b) #define EZTRACE_starpu_starpu_codelet_init_572 (starpu_PREFIX | 0x23c) #define EZTRACE_starpu_starpu_codelet_display_stats_573 (starpu_PREFIX | 0x23d) #define EZTRACE_starpu_starpu_codelet_display_stats_574 (starpu_PREFIX | 0x23f) #define EZTRACE_starpu_starpu_parallel_task_barrier_init_577 (starpu_PREFIX | 0x241) #define EZTRACE_starpu_starpu_parallel_task_barrier_init_578 (starpu_PREFIX | 0x242) #define EZTRACE_starpu_starpu_parallel_task_barrier_init_n_579 (starpu_PREFIX | 0x243) #define EZTRACE_starpu_starpu_parallel_task_barrier_init_n_580 (starpu_PREFIX | 0x244) #define EZTRACE_starpu_starpu_task_dup_581 (starpu_PREFIX | 0x245) #define EZTRACE_starpu_starpu_task_dup_582 (starpu_PREFIX | 0x246) #define EZTRACE_starpu_starpu_task_bundle_create_587 (starpu_PREFIX | 0x24b) #define EZTRACE_starpu_starpu_task_bundle_create_588 (starpu_PREFIX | 0x24c) #define EZTRACE_starpu_starpu_task_bundle_insert_589 (starpu_PREFIX | 0x24d) #define EZTRACE_starpu_starpu_task_bundle_insert_590 (starpu_PREFIX | 0x24e) #define EZTRACE_starpu_starpu_task_bundle_remove_591 (starpu_PREFIX | 0x24f) #define EZTRACE_starpu_starpu_task_bundle_remove_592 (starpu_PREFIX | 0x250) #define EZTRACE_starpu_starpu_task_bundle_close_593 (starpu_PREFIX | 0x251) #define EZTRACE_starpu_starpu_task_bundle_close_594 (starpu_PREFIX | 0x252) #define EZTRACE_starpu_starpu_create_sync_task_595 (starpu_PREFIX | 0x253) #define EZTRACE_starpu_starpu_create_sync_task_596 (starpu_PREFIX | 0x254) #define EZTRACE_starpu_starpu_execute_on_each_worker_691 (starpu_PREFIX | 0x2b3) #define EZTRACE_starpu_starpu_execute_on_each_worker_692 (starpu_PREFIX | 0x2b4) #define EZTRACE_starpu_starpu_execute_on_each_worker_ex_693 (starpu_PREFIX | 0x2b5) #define EZTRACE_starpu_starpu_execute_on_each_worker_ex_694 (starpu_PREFIX | 0x2b6) #define EZTRACE_starpu_starpu_execute_on_specific_workers_695 (starpu_PREFIX | 0x2b7) #define EZTRACE_starpu_starpu_execute_on_specific_workers_696 (starpu_PREFIX | 0x2b8) #define EZTRACE_starpu_starpu_data_cpy_697 (starpu_PREFIX | 0x2b9) #define EZTRACE_starpu_starpu_data_cpy_698 (starpu_PREFIX | 0x2ba) #endif /* __starpu_EV_CODES_H__ */ eztrace-1.1-2/src/modules/stdio/000077500000000000000000000000001265506773700165525ustar00rootroot00000000000000eztrace-1.1-2/src/modules/stdio/Makefile.am000066400000000000000000000026001265506773700206040ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. TLCFLAGS=$(TL_CPPFLAGS) TLLDFLAGS=$(TL_LDFLAGS) TLLIBADD=$(TL_LIB) GTGCFLAGS=$(GTG_CPPFLAGS) GTGLDFLAGS=$(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD=$(GTG_LIB) lib_LTLIBRARIES = libeztrace-convert-stdio.la \ libeztrace-stdio.la \ libeztrace-autostart-stdio.la AM_CFLAGS = -W -Wall -Wextra -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ -I$(top_srcdir)/src/pptrace libeztrace_convert_stdio_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) libeztrace_convert_stdio_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) libeztrace_convert_stdio_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_stdio_la_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace_convert_stdio_la_SOURCES = eztrace_convert_stdio.c libeztrace_stdio_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_stdio_la_LIBADD = $(TLLIBADD) libeztrace_stdio_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_stdio_la_SOURCES = stdio.c libeztrace_autostart_stdio_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_autostart_stdio_la_LIBADD = $(TLLIBADD) libeztrace_autostart_stdio_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_autostart_stdio_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra -DEZTRACE_AUTOSTART libeztrace_autostart_stdio_la_SOURCES = stdio.c noinst_HEADERS = stdio_ev_codes.h eztrace-1.1-2/src/modules/stdio/Makefile.in000066400000000000000000000712711265506773700206270ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright (C) CNRS, INRIA, Universite Bordeaux 1, Telecom SudParis # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = src/modules/stdio ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(noinst_HEADERS) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(libdir)" LTLIBRARIES = $(lib_LTLIBRARIES) am__DEPENDENCIES_1 = am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) libeztrace_autostart_stdio_la_DEPENDENCIES = $(am__DEPENDENCIES_2) am_libeztrace_autostart_stdio_la_OBJECTS = \ libeztrace_autostart_stdio_la-stdio.lo libeztrace_autostart_stdio_la_OBJECTS = \ $(am_libeztrace_autostart_stdio_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libeztrace_autostart_stdio_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(libeztrace_autostart_stdio_la_CFLAGS) $(CFLAGS) \ $(libeztrace_autostart_stdio_la_LDFLAGS) $(LDFLAGS) -o $@ am_libeztrace_convert_stdio_la_OBJECTS = \ libeztrace_convert_stdio_la-eztrace_convert_stdio.lo libeztrace_convert_stdio_la_OBJECTS = \ $(am_libeztrace_convert_stdio_la_OBJECTS) libeztrace_convert_stdio_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_convert_stdio_la_LDFLAGS) \ $(LDFLAGS) -o $@ libeztrace_stdio_la_DEPENDENCIES = $(am__DEPENDENCIES_2) am_libeztrace_stdio_la_OBJECTS = libeztrace_stdio_la-stdio.lo libeztrace_stdio_la_OBJECTS = $(am_libeztrace_stdio_la_OBJECTS) libeztrace_stdio_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_stdio_la_LDFLAGS) \ $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libeztrace_autostart_stdio_la_SOURCES) \ $(libeztrace_convert_stdio_la_SOURCES) \ $(libeztrace_stdio_la_SOURCES) DIST_SOURCES = $(libeztrace_autostart_stdio_la_SOURCES) \ $(libeztrace_convert_stdio_la_SOURCES) \ $(libeztrace_stdio_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac HEADERS = $(noinst_HEADERS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ TLCFLAGS = $(TL_CPPFLAGS) TLLDFLAGS = $(TL_LDFLAGS) TLLIBADD = $(TL_LIB) GTGCFLAGS = $(GTG_CPPFLAGS) GTGLDFLAGS = $(GTG_LDFLAGS) GTGDEPENDENCIES = $(GTG_DEPENDENCIES) GTGLIBADD = $(GTG_LIB) lib_LTLIBRARIES = libeztrace-convert-stdio.la \ libeztrace-stdio.la \ libeztrace-autostart-stdio.la AM_CFLAGS = -W -Wall -Wextra -I$(srcdir)/../../core/ -I$(top_builddir)/src/core \ -I$(top_srcdir)/src/pptrace libeztrace_convert_stdio_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) libeztrace_convert_stdio_la_LIBADD = $(TLLIBADD) $(GTGLIBADD) libeztrace_convert_stdio_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) libeztrace_convert_stdio_la_DEPENDENCIES = $(GTGDEPENDENCIES) libeztrace_convert_stdio_la_SOURCES = eztrace_convert_stdio.c libeztrace_stdio_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_stdio_la_LIBADD = $(TLLIBADD) libeztrace_stdio_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_stdio_la_SOURCES = stdio.c libeztrace_autostart_stdio_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_autostart_stdio_la_LIBADD = $(TLLIBADD) libeztrace_autostart_stdio_la_LDFLAGS = --no-undefined $(TLLDFLAGS) libeztrace_autostart_stdio_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra -DEZTRACE_AUTOSTART libeztrace_autostart_stdio_la_SOURCES = stdio.c noinst_HEADERS = stdio_ev_codes.h all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/modules/stdio/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu src/modules/stdio/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ } uninstall-libLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ done clean-libLTLIBRARIES: -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) @list='$(lib_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libeztrace-autostart-stdio.la: $(libeztrace_autostart_stdio_la_OBJECTS) $(libeztrace_autostart_stdio_la_DEPENDENCIES) $(EXTRA_libeztrace_autostart_stdio_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_autostart_stdio_la_LINK) -rpath $(libdir) $(libeztrace_autostart_stdio_la_OBJECTS) $(libeztrace_autostart_stdio_la_LIBADD) $(LIBS) libeztrace-convert-stdio.la: $(libeztrace_convert_stdio_la_OBJECTS) $(libeztrace_convert_stdio_la_DEPENDENCIES) $(EXTRA_libeztrace_convert_stdio_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_convert_stdio_la_LINK) -rpath $(libdir) $(libeztrace_convert_stdio_la_OBJECTS) $(libeztrace_convert_stdio_la_LIBADD) $(LIBS) libeztrace-stdio.la: $(libeztrace_stdio_la_OBJECTS) $(libeztrace_stdio_la_DEPENDENCIES) $(EXTRA_libeztrace_stdio_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_stdio_la_LINK) -rpath $(libdir) $(libeztrace_stdio_la_OBJECTS) $(libeztrace_stdio_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_autostart_stdio_la-stdio.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_stdio_la-eztrace_convert_stdio.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_stdio_la-stdio.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< libeztrace_autostart_stdio_la-stdio.lo: stdio.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_stdio_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_stdio_la_CFLAGS) $(CFLAGS) -MT libeztrace_autostart_stdio_la-stdio.lo -MD -MP -MF $(DEPDIR)/libeztrace_autostart_stdio_la-stdio.Tpo -c -o libeztrace_autostart_stdio_la-stdio.lo `test -f 'stdio.c' || echo '$(srcdir)/'`stdio.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_autostart_stdio_la-stdio.Tpo $(DEPDIR)/libeztrace_autostart_stdio_la-stdio.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='stdio.c' object='libeztrace_autostart_stdio_la-stdio.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_stdio_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_stdio_la_CFLAGS) $(CFLAGS) -c -o libeztrace_autostart_stdio_la-stdio.lo `test -f 'stdio.c' || echo '$(srcdir)/'`stdio.c libeztrace_convert_stdio_la-eztrace_convert_stdio.lo: eztrace_convert_stdio.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_stdio_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_stdio_la-eztrace_convert_stdio.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_stdio_la-eztrace_convert_stdio.Tpo -c -o libeztrace_convert_stdio_la-eztrace_convert_stdio.lo `test -f 'eztrace_convert_stdio.c' || echo '$(srcdir)/'`eztrace_convert_stdio.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_stdio_la-eztrace_convert_stdio.Tpo $(DEPDIR)/libeztrace_convert_stdio_la-eztrace_convert_stdio.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_stdio.c' object='libeztrace_convert_stdio_la-eztrace_convert_stdio.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_stdio_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_stdio_la-eztrace_convert_stdio.lo `test -f 'eztrace_convert_stdio.c' || echo '$(srcdir)/'`eztrace_convert_stdio.c libeztrace_stdio_la-stdio.lo: stdio.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_stdio_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_stdio_la-stdio.lo -MD -MP -MF $(DEPDIR)/libeztrace_stdio_la-stdio.Tpo -c -o libeztrace_stdio_la-stdio.lo `test -f 'stdio.c' || echo '$(srcdir)/'`stdio.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_stdio_la-stdio.Tpo $(DEPDIR)/libeztrace_stdio_la-stdio.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='stdio.c' object='libeztrace_stdio_la-stdio.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_stdio_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_stdio_la-stdio.lo `test -f 'stdio.c' || echo '$(srcdir)/'`stdio.c mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) $(HEADERS) installdirs: for dir in "$(DESTDIR)$(libdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-libLTLIBRARIES install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-libLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libLTLIBRARIES clean-libtool cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-libLTLIBRARIES install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-libLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/src/modules/stdio/eztrace_convert_stdio.c000066400000000000000000000122161265506773700233170ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE #include #include #include "eztrace_convert.h" #include "stdio_ev_codes.h" #include "eztrace_list.h" static int recording_stats = 0; #define STDIO_CHANGE() if(!recording_stats) CHANGE() #define TOSTRING(x) #x #define GENERATE_HANDLER(fname) \ void handle_stdio_##fname (int start) \ { \ FUNC_NAME; \ DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); \ if(start) { \ STDIO_CHANGE() pushState(CURRENT, "ST_Thread", thread_id, TOSTRING(stdio_##fname)); \ }else{ \ STDIO_CHANGE() popState(CURRENT, "ST_Thread", thread_id); \ } \ } GENERATE_HANDLER(read) GENERATE_HANDLER(pread) GENERATE_HANDLER(readv) GENERATE_HANDLER(fread) GENERATE_HANDLER(write) GENERATE_HANDLER(pwrite) GENERATE_HANDLER(writev) GENERATE_HANDLER(fwrite) GENERATE_HANDLER(select) GENERATE_HANDLER(pselect) GENERATE_HANDLER(lseek) GENERATE_HANDLER(poll) GENERATE_HANDLER(ppoll) int eztrace_convert_stdio_init() { if (get_mode() == EZTRACE_CONVERT) { addEntityValue("stdio_read", "ST_Thread", "stdio_read", GTG_BLACK); addEntityValue("stdio_pread", "ST_Thread", "stdio_pread", GTG_BLACK); addEntityValue("stdio_readv", "ST_Thread", "stdio_readv", GTG_BLACK); addEntityValue("stdio_fread", "ST_Thread", "stdio_fread", GTG_BLACK); addEntityValue("stdio_write", "ST_Thread", "stdio_write", GTG_BLACK); addEntityValue("stdio_pwrite", "ST_Thread", "stdio_pwrite", GTG_BLACK); addEntityValue("stdio_writev", "ST_Thread", "stdio_writev", GTG_BLACK); addEntityValue("stdio_fwrite", "ST_Thread", "stdio_fwrite", GTG_BLACK); addEntityValue("stdio_select", "ST_Thread", "stdio_select", GTG_BLACK); addEntityValue("stdio_pselect", "ST_Thread", "stdio_pselect", GTG_BLACK); addEntityValue("stdio_lseek", "ST_Thread", "stdio_lseek", GTG_BLACK); addEntityValue("stdio_poll", "ST_Thread", "stdio_poll", GTG_BLACK); addEntityValue("stdio_ppoll", "ST_Thread", "stdio_ppoll", GTG_BLACK); } return 0; } /* return 1 if the event was handled */ int handle_stdio_events(eztrace_event_t *ev) { if (!STARTED) return 0; switch (LITL_READ_GET_CODE(ev)) { case EZTRACE_STDIO_READ_START: handle_stdio_read(1); break; case EZTRACE_STDIO_PREAD_START: handle_stdio_pread(1); break; case EZTRACE_STDIO_READV_START: handle_stdio_readv(1); break; case EZTRACE_STDIO_FREAD_START: handle_stdio_fread(1); break; case EZTRACE_STDIO_WRITE_START: handle_stdio_write(1); break; case EZTRACE_STDIO_PWRITE_START: handle_stdio_pwrite(1); break; case EZTRACE_STDIO_WRITEV_START: handle_stdio_writev(1); break; case EZTRACE_STDIO_FWRITE_START: handle_stdio_fwrite(1); break; case EZTRACE_STDIO_SELECT_START: handle_stdio_select(1); break; case EZTRACE_STDIO_PSELECT_START: handle_stdio_pselect(1); break; case EZTRACE_STDIO_LSEEK_START: handle_stdio_lseek(1); break; case EZTRACE_STDIO_POLL_START: handle_stdio_poll(1); break; case EZTRACE_STDIO_PPOLL_START: handle_stdio_ppoll(1); break; case EZTRACE_STDIO_READ_STOP: handle_stdio_read(0); break; case EZTRACE_STDIO_PREAD_STOP: handle_stdio_pread(0); break; case EZTRACE_STDIO_READV_STOP: handle_stdio_readv(0); break; case EZTRACE_STDIO_FREAD_STOP: handle_stdio_fread(0); break; case EZTRACE_STDIO_WRITE_STOP: handle_stdio_write(0); break; case EZTRACE_STDIO_PWRITE_STOP: handle_stdio_pwrite(0); break; case EZTRACE_STDIO_WRITEV_STOP: handle_stdio_writev(0); break; case EZTRACE_STDIO_FWRITE_STOP: handle_stdio_fwrite(0); break; case EZTRACE_STDIO_SELECT_STOP: handle_stdio_select(0); break; case EZTRACE_STDIO_PSELECT_STOP: handle_stdio_pselect(0); break; case EZTRACE_STDIO_LSEEK_STOP: handle_stdio_lseek(0); break; case EZTRACE_STDIO_POLL_STOP: handle_stdio_poll(0); break; case EZTRACE_STDIO_PPOLL_STOP: handle_stdio_ppoll(0); break; default: return 0; } return 1; } int handle_stdio_stats(eztrace_event_t *ev) { recording_stats = 1; return handle_stdio_events(ev); } void print_stdio_stats() { printf("\nSTDIO:\n"); printf("-------\n"); } struct eztrace_convert_module stdio_module; void libinit(void) __attribute__ ((constructor)); void libinit(void) { stdio_module.api_version = EZTRACE_API_VERSION; stdio_module.init = eztrace_convert_stdio_init; stdio_module.handle = handle_stdio_events; stdio_module.handle_stats = handle_stdio_stats; stdio_module.print_stats = print_stdio_stats; stdio_module.module_prefix = EZTRACE_STDIO_EVENTS_ID; int res __attribute__ ((__unused__)); res = asprintf(&stdio_module.name, "stdio"); res = asprintf( &stdio_module.description, "Module for stdio functions (read, write, select, poll, etc.)"); stdio_module.token.data = &stdio_module; eztrace_convert_register_module(&stdio_module); } void libfinalize(void) __attribute__ ((destructor)); void libfinalize(void) { } eztrace-1.1-2/src/modules/stdio/stdio.c000066400000000000000000000165031265506773700200450ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #define _GNU_SOURCE 1 /* or _BSD_SOURCE or _SVID_SOURCE */ #define _REENTRANT #include #include #include #include #include #include #include #include #include "stdio_ev_codes.h" #include "eztrace.h" #include "pptrace.h" /* set to 1 when all the hooks are set. * This is usefull in order to avoid recursive calls */ static int __stdio_initialized = 0; ssize_t (*libread)(int fd, void *buf, size_t count); ssize_t read(int fd, void *buf, size_t count) { FUNCTION_ENTRY; INTERCEPT("read", libread); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_READ_START, fd, buf, count); ssize_t ret = libread(fd, buf, count); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_READ_STOP, fd, buf, count); return ret; } ssize_t (*libwrite)(int fd, const void *buf, size_t count); ssize_t write(int fd, const void *buf, size_t count) { FUNCTION_ENTRY; INTERCEPT("write", libwrite); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_WRITE_START, fd, buf, count); ssize_t ret = libwrite(fd, buf, count); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_WRITE_STOP, fd, buf, count); return ret; } /* pointers to actual stdio functions */ ssize_t (*libpread)(int fd, void *buf, size_t count, off_t offset); ssize_t (*libpwrite)(int fd, const void *buf, size_t count, off_t offset); ssize_t (*libreadv)(int fd, const struct iovec *iov, int iovcnt); ssize_t (*libwritev)(int fd, const struct iovec *iov, int iovcnt); size_t (*libfread)(void *ptr, size_t size, size_t nmemb, FILE *stream); size_t (*libfwrite)(const void *ptr, size_t size, size_t nmemb, FILE *stream); off_t (*liblseek)(int fd, off_t offset, int whence); int (*libselect)(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout); int (*libpselect)(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, const struct timespec *timeout, const sigset_t *sigmask); int (*libpoll)(struct pollfd *fds, nfds_t nfds, int timeout); int (*libppoll)(struct pollfd *fds, nfds_t nfds, const struct timespec *timeout, const sigset_t *sigmask); ssize_t pread(int fd, void *buf, size_t count, off_t offset) { FUNCTION_ENTRY; INTERCEPT("pread", libpread); EZTRACE_EVENT_PACKED_4(EZTRACE_STDIO_PREAD_START, fd, buf, count, offset); ssize_t ret = libpread(fd, buf, count, offset); EZTRACE_EVENT_PACKED_4(EZTRACE_STDIO_PREAD_STOP, fd, buf, count, offset); return ret; } ssize_t pwrite(int fd, const void *buf, size_t count, off_t offset) { FUNCTION_ENTRY; INTERCEPT("pwrite", libpwrite); EZTRACE_EVENT_PACKED_4(EZTRACE_STDIO_PWRITE_START, fd, buf, count, offset); ssize_t ret = libpwrite(fd, buf, count, offset); EZTRACE_EVENT_PACKED_4(EZTRACE_STDIO_PWRITE_STOP, fd, buf, count, offset); return ret; } ssize_t readv(int fd, const struct iovec *iov, int iovcnt) { FUNCTION_ENTRY; INTERCEPT("readv", libreadv); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_READV_START, fd, iov, iovcnt); ssize_t ret = libreadv(fd, iov, iovcnt); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_READV_STOP, fd, iov, iovcnt); return ret; } ssize_t writev(int fd, const struct iovec *iov, int iovcnt) { FUNCTION_ENTRY; INTERCEPT("writev", libwritev); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_WRITEV_START, fd, iov, iovcnt); ssize_t ret = libwritev(fd, iov, iovcnt); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_WRITEV_STOP, fd, iov, iovcnt); return ret; } size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream) { FUNCTION_ENTRY; INTERCEPT("fread", libfread); EZTRACE_EVENT_PACKED_4(EZTRACE_STDIO_FREAD_START, ptr, size, nmemb, stream); size_t ret = libfread(ptr, size, nmemb, stream); EZTRACE_EVENT_PACKED_4(EZTRACE_STDIO_FREAD_STOP, ptr, size, nmemb, stream); return ret; } size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream) { FUNCTION_ENTRY; INTERCEPT("fwrite", libfwrite); if (!__stdio_initialized) { if (!libfwrite) { printf("Interception did not work for fwrite\n"); abort(); } return libfwrite(ptr, size, nmemb, stream); } EZTRACE_EVENT_PACKED_4(EZTRACE_STDIO_FWRITE_START, ptr, size, nmemb, stream); size_t ret = libfwrite(ptr, size, nmemb, stream); EZTRACE_EVENT_PACKED_4(EZTRACE_STDIO_FWRITE_STOP, ptr, size, nmemb, stream); return ret; } off_t lseek(int fd, off_t offset, int whence) { FUNCTION_ENTRY; static int not_yet_init = 1; if (not_yet_init) { INTERCEPT("lseek", liblseek); not_yet_init = 0; } EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_LSEEK_START, fd, offset, whence); off_t ret = liblseek(fd, offset, whence); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_LSEEK_STOP, fd, offset, whence); return ret; } int select(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout) { FUNCTION_ENTRY; INTERCEPT("select", libselect); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_SELECT_START, nfds, timeout?timeout->tv_sec : 0, timeout?timeout->tv_usec : 0); int ret = libselect(nfds, readfds, writefds, exceptfds, timeout); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_SELECT_STOP, nfds, timeout?timeout->tv_sec : 0, timeout?timeout->tv_usec : 0); return ret; } int pselect(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, const struct timespec *timeout, const sigset_t *sigmask) { FUNCTION_ENTRY; INTERCEPT("pselect", libpselect); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_PSELECT_START, nfds, timeout?timeout->tv_sec : 0, timeout?timeout->tv_nsec : 0); int ret = libpselect(nfds, readfds, writefds, exceptfds, timeout, sigmask); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_PSELECT_STOP, nfds, timeout?timeout->tv_sec : 0, timeout?timeout->tv_nsec : 0); return ret; } int poll(struct pollfd *fds, nfds_t nfds, int timeout) { FUNCTION_ENTRY; INTERCEPT("poll", libpoll); EZTRACE_EVENT_PACKED_2(EZTRACE_STDIO_POLL_START, nfds, timeout); int ret = libpoll(fds, nfds, timeout); EZTRACE_EVENT_PACKED_2(EZTRACE_STDIO_POLL_STOP, nfds, timeout); return ret; } int ppoll(struct pollfd *fds, nfds_t nfds, const struct timespec *timeout, const sigset_t *sigmask) { FUNCTION_ENTRY; INTERCEPT("ppoll", libppoll); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_PPOLL_START, nfds, timeout?timeout->tv_sec : 0, timeout?timeout->tv_nsec : 0); int ret = libppoll(fds, nfds, timeout, sigmask); EZTRACE_EVENT_PACKED_3(EZTRACE_STDIO_PPOLL_STOP, nfds, timeout?timeout->tv_sec : 0, timeout?timeout->tv_nsec : 0); return ret; } START_INTERCEPT_MODULE(stdio) INTERCEPT2("read", libread) INTERCEPT2("write", libwrite) INTERCEPT2("pread", libpread) INTERCEPT2("pwrite", libpwrite) INTERCEPT2("readv", libreadv) INTERCEPT2("writev", libwritev) INTERCEPT2("fread", libfread) INTERCEPT2("fwrite", libfwrite) INTERCEPT2("lseek", liblseek) INTERCEPT2("select", libselect) INTERCEPT2("pselect", libpselect) INTERCEPT2("poll", libpoll) INTERCEPT2("ppoll", libppoll) END_INTERCEPT_MODULE(stdio) static void __stdio_init(void) __attribute__ ((constructor)); static void __stdio_init(void) { DYNAMIC_INTERCEPT_ALL_MODULE(stdio); #ifdef EZTRACE_AUTOSTART eztrace_start(); #endif __stdio_initialized = 1; } static void __stdio_conclude(void) __attribute__ ((destructor)); static void __stdio_conclude(void) { __stdio_initialized = 0; eztrace_stop(); } eztrace-1.1-2/src/modules/stdio/stdio_ev_codes.h000066400000000000000000000042431265506773700217170ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, Telecom SudParis * See COPYING in top-level directory. */ #ifndef __STDIO_EV_CODES_H__ #define __STDIO_EV_CODES_H__ #include "ev_codes.h" #define EZTRACE_STDIO_EVENTS_ID SYSTEM_MODULE_ID(0x03) #define EZTRACE_STDIO_PREFIX GENERATE_SYSTEM_MODULE_PREFIX(EZTRACE_STDIO_EVENTS_ID) #define EZTRACE_STDIO_READ_START (EZTRACE_STDIO_PREFIX | 0X0110) #define EZTRACE_STDIO_PREAD_START (EZTRACE_STDIO_PREFIX | 0X0120) #define EZTRACE_STDIO_READV_START (EZTRACE_STDIO_PREFIX | 0X0130) #define EZTRACE_STDIO_FREAD_START (EZTRACE_STDIO_PREFIX | 0X0140) #define EZTRACE_STDIO_WRITE_START (EZTRACE_STDIO_PREFIX | 0X0210) #define EZTRACE_STDIO_PWRITE_START (EZTRACE_STDIO_PREFIX | 0X0220) #define EZTRACE_STDIO_WRITEV_START (EZTRACE_STDIO_PREFIX | 0X0230) #define EZTRACE_STDIO_FWRITE_START (EZTRACE_STDIO_PREFIX | 0X0240) #define EZTRACE_STDIO_SELECT_START (EZTRACE_STDIO_PREFIX | 0X0310) #define EZTRACE_STDIO_PSELECT_START (EZTRACE_STDIO_PREFIX | 0X0320) #define EZTRACE_STDIO_LSEEK_START (EZTRACE_STDIO_PREFIX | 0X0330) #define EZTRACE_STDIO_POLL_START (EZTRACE_STDIO_PREFIX | 0X0340) #define EZTRACE_STDIO_PPOLL_START (EZTRACE_STDIO_PREFIX | 0X0350) #define EZTRACE_STDIO_READ_STOP (EZTRACE_STDIO_PREFIX | 0X0111) #define EZTRACE_STDIO_PREAD_STOP (EZTRACE_STDIO_PREFIX | 0X0121) #define EZTRACE_STDIO_READV_STOP (EZTRACE_STDIO_PREFIX | 0X0131) #define EZTRACE_STDIO_FREAD_STOP (EZTRACE_STDIO_PREFIX | 0X0141) #define EZTRACE_STDIO_WRITE_STOP (EZTRACE_STDIO_PREFIX | 0X0211) #define EZTRACE_STDIO_PWRITE_STOP (EZTRACE_STDIO_PREFIX | 0X0221) #define EZTRACE_STDIO_WRITEV_STOP (EZTRACE_STDIO_PREFIX | 0X0231) #define EZTRACE_STDIO_FWRITE_STOP (EZTRACE_STDIO_PREFIX | 0X0241) #define EZTRACE_STDIO_SELECT_STOP (EZTRACE_STDIO_PREFIX | 0X0311) #define EZTRACE_STDIO_PSELECT_STOP (EZTRACE_STDIO_PREFIX | 0X0321) #define EZTRACE_STDIO_LSEEK_STOP (EZTRACE_STDIO_PREFIX | 0X0331) #define EZTRACE_STDIO_POLL_STOP (EZTRACE_STDIO_PREFIX | 0X0341) #define EZTRACE_STDIO_PPOLL_STOP (EZTRACE_STDIO_PREFIX | 0X0351) #endif /* __STDIO_EV_CODES_H__ */ eztrace-1.1-2/src/pptrace/000077500000000000000000000000001265506773700154165ustar00rootroot00000000000000eztrace-1.1-2/src/pptrace/arch/000077500000000000000000000000001265506773700163335ustar00rootroot00000000000000eztrace-1.1-2/src/pptrace/arch/armv7/000077500000000000000000000000001265506773700173675ustar00rootroot00000000000000eztrace-1.1-2/src/pptrace/arch/armv7/opcode.c000066400000000000000000000030231265506773700210020ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * opcode.c * * Determining the size to override (by computing the size of instructions) using the opcode library */ #include #include #include #include #include int dummy_print(void *stream, const char *fmt) { return 0; } /* * This function determines the size of instructions that will be replaced. * Output is the size of the replacement */ ssize_t opcode_get_overridden_size(bfd *abfd, pid_t child, word_uint symbol, size_t trampoline_size) { size_t max_size = trampoline_size * 2; if (max_size < 10) max_size = 10; unsigned char* code = (unsigned char*) malloc(max_size); trace_read(child, symbol, code, max_size); struct disassemble_info i; INIT_DISASSEMBLE_INFO(i, NULL, dummy_print); i.arch = bfd_get_arch(abfd); i.mach = bfd_get_mach(abfd); disassembler_ftype disassemble = disassembler(abfd); i.buffer = code; i.buffer_vma = (unsigned long) i.buffer; i.buffer_length = max_size; i.disassembler_options = "force-thumb"; ssize_t j; for (j = 0; j < trampoline_size;) { j += disassemble(i.buffer_vma + j, &i); } free(code); return j; } ssize_t get_overridden_size(void* bin, pid_t child, word_uint symbol, size_t trampoline_size) { return opcode_get_overridden_size((bfd*) bin, child, symbol, trampoline_size); } eztrace-1.1-2/src/pptrace/arch/armv7/trace.c000066400000000000000000000021361265506773700206330ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * trace.c * * Determining the size to override (by computing the size of instructions) using single step tracing */ #include #include #include #include #include #define ARM_INSTR_SIZE_BYTE (ARM_INSTR_SIZE/8) /* * This function determines the size of instructions that will be replaced. * Output is the size of the replacement */ ssize_t get_overridden_size(void *bin, pid_t child, word_uint symbol, size_t trampoline_size) { /* On ARM mode, the size of instructions is static (32 bits). Thus, the size of instructions to replace * can be computed as follows. * Please note that this is only possible for ARM mode, *the result for Thumb mode is incorrect* ! */ return (size_t)( ((trampoline_size + symbol) / ARM_INSTR_SIZE_BYTE + ((trampoline_size + symbol) % ARM_INSTR_SIZE_BYTE == 0 ? 0 : 1)) * ARM_INSTR_SIZE_BYTE - symbol); } eztrace-1.1-2/src/pptrace/arch/bfd.c000066400000000000000000000140471265506773700172400ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * bfd.c * * Parsing of binaries using the BFD library. See binary.h for the interfaces * This file needs the -lbfd flag when linking * * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #include #include #include #include #include #include #include #include #include #include #include "ezt_demangle.h" // Internals int _initialized = 0; void _zzt_bin_init() { if (_initialized == 0) { bfd_init(); } } zzt_word zzt_asymbol_size(asymbol *sym) { if (bfd_asymbol_flavour(sym) == bfd_target_elf_flavour) { // ELF case hack by reverse engineering libbfd... bfd_vma* ielf = (bfd_vma*) (sym + 1); // The elf_internal_sym structure can be found right after the bfd struct return *(ielf + 1); // and second word in that struct is the size of the symbol } else { // We don't know return 0; } } /* read the symtable * fills syms and return the number of symbols */ static int __get_symbol_table(bfd* abfd, asymbol***symbol_table) { asymbol** syms = 0; unsigned int size; int dyn = 0; int i; char *p = NULL; /* search for symbols a static binary */ long symcount = bfd_read_minisymbols(abfd, dyn, (void**)&syms, &size); if (symcount == 0) { /* no symbol found. abfd is probably a dynamic library */ dyn = 1; symcount = bfd_read_minisymbols(abfd, dyn, (void**)&syms, &size); } if (symcount < 0) { return symcount; } *symbol_table = (asymbol **) malloc(sizeof(asymbol*) * symcount); assert(*symbol_table); p = (char*)syms; for ( i = 0; i < symcount; i++) { (*symbol_table)[i] = bfd_minisymbol_to_symbol(abfd, dyn, p, NULL); p += size; } return symcount; } void* apply_on_symbol(void *bin, char *symbol, void* (*apply)(bfd *abfd, asymbol *sym, va_list ap), ...) { va_list ap; bfd* abfd = (bfd*) bin; asymbol **symbol_table; long number_of_symbols; long i; va_start(ap, apply); number_of_symbols = __get_symbol_table(abfd, &symbol_table); if (number_of_symbols < 0) return NULL; for (i = 0; i < number_of_symbols; i++) { if (strcmp(symbol_table[i]->name, symbol) == 0 || strcmp(ezt_demangle(symbol_table[i]->name), symbol) == 0) { void* result = apply(abfd, symbol_table[i], ap); va_end(ap); free(symbol_table); return result; } } va_end(ap); free(symbol_table); return NULL; } const char* pptrace_bin_error() { if (bfd_get_error() == bfd_error_no_error) return NULL; return bfd_errmsg(bfd_get_error()); } // free_symbol void free_symbol(zzt_symbol *symbol) { if (symbol) { if (symbol->symbol_name) free(symbol->symbol_name); symbol->symbol_name = NULL; if (symbol->section_name) free(symbol->section_name); symbol->section_name = NULL; free(symbol); } } // open_binary void* open_binary(char *path) { bfd * bfd; _zzt_bin_init(); bfd = bfd_openr(path, NULL); if (!bfd) { return NULL; } if (!bfd_check_format(bfd, bfd_object)) { bfd_close(bfd); return NULL; } return bfd; } // close_binary void close_binary(void *bin) { bfd_close((bfd*) bin); } int get_binary_bits(void *bin) { return bfd_arch_bits_per_address((bfd*) bin); } // get_symbol void* symbol_from_bfd_sym(bfd *abfd __attribute__((unused)), asymbol *sym, va_list ap __attribute__((unused))) { zzt_symbol *result; result = (zzt_symbol*) malloc(sizeof(zzt_symbol)); result->symbol_name = strdup(sym->name); result->symbol_offset = sym->value; if (bfd_get_section(sym) == NULL) { result->section_name = ""; result->section_addr = 0; } else { result->section_name = strdup(bfd_get_section(sym)->name); result->section_addr = bfd_asymbol_base(sym); } result->symbol_size = zzt_asymbol_size(sym); #ifdef __arm__ /* On ARM processors, a symbol defined in a shared-library (ie. marked as 'U' in the symbol table) * may have a base address. The instructions located at this base address seem to be replaced by * the 'real' instruction when the library is loaded. * * In order to simplify pptrace behavior, let's return NULL for these symbols. */ if(result) { symbol_info syminfo; bfd_get_symbol_info(abfd, sym, &syminfo); if(syminfo.type == 'U') { result = NULL; } } #endif return (void*) result; } zzt_symbol* get_symbol(void *bin, char *symbol) { return (zzt_symbol*) apply_on_symbol(bin, symbol, symbol_from_bfd_sym); } // read_symbol void* read_symbol_from_bfd_sym(bfd *abfd, asymbol *sym, va_list ap) { void* buffer = va_arg(ap, void*); ssize_t size = va_arg(ap, ssize_t); size_t result = zzt_asymbol_size(sym); if (result == 0 || result > size) result = size; if (bfd_get_section(sym) != NULL) { if (bfd_get_section_contents(abfd, bfd_get_section(sym), buffer, sym->value, result)) { return (void*) result; } } return (void*) 0; } size_t read_symbol(void *bin, zzt_symbol *symbol, void *buffer, ssize_t size) { return (size_t) apply_on_symbol(bin, symbol->symbol_name, read_symbol_from_bfd_sym, buffer, size); } // read_zstring struct _get_section_struct { asection *result; zzt_word addr; }; size_t read_zstring(void *bin, zzt_symbol *symbol __attribute__((unused)), zzt_word addr, void *buffer, ssize_t size) { asection *sect; uint8_t buf; bfd *abfd = (bfd*) bin; for (sect = abfd->sections; sect != NULL; sect = sect->next) { if (sect->vma <= addr && addr < sect->vma + sect->size) { addr -= sect->vma; if (size > sect->size - addr) { size = sect->size - addr; } size_t result; for (result = 0; result < size - 1 && bfd_get_section_contents(abfd, sect, &buf, addr + result, 1) && buf != 0; result++) { ((uint8_t*) buffer)[result] = buf; } ((uint8_t*) buffer)[result] = 0; result++; return result; } } return 0; } eztrace-1.1-2/src/pptrace/arch/x86_64/000077500000000000000000000000001265506773700172715ustar00rootroot00000000000000eztrace-1.1-2/src/pptrace/arch/x86_64/hijack.c000066400000000000000000000077111265506773700206740ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * hijack.c * * Check the instructions that we are going to overwrite with a trampoline * */ #ifdef __x86_64__ #ifdef HAVE_LIBOPCODE #include #include #include #include int dummy_print(void *stream __attribute__((unused)), const char *fmt __attribute__((unused)), ...) { return 0; } #define HAVE_CHECK_INSTRUCTIONS /* Check the instructions that we are going to overwrite with a trampoline * Return 1 if the trampoline can be inserted without any issue. * return 0 if the trampoline may break the program */ int check_instructions(void* bin, pid_t child, word_uint sym_addr, word_uint reloc_addr, size_t length) { /* copy the child memory locally so that we can modify it */ uint8_t buffer[1024]; trace_read(child, sym_addr, buffer, length); bfd* abfd = (bfd*)bin; /* set to 1 if it is possible to modify the child program */ int can_change = 1; asection* section; section = bfd_get_section_by_name( abfd, ".text" ); if (section == NULL ) { return 0; } pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "Check instruction %d bytes starting at %p. relocating to %p\n", length, sym_addr, reloc_addr); /* reloc_addr and sym_addr are separated by more than 2GB * -> we can't use 'small jumps' */ if(reloc_addr-sym_addr > 1<<30) { can_change=0; } struct disassemble_info i; init_disassemble_info ( &i, NULL, dummy_print ); i.arch = bfd_get_arch(abfd); i.mach = bfd_get_mach(abfd); disassembler_ftype disassemble = disassembler(abfd); if ( disassemble == NULL ) { return 0; } i.buffer_vma = section->vma; i.buffer_length = section->size; i.section = section; bfd_malloc_and_get_section( abfd, section, &i.buffer ); disassemble_init_for_target ( &i ); unsigned long count, pc; pc = sym_addr; count = 0; unsigned start_addr=0; int need_to_push_changes=0; /* browse the instructions and search for problematic opcodes. We may have a * problem in the following situations: * - one of the instructions is a jump * - one of the instruction uses RIP-relative addressing * -> in this case we can try to change the offset */ do { pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "0x%x ", pc ); count = disassemble( pc, &i ); pc += count; pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "\n\t" ); /* TODO: check for other problematic instructions (ie. jump) */ if( buffer[start_addr] == 0x8b && buffer[start_addr+1] == 0x5) { /* the instruction is a 'mov offset(%rip), %register' * we need to change the value of offset */ if(can_change) { /* it is possible to change the offset */ //uint32_t *p_addr = (uint32_t*)&buffer[start_addr+2]; uint32_t addr = buffer[start_addr+2] | buffer[start_addr+3]<<8 |buffer[start_addr+4]<<16; pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "\t\told offset: %lx\n", addr); addr = addr-(reloc_addr-sym_addr); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "\t\tnew offset: %lx\n", addr); buffer[start_addr+2] = addr & 0xff; buffer[start_addr+3] = (addr & 0xff00)>>8; buffer[start_addr+4] = (addr & 0xff0000)>>16; addr = buffer[start_addr+2] | buffer[start_addr+3]<<8 |buffer[start_addr+4]<<16; need_to_push_changes=1; } else { /* it's not possible to change the offset. We should not instrument this * function ! */ return 0; } } start_addr+=count; } while ( count > 0 && pc < bfd_get_start_address( abfd ) + section->size && pc <= sym_addr+length); if(need_to_push_changes && can_change) { /* some instructions were modified. We need to push the modifications */ pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "\tWriting the modified instructions.\n"); trace_write(child, sym_addr, buffer, length); } return 1; } #endif /* HAVE_LIBOPCODES */ #endif /* __x86_64__ */ eztrace-1.1-2/src/pptrace/arch/x86_64/opcode.c000066400000000000000000000027421265506773700207130ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * opcode.c * * Determining the size to override (by computing the size of instructions) using the opcode library * * Created on: 2 August 2011 * Author: dmartin */ #include #include #include #include #include int dummy_print(void *stream, const char *fmt); /* * This function determines the size of instructions that will be replaced. * Output is the size of the replacement */ ssize_t opcode_get_overridden_size(bfd *abfd, pid_t child, word_uint symbol, size_t trampoline_size) { size_t max_size = trampoline_size * 2; bfd_byte *code; struct disassemble_info i; if (max_size < 10) max_size = 10; code = (bfd_byte*) malloc(max_size); trace_read(child, symbol, code, max_size); INIT_DISASSEMBLE_INFO(i, NULL, dummy_print); i.arch = bfd_get_arch(abfd); i.mach = bfd_get_mach(abfd); disassembler_ftype disassemble = disassembler(abfd); i.buffer = code; i.buffer_vma = (unsigned long) i.buffer; i.buffer_length = max_size; ssize_t j; for (j = 0; j < trampoline_size;) { j += disassemble(i.buffer_vma + j, &i); } free(code); return j; } ssize_t get_overridden_size(void* bin, pid_t child, word_uint symbol, size_t trampoline_size) { return opcode_get_overridden_size((bfd*) bin, child, symbol, trampoline_size); } eztrace-1.1-2/src/pptrace/arch/x86_64/trace.c000066400000000000000000000045701265506773700205410ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * trace.c * * Determining the size to override (by computing the size of instructions) using single step tracing * * Created on: 2 July 2011 * Author: Damien Martin-Guillerez */ #include #include #include #include #include /* * This function returns the jump size */ ssize_t trace_get_jump_size(pid_t child, word_uint instruction_addr) { uint8_t buf[10]; size_t offset = 0; uint8_t prefix = 0; trace_read(child, instruction_addr, buf, 10); ssize_t r = read_jump(buf, 10, offset, prefix); while (!r && offset < 9) { prefix = buf[offset]; offset++; r = read_jump(buf, 10, offset, prefix); } if (r > 0) { return r + offset; // it's a jump of r + offset bytes } return 0; } /* * This function determines the size of instructions that will be replaced. * To do so, place rip on the symbol and single step until the size of instruction exceed trampoline_size * Output is the size of the replacement */ ssize_t get_overridden_size(void *bin __attribute__((unused)), pid_t child, word_uint symbol, size_t trampoline_size) { REG_STRUCT regs; trace_get_regs(child, ®s); // Backup registers set_ip(child, symbol); // Jump to symbol word_uint crip = symbol; while (crip < symbol + trampoline_size) { int status = trace_singlestep(child); // single stepping until we go further than symbol + trampoline_size word_uint newrip = get_ip(child); // Unfortunately, this works only if no jump / call if (newrip < crip || newrip > crip + 2) { // There might be a jump // Tells whether it is a jump or not ssize_t off = trace_get_jump_size(child, crip); if (off) { newrip = crip + off; set_ip(child, newrip); } else if (newrip < crip) { trace_set_regs(child, ®s); // Restore registers return 0; // We have failed! } } else if (newrip == crip) { if (WIFSTOPPED(status)) { newrip = crip; // Stopped, continue } else { pptrace_fubar("got signal %d (term) %d (status)", WTERMSIG(status), WSTOPSIG(status)); } } crip = newrip; } trace_set_regs(child, ®s); // Restore registers return (size_t)(crip - symbol); } eztrace-1.1-2/src/pptrace/binary.c000066400000000000000000000027411265506773700170520ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * binary.c * * Wrapper to include the good library for parsing of binary files * * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #include #include #include #include #include #include "arch/bfd.c" char** read_zstring_array(void *bin, char *symbol) { char **result; char *buf; char buf2[4096]; zzt_symbol *sym = get_symbol(bin, symbol); int bytes = get_binary_bits(bin) >> 3; if (sym == NULL) return NULL; size_t size = sym->symbol_size; if (size <= 0) size = 1024; buf = malloc(size); if (buf == NULL) return NULL; uint32_t* val32 = (uint32_t*) buf; word_uint* val64 = (word_uint*) buf; size = read_symbol(bin, sym, buf, size) / bytes; result = (char**) malloc(size * sizeof(char*)); size_t i = 0; for (i = 0; i < size; i++) { zzt_word w = (bytes == 4) ? val32[i] : val64[i]; if (w == 0) { result[i] = 0; free(buf); return result; } read_zstring(bin, sym, w, buf2, 1024); // printf("\t[%d] %p %s\n", i, (void*)w, buf2); result[i] = strdup(buf2); } free(buf); return result; } void free_zstring_array(char **strarray) { int i = 0; while (strarray[i] != NULL) { free(strarray[i]); i++; } free(strarray); } eztrace-1.1-2/src/pptrace/binary.h000066400000000000000000000056671265506773700170710ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * binary.h -- Interface for reading symbol from binaries * * Provided methods: * - open_binary(path): open the binary for reading and return an opaque * structure * - close_binary(bin): close the opaque structure opened by open_binary * - get_symbol(bin, symbol): get the symbol in which name is provided by * the symbol parameter from the binary bin (opaque structure). * The returned structure contains the section of the symbol (name * and address), the offset of the symbol inside the section, * the symbol name and, if available, the symbol size. * - free_symbol(symbol): free a structure returned by a previous call of get_symbol() * - get_binary_bits(bin): return the size of a word inside the binary (e.g. is the code * of the binary for a 32 bits arch or a 64 bits * - read_symbol(bin, symbol, buffer, size): read the symbol content from the binary bin. * If the symbol is found and present in the library, then its content is * copied in buffer copying at most size bytes. The number of copied bytes * are returned in result. * - read_zstring(bin, symbol, addr, buffer, size): read size bytes given an address read from * the symbol given in argument. If the address is found, at most size bytes * are copied into buffer. * - read_zstring_array(bin, symbol): read a null terminated string array from a binary and * allocate the string array. The string array should be freed upon with * free_zstring_array(). * - free_zstring_array(arr): delete a null terminated string array allocated by read_zstring_array(). * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #ifndef PPTRACE_BINARY_H_ #define PPTRACE_BINARY_H_ #include #include #include #include "types.h" typedef word_uint zzt_word; typedef struct _zzt_symbol { zzt_word symbol_offset; char *symbol_name; zzt_word symbol_size; char *section_name; zzt_word section_addr; } zzt_symbol; #define INIT_ZZT_SYMBOL(n, addr, size) zzt_symbol n; n.symbol_name = #n; n.symbol_size = (zzt_word)(size); n.section_name = NULL; n.section_addr = (zzt_word)0; n.symbol_offset = (zzt_word)(addr); void close_binary(void *bin); void* open_binary(char *path); zzt_symbol* get_symbol(void *bin, char *symbol); void free_symbol(zzt_symbol *symbol); int get_binary_bits(void *bin); size_t read_symbol(void *bin, zzt_symbol *symbol, void *buffer, ssize_t size); size_t read_zstring(void *bin, zzt_symbol *symbol, zzt_word addr, void *buffer, ssize_t size); char** read_zstring_array(void *bin, char *symbol); void free_zstring_array(char **strarray); #endif /* PPTRACE_BINARY_H_ */ eztrace-1.1-2/src/pptrace/cpu/000077500000000000000000000000001265506773700162055ustar00rootroot00000000000000eztrace-1.1-2/src/pptrace/cpu/arm.c000066400000000000000000000057701265506773700171410ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * arm.c * * Generate opcodes for ARM cortex-A9 processors * * Author: Damien Martin-Guillerez */ #include #include ssize_t insert_opcodes(uint8_t* opcode, int opcode_size, uint8_t* buf, size_t size, size_t offset) { int i = 0; pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "(opcodes)\tinserting opcodes: "); while (offset < size && i < opcode_size) { pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "%02X ", opcode[i]); buf[offset] = opcode[i]; offset++; i++; } pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "\n"); return offset; } ssize_t read_jump(uint8_t* buf, size_t size, size_t offset, uint8_t prefix) { // Since the size of instructions on ARMv7 is static (=32b), the size of the jump instruction // can be simply computed as return ARM_INSTR_SIZE / 8; } static inline int get_unsigned_nb_bits(word_uint value) { int index = 0; while (value) { value >>= 1; index++; } return index; } int get_signed_nb_bits(word_int value) { if (value < 0) { value = -value; } else { value++; } return get_unsigned_nb_bits(value) + 1; } ssize_t generate_nops(uint8_t*buffer, size_t size) { int i; uint8_t buf[1024]; for (i = 0; i < 1024; i += 2) { buf[i] = 0xbf; buf[i + 1] = 0x00; } return insert_opcodes(buf, 12, buffer, size, 0); } ssize_t generate_trampoline(uint8_t* buffer, size_t size, word_uint orig_addr, word_uint reloc_addr) { uint8_t buf[12]; pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "(opcodes)\tgenerating trampoline from 0x%lx to 0x%lx\n", (unsigned long) orig_addr, (unsigned long) reloc_addr); if (size < 12) return -1; uint32_t addr = reloc_addr; #define GET_IM8(addr_16) ((addr_16) & 0x000000ff) #define GET_IM3(addr_16) (((addr_16)>>8) & 0x00000007) #define GET_I(addr_16) (((addr_16) >>11) & 0x00000001) #define GET_IM4(addr_16) (((addr_16) >>12) & 0x0000000f) /* working with register R8 */ uint8_t register_id = 8; /* switch to Thumb mode */ addr = addr | 0x01; // im4:i:im3:im8 uint16_t addr16 = addr & 0x0000FFFF; // movw rX, addr[0:15] uint32_t _im8 = GET_IM8(addr16); uint32_t _im3 = GET_IM3(addr16); uint32_t _i = GET_I (addr16); uint32_t _im4 = GET_IM4(addr16); buf[3] = (_im3 << 4) | register_id; buf[2] = _im8; buf[1] = (_i << 2) | (uint8_t) 0xf2; buf[0] = _im4 | (uint8_t) 0x40; // movt rX, addr[16:31] addr16 = addr >> 16; _im8 = GET_IM8(addr16); _im3 = GET_IM3(addr16); _i = GET_I (addr16); _im4 = GET_IM4(addr16); buf[7] = (_im3 << 4) | register_id; buf[6] = _im8; buf[5] = (_i << 2) | (uint8_t) 0xf2; buf[4] = _im4 | (uint8_t) 0xC0; // bx rX buf[8] = register_id << 3; buf[9] = 0x47; // nop buf[10] = 0x00; buf[11] = 0xbf; return insert_opcodes(buf, 12, buffer, size, 0); } eztrace-1.1-2/src/pptrace/cpu/intel.c000066400000000000000000000115561265506773700174740ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * intel.c * * Production of opcodes for 64-bit intel processors (aka. amd64 architecture). * This file should also be used for 32-bit targets (the program should adapt itself to the target). * * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #include #include #include "errors.h" ssize_t insert_opcodes(uint8_t* opcode, int opcode_size, uint8_t* buf, size_t size, size_t offset) { int i = 0; pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "(opcodes)\tinserting opcodes: "); while (offset < size && i < opcode_size) { pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "%02X ", opcode[i]); buf[offset] = opcode[i]; offset++; i++; } pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "\n"); return offset; } ssize_t read_jump(uint8_t* buf, size_t size, size_t offset, uint8_t prefix) { ssize_t offlen = (prefix == 0x66) ? 2 : 4; // if prefix is an instruction size override then it's 16-bits offset switch (buf[offset]) { case 0xEB: // JMP cb case 0xE3: // JrCXZ cb case 0x70: case 0x71: case 0x72: case 0x73: case 0x74: case 0x75: case 0x76: case 0x77: // Jcc cb case 0x78: case 0x79: case 0x7A: case 0x7B: case 0x7C: case 0x7D: case 0x7E: case 0x7F: return 2; case 0x0f: // Possible Jcc cw/cd (0x0f 0x8x cd) if (size < offset + 2) return -2; // We need more byte to answer return ((buf[offset + 1] & 0xf0) == 0x80) ? 2 + offlen : 0; case 0xE9: // JMP cw/cd case 0xE8: // CALL cw/cd case 0x9A: // CALL FAR cw/cd return 1 + offlen; case 0xFF: // JMP /4, JMP FAR /5, CALL /2, CALL FAR /3 // Parse the ModRM byte if (size < offset + 2) return -2; // We need more byte to answer uint8_t modRM = buf[offset + 1]; uint8_t mod = (modRM >> 6) & 0x3; uint8_t reg = (modRM >> 3) & 0x7; uint8_t rm = (modRM) & 0x7; if (reg < 2 || reg > 5) return -1; // Neither CALL nor JMP switch (mod) { case 0: // Registers ( + SIB byte if rm = 4) return (rm == 4) ? 4 : 3; case 3: // Extended registers return 3; case 1: // offset16 ( + SIB byte if rm = 4) return (rm == 4) ? 5 : 4; case 2: // offset32 ( + SIB byte if rm = 4) return (rm == 4) ? 7 : 6; } return -1; // ??? case 0xC3: // RET case 0xCB: // RET FAR return 1; case 0xC2: // RET cw case 0xCA: // RET FAR cw return 3; // Prefixes case 0x66: // Operand-Size Override case 0x67: // Address-Size Override case 0x2E: case 0x3E: case 0x26: case 0x64: case 0x65: case 0x36: // Segment Override case 0xF0: // Lock case 0xF3: case 0xF2: // Repeat return 0; // Retry with next byte default: return -1; // It's not a jump, nor a prefix } } static inline int get_unsigned_nb_bits(word_uint value) { int index = 0; while (value) { value >>= 1; index++; } return index; } int get_signed_nb_bits(word_int value) { if (value < 0) { value = -value; } else { value++; } return get_unsigned_nb_bits(value) + 1; } ssize_t generate_trampoline(uint8_t* buffer, size_t size, word_uint orig_addr, word_uint reloc_addr) { uint8_t buf[12]; word_int offset = reloc_addr - orig_addr; pptrace_debug( PPTRACE_DEBUG_LEVEL_ALL, "(opcodes)\tgenerating trampoline from 0x%lx to 0x%lx (delta is %ld)\n", (unsigned long) orig_addr, (unsigned long) reloc_addr, (unsigned long) offset); if (get_signed_nb_bits(offset - 2) <= 8) { if (size < 2) return -1; // 8-bit offset (jmp rel8off EB) buf[0] = 0xeb; buf[1] = offset - 2; return insert_opcodes(buf, 2, buffer, size, 0); } else if (get_signed_nb_bits(offset - 5) <= 32) { if (size < sizeof(uint32_t) + 1) return -1; // 32-bit offset (jmp rel32off E9) buf[0] = 0xe9; uint32_t off = offset - 5; memcpy((void*) (buf + 1), (void*) (&off), sizeof(uint32_t)); return insert_opcodes(buf, sizeof(uint32_t) + 1, buffer, size, 0); } else if (get_unsigned_nb_bits(reloc_addr) <= 32) { // 32-bits jump // mov eax, addr (B8 + rd); jump eax (FF E0) if (size < 7) return -1; buf[0] = 0xb8; // mov eax, addr uint32_t addr = reloc_addr; memcpy((void*) (buf + 1), (void*) (&addr), sizeof(uint32_t)); buf[5] = 0xff; // jmp eax buf[6] = 0xe0; return insert_opcodes(buf, 7, buffer, size, 0); } else { // 64-bits jump if (size < 12) return -1; // Absolute jump (mov rax, addr (REX.W + B8+ rd) ; jmp rax) buf[0] = 0x48; // mov rax, addr buf[1] = 0xb8; memcpy((void*) (buf + 2), (void*) (&reloc_addr), sizeof(word_uint)); buf[10] = 0xff; // jmp rax buf[11] = 0xe0; return insert_opcodes(buf, 12, buffer, size, 0); } } eztrace-1.1-2/src/pptrace/errors.c000066400000000000000000000035121265506773700170770ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * errors.c * * Created on: 2 Aug. 2011 * Author: Damien Martin-Guillerez */ #include #include #include #include #include #include #include char errmsg[1024]; int pptrace_debug_level = __PPTRACE_DEBUG_LEVEL; const char* pptrace_get_error() { const char *bin_error = pptrace_bin_error(); if (bin_error) return bin_error; if (errmsg[0]) return errmsg; if (errno) { return strerror(errno); } return NULL; } void pptrace_clear_error() { errmsg[0] = 0; } void pptrace_report_error(char *fmt, ...) { va_list va; va_start(va, fmt); vsnprintf(errmsg, sizeof(errmsg), fmt, va); va_end(va); } void pptrace_error(char *fmt, ...) { #if PPTRACE_DEBUG_LEVEL_NONE <= __PPTRACE_DEBUG_LEVEL va_list va; va_start(va, fmt); vfprintf(stderr, fmt, va); va_end(va); const char *emsg = pptrace_get_error(); if (emsg) { fprintf(stderr, ": %s\n", emsg); } else { fprintf(stderr, "\n"); } #endif } void pptrace_fubar(char *fmt, ...) { va_list va; va_start(va, fmt); fprintf(stderr, "FUBAR: "); vfprintf(stderr, fmt, va); fprintf(stderr, "\n"); va_end(va); exit(-1); } void pptrace_debug(int level, char *fmt, ...) { if (level <= pptrace_debug_level) { va_list va; va_start(va, fmt); vfprintf(stderr, fmt, va); va_end(va); } } void pptrace_dump_buffer(int level, char *buffer, size_t length) { size_t i; if (level <= pptrace_debug_level) { for (i = 0; i < length; i++) { fprintf(stderr, "%02x ", buffer[i]); if (i % 20 == 0) fprintf(stderr, "\n"); } fprintf(stderr, "\n"); } } eztrace-1.1-2/src/pptrace/errors.h000066400000000000000000000032161265506773700171050ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * errors.h -- Error reporting inside PPTrace. * * Methods provided are: * - pptrace_get_error(): returns the last reported error * - pptrace_clear_error(): clear the error reported by PPTrace internals * - pptrace_error(fmt, ...): printf-like function to display an error. * *PPTrace Internals* * - pptrace_report_error(fmt, ...): printf-like function to report an error * that won't be displayed. *PPTrace Internals* * - pptrace_fubar(fmt, ...): printf-like function for fatal error. This ends * the process. *PPTrace Internals* * - pptrace_bin_error(): method implemented by the binary module to provides * error specific to the binary module. *PPTrace Internals* * - pptrace_debug(level, fmt, ...): printf-like function for printing * debugging information. *PPTrace Internals* * - pptrace_dump_buffer(level, buffer, length): print in hex format the * buffer given in argument for debugging purpose. *PPTrace Internals* * * Created on: 2 Aug. 2011 * Author: Damien Martin-Guillerez */ #ifndef PPTRACE_ERRORS_H_ #define PPTRACE_ERRORS_H_ #include #include const char* pptrace_get_error(); void pptrace_clear_error(); void pptrace_error(char *fmt, ...); void pptrace_report_error(char *fmt, ...); void pptrace_fubar(char *fmt, ...); const char* pptrace_bin_error(); void pptrace_debug(int level, char *fmt, ...); void pptrace_dump_buffer(int level, char *buffer, size_t length); #endif // PPTRACE_ERRORS_H_ eztrace-1.1-2/src/pptrace/hijack.c000066400000000000000000000266721265506773700170300ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include #include #include #include #include #ifdef __x86_64__ #ifdef HAVE_LIBOPCODE #include "arch/x86_64/hijack.c" #endif /* HAVE_LIBOPCODES */ #endif #ifndef HAVE_CHECK_INSTRUCTIONS /* check_instructions is not defined. * define it as a dummy function that always allow the insertion of a trampoline */ int check_instructions(void* bin, pid_t child, word_uint sym_addr, word_uint reloc_addr, size_t length) { return 1; } #endif #define HIJACK_CODE_FAILED(test) if(test) { \ goto out_failed; \ } static ssize_t __install_jump(pid_t child, ssize_t max_size, word_uint src_addr, word_uint dest_addr) { // create the trampoline back to the original address uint8_t* jump = (uint8_t*) malloc(max_size); ssize_t jump_size = generate_trampoline(jump, max_size, src_addr, dest_addr); HIJACK_CODE_FAILED(jump_size < 0); // install the jump pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "(hijack)\tinserting a jump from (0x%lx) to (0x%lx)\n", (unsigned long) (src_addr), (unsigned long) (dest_addr)); trace_write(child, src_addr, jump, jump_size); out: assert(jump_size<=max_size); free(jump); return jump_size; out_failed: jump_size = -1; goto out; } /* copies the overwritten opcodes, creates the back jump from * reloc_addr+overwrite_size to sym_addr+overwrite_size and installs it * return the size of the created back jump (or -1 in case of an error) */ static ssize_t __install_back_jump(pid_t child, word_uint reloc_addr, word_uint sym_addr, ssize_t overwrite_size) { // copy the overwritten code to reloc_addr pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "(hijack)\tcopying overwritten code (%d bytes) from original code (0x%lx) to relocated position (0x%lx)\n", overwrite_size, (unsigned long) sym_addr, (unsigned long) (reloc_addr)); trace_copy(child, sym_addr, reloc_addr, overwrite_size); ssize_t back_jump_size = __install_jump(child, MAX_TRAMPOLINE_SIZE, reloc_addr+overwrite_size, sym_addr+overwrite_size); HIJACK_CODE_FAILED(back_jump_size < 0); out: return back_jump_size; out_failed: back_jump_size=-1; goto out; } /* creates the first jump from sym_addr to repl_addr * * return the size that will be overwritten when the jump is installed * or -1 in case of an error. */ static ssize_t __prepare_first_jump(void *bin, pid_t child, word_uint sym_addr, word_uint sym_size, word_uint repl_addr, uint8_t **first_jump){ *first_jump = (uint8_t*) malloc(sym_size); // Build the first jump from sym_addr to repl_addr ssize_t first_jump_size = generate_trampoline(*first_jump, sym_size, sym_addr, repl_addr); HIJACK_CODE_FAILED(first_jump_size < 0); // get the size to override ssize_t over = get_overridden_size(bin, child, sym_addr, first_jump_size); HIJACK_CODE_FAILED(over < first_jump_size || over > sym_size); out: return over; out_failed: /* no need to free first_jump since it will be freed by the calling function */ over=-1; goto out; } /* install the first jump from sym_addr to repl_addr and free *first_jump */ static void __finalize_first_jump(pid_t child, word_uint sym_addr, word_uint repl_addr, uint8_t* first_jump, ssize_t overwrite_size) { // install first_jump pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "(hijack)\tinserting first jump from 0x%lx to 0x%lx\n", (unsigned long) sym_addr, (unsigned long) repl_addr); trace_write(child, sym_addr, first_jump, overwrite_size); // Insert the long jump free(first_jump); } /* set the callback address to reloc_addr */ static void __assign_callback_address(pid_t child, word_uint reloc_addr, word_uint orig_addr) { pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "(hijack)\tassigning callback (located at addr 0x%lx) to 0x%lx\n", (unsigned long) orig_addr, (unsigned long) reloc_addr); trace_write(child, orig_addr, (uint8_t*) (&reloc_addr), sizeof(reloc_addr)); } ssize_t hijack_code_small_jump(void* bin, pid_t child, word_uint sym_addr, word_uint sym_size, word_uint reloc_addr, word_uint orig_addr, word_uint repl_addr) { // If the size is not available, then we suppose we have enough room if (sym_size <= 0) { sym_size = MAX_TRAMPOLINE_SIZE; } uint8_t* small_jump = NULL; /* sym_addr: address of the original function (in which we install a call to eztrace) * reloc_addr: address of the block of data that jumps to eztrace * repl_addr: address of the eztrace version of the function * orig_addr: address of the callback in eztrace that permits to call the user-defined function */ /* the goal here is to change the child process so that when the application calls the sym_addr function, * the following behavior occurs: * call sym_addr: (small) jump to reloc_addr (<-- small_jump) * reloc_addr: (long) jump to repl_addr (<-- long_jump) * repl_addr: perform eztrace stuff (recording events, etc.) * repl_addr: call *orig_addr (=reloc_addr+over) * orig_addr: replay the overwritten opcodes * orig_addr: (long) jump to sym_addr+x (<-- back_jump) * sym_addr: process stuff (it is the application function) * sym_addr: ret -> go back to repl_addr * repl_addr: perform eztrace stuff (recording events, etc.) * repl_addr: ret -> go back to the application */ /* We need to : - install a small (ie. relative) jump from sym_addr to reloc_addr - install long (ie. absolute) jump from reloc_addr to repl_addr - copy the overwritten opcodes from sym_addr to reloc_addr+sizeof(long_jump) - install a jump from reloc_addr+sizeof(long_jump) to sym_addr - set the callback value to reloc_addr+sizeof(long_jump) */ // Prepare the first (small) jump from sym_addr to reloc_addr ssize_t over = __prepare_first_jump(bin, child,sym_addr, sym_size, reloc_addr, &small_jump); HIJACK_CODE_FAILED((!check_instructions(bin, child, sym_addr, reloc_addr, over))); // Install the (long) jump from reloc_addr to repl_addr ssize_t long_jump_size = __install_jump(child, MAX_TRAMPOLINE_SIZE,reloc_addr, repl_addr); HIJACK_CODE_FAILED(long_jump_size < 0); // copy the overwritten opcodes and installs the jump back to sym_addr word_uint back_jump_addr = reloc_addr + long_jump_size; ssize_t back_jump_size = __install_back_jump(child, back_jump_addr, sym_addr, over); HIJACK_CODE_FAILED(back_jump_size < 0); // Insert the trampoline into the dest process __finalize_first_jump(child, sym_addr, reloc_addr, small_jump, over); // set the callback to back_jump_addr __assign_callback_address(child, back_jump_addr, orig_addr); // Return the size of the inserted code ssize_t retval = long_jump_size + back_jump_size + over; out: return retval; out_failed: free(small_jump); retval=-1; goto out; } ssize_t hijack_code_long_jump(void* bin, pid_t child, word_uint sym_addr, word_uint sym_size, word_uint reloc_addr, word_uint orig_addr, word_uint repl_addr) { // If the size is not available, then we assume we have enough room if (sym_size <= 0) { sym_size = MAX_TRAMPOLINE_SIZE; } /* sym_addr: address of the original function (in which we install a call to eztrace) * reloc_addr: address of the block of data that jumps back to the application * repl_addr: address of the eztrace version of the function * orig_addr: address of the callback in eztrace that permits to call the user-defined function */ /* the goal here is to change the child process so that when the application calls the sym_addr function, * the following behavior occurs: * call sym_addr: jump to repl_addr (<-- first_jump) * repl_addr: perform eztrace stuff (recording events, etc.) * repl_addr: call *orig_addr (=reloc_addr) * reloc_addr: replay the overwritten opcodes * reloc_addr: (long) jump to sym_addr+x (<-- back_jump) * sym_addr: process stuff (it is the application function) * sym_addr: ret -> go back to repl_addr * repl_addr: perform eztrace stuff (recording events, etc.) * repl_addr: ret -> go back to the application */ /* We need to : - install a jump from sym_addr to repl_addr - copy the overwritten opcodes from sym_addr to reloc_addr - install a jump from reloc_addr to sym_addr - set the callback value to reloc_addr */ // Prepare the first jump from sym_addr to repl_addr uint8_t *first_jump = NULL; ssize_t overwrite_size = __prepare_first_jump(bin, child, sym_addr, sym_size, repl_addr, &first_jump); HIJACK_CODE_FAILED(overwrite_size < 0); // Copy the opcodes that are going to be overwritten by first_jump // and install the jump back to sym_addr /* BUG: we should check that the relocated opcodes to not depend on their address * For instance, mov (%rip+x), %eax fails */ ssize_t back_jump_size = __install_back_jump(child, reloc_addr, sym_addr, overwrite_size); HIJACK_CODE_FAILED(back_jump_size < 0); // Now we can install the first jump (and thus overwrite the first opcode) __finalize_first_jump(child, sym_addr, repl_addr, first_jump, overwrite_size); // set the callback to reloc_addr #ifdef __arm__ /* we need to switch to Thumb momde */ reloc_addr |= 0x01; #endif __assign_callback_address(child, reloc_addr, orig_addr); // Return the size of the inserted code ssize_t retval = back_jump_size + overwrite_size; out: return retval; out_failed: free(first_jump); retval = 1; goto out; } ssize_t hijack_code(void* bin, pid_t child, word_uint sym_addr, word_uint sym_size, word_uint reloc_addr, word_uint orig_addr, word_uint repl_addr) { #if __arm__ return hijack_code_long_jump(bin, child, sym_addr, sym_size, reloc_addr, orig_addr, repl_addr); #else return hijack_code_small_jump(bin, child, sym_addr, sym_size, reloc_addr, orig_addr, repl_addr); #endif } ssize_t hijack(void* bin, pid_t child, zzt_symbol *toHijack, zzt_symbol *orig, zzt_symbol *repl) { // Compute the addresses from the symbols word_uint addr = (word_uint) (toHijack->symbol_offset + toHijack->section_addr); word_uint sym_size = (word_uint) (toHijack->symbol_size); word_uint orig_addr = (word_uint) (orig->symbol_offset + orig->section_addr); word_uint repl_addr = (word_uint) (repl->symbol_offset + repl->section_addr); pptrace_debug( PPTRACE_DEBUG_LEVEL_DEBUG, "Hijacking symbol %s (0x%lx) with %s (0x%lx) using %s (0x%lx) as function pointer...\n", toHijack->symbol_name, (unsigned long) addr, repl->symbol_name, (unsigned long) repl_addr, orig->symbol_name, (unsigned long) orig_addr); pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "Allocating buffer for relocating bytes... "); word_uint reloc_addr = allocate_buffer(child, MAX_TRAMPOLINE_SIZE); if (reloc_addr != 0) { pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "ok (0x%lx)\n", (unsigned long) reloc_addr); ssize_t hijack_size = hijack_code(bin, child, addr, sym_size, reloc_addr, orig_addr, repl_addr); if (hijack_size > 0 && hijack_size != MAX_TRAMPOLINE_SIZE) { correct_buffer_allocation(child, MAX_TRAMPOLINE_SIZE, hijack_size); } pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "Symbol hijacked...\n"); return hijack_size; } pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "failed!\n"); return -1; } eztrace-1.1-2/src/pptrace/hijack.h000066400000000000000000000030051265506773700170160ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * hijack.h -- High-level interface for inserting hijacks into a traced process * * Provided methods are: * - hijack_code(bin, child, sym_addr, sym_size, reloc_addr, orig_addr, * repl_addr): hijacks the symbol at address *sym_addr* which size is * *sym_size*. It will insert a jump to *repl_addr* at *sym_addr*. The * symbol at *orig_addr* will be filled with the address *reloc_addr* * that contains the code overridden by the trampoline. This is done by * determining the size of instruction using the *bin* parameter (a * binary opened by open_binary()) * - hijack(bin, child, toHijack, orig, repl): allocates * the destination buffer for the hijack and then do the hijack using * hijack_symbol(). *toHijack* is the symbol to intercept, *orig* is the * symbol to store the address of the hijack code and *repl* is the symbol * called instead of the *toHijack* symbol * * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #ifndef HIJACK_H_ #define HIJACK_H_ ssize_t hijack_code(void* bin, pid_t child, word_uint sym_addr, word_uint sym_size, word_uint reloc_addr, word_uint orig_addr, word_uint repl_addr); ssize_t hijack(void* bin, pid_t child, zzt_symbol *toHijack, zzt_symbol *orig, zzt_symbol *repl); #endif /* HIJACK_H_ */ eztrace-1.1-2/src/pptrace/isize.c000066400000000000000000000016601265506773700167100ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * isize.c * * Wrapper to include the good library for determining the instruction size * * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #include #include #ifdef __x86_64__ // x86_64 #ifndef __PPTRACE_ISIZE_TYPE #include "arch/x86_64/trace.c" #else #if __PPTRACE_ISIZE_TYPE == PPTRACE_ISIZE_TYPE_OPCODE #include "arch/x86_64/opcode.c" #else // if ! (__PPTRACE_ISIZE_TYPE == PPTRACE_ISIZE_TYPE_OPCODE) #include "arch/x86_64/trace.c" #endif // ! (__PPTRACE_ISIZE_TYPE == PPTRACE_ISIZE_TYPE_OPCODE) #endif // !defined(__PPTRACE_ISIZE_TYPE) #elif __arm__ // ARMv7 #ifdef HAVE_LIBOPCODE #include "arch/armv7/opcode.c" #else #warning Libopcode not available. pptrace will not work! #endif #endif eztrace-1.1-2/src/pptrace/isize.h000066400000000000000000000015731265506773700167200ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * isize.h -- determining instruction size * * Provided method: * - get_overridden_size(bin, child, symbol, trampoline_size): determines * how much of *symbol* should be copied to replace the part overridden by * the trampoline of size *trampoline_size*. *bin* is the opaque structure * of the binary and *child* the pid of the child process. * * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #ifndef PPTRACE_ISIZE_H_ #define PPTRACE_ISIZE_H_ #include #include #include ssize_t get_overridden_size(void* bin, pid_t child, word_uint symbol, size_t trampoline_size); #endif /* PPTRACE_ISIZE_H_ */ eztrace-1.1-2/src/pptrace/memory.c000066400000000000000000000027051265506773700170760ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * memory.c * * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #include #include #include // Memory allocation. Don't handle memory free (we don't care actually) #define MY_PAGE_SIZE (1024*1024) // We use 1Mbytes pages for allocation word_uint currentPointer = 0; // The current pointer toward free memory word_uint currentEndPointer = 0; // The pointer to the end of the current page word_uint allocate_buffer(pid_t child, size_t size) { // This algorithm is dummy, because we don't need to be memory efficient for the kind of target we plan if (currentPointer - currentEndPointer < size) { // We need a new page word_uint pagesize = MY_PAGE_SIZE; while (pagesize < size) pagesize += MY_PAGE_SIZE; currentPointer = trace_mmap(child, 0, pagesize, PROT_READ | PROT_EXEC); if (currentPointer) { currentEndPointer = currentPointer + pagesize; } else { currentEndPointer = 0; return 0; } } // Do the dummy allocation word_uint r = currentPointer; currentPointer += size; return r; } void correct_buffer_allocation(pid_t child __attribute__((unused)), size_t required_size, size_t actual_size) { currentPointer -= (required_size - actual_size); } eztrace-1.1-2/src/pptrace/memory.h000066400000000000000000000017561265506773700171100ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * memory.h -- handles memory allocation in the target process * * Provided methods: * - allocate_buffer(child, size): allocate a buffer of size *size* in * the process *child*. Returns the address allocated * - correct_buffer_allocation(child, required_size, actual_size): free * (*required_size*-*actual_size*) in the process *child* for the last * allocation made by allocate_buffer(). * * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #ifndef PPTRACE_MEMORY_H_ #define PPTRACE_MEMORY_H_ #include #include #include #include "types.h" word_uint allocate_buffer(pid_t child, size_t size); void correct_buffer_allocation(pid_t child, size_t required_size, size_t actual_size); #endif /* PPTRACE_MEMORY_H_ */ eztrace-1.1-2/src/pptrace/opcodes.c000066400000000000000000000016271265506773700172240ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * opcodes.c * * Wrapper to include the good set of opcodes. If we ever * support multiple instruction set, we should certainly change that by an array * of opcodes. * * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #include #include #if __x86_64__ // x86_64 //#ifndef __PPTRACE_ARCH_TYPE #include "cpu/intel.c" //#else //#if __PPTRACE_ARCH_TYPE == PPTRACE_ARCH_TYPE_XXX //#include "opcodes/x x x.c" //#else // if ! (__PPTRACE_ARCH_TYPE == PPTRACE_ARCH_TYPE_XXX) //#include "opcodes/intel.c" //#endif // ! (__PPTRACE_ARCH_TYPE == PPTRACE_ARCH_TYPE_XXX) //#endif // !defined(__PTRACE_ARCH_TYPE) #elif __arm__ // ARMv7 -- ARM cortex-A9 #include "cpu/arm.c" #endif eztrace-1.1-2/src/pptrace/opcodes.h000066400000000000000000000036151265506773700172300ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * opcodes.h -- Opcode generation * * - insert_opcodes(opcode, opcode_size, buf, size, offset): insert *opcode* * of size *opcode_size* at offset *offset* of *buf* of size *size*. * Returns min(offset+opcode_size, size) * - generate_trampoline(buf, size, orig_addr, reloc_addr): generates * opcodes to jump to *reloc_addr* from *orig_addr*. The opcodes are the * smallest possible. * The generated opcodes are put at the beginning of *buf* (that is * of size *size*). Returns the new size of the inserted opcodes. * - read_jump(buf, size, offset, prefix): read a jump part that was prefixed * by *prefix* and that is contained at offset *offset* of *buf* (*size* is * the size of *buf*). The returned value is the size of the instruction * if a jump is read, 0 if a valid prefix for a jump was encountered, and < 0 * if the instruction is not a jump. * * - MAX_TRAMPOLINE_SIZE is a constant giving the maximum size of a trampoline * overwrite * * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #ifndef PPTRACE_OPCODES_H_ #define PPTRACE_OPCODES_H_ #include #include #include #include "types.h" #if __x86_64__ #define MAX_TRAMPOLINE_SIZE 48 // Be large :) #elif __arm__ #define MAX_TRAMPOLINE_SIZE 24 // in bytes!!! = sizes of one jumps and max overridden size. #endif ssize_t insert_opcodes(uint8_t* opcode, int opcode_size, uint8_t* buf, size_t size, size_t offset); ssize_t generate_trampoline(uint8_t* buffer, size_t size, word_uint orig_addr, word_uint reloc_addr); ssize_t read_jump(uint8_t* buf, size_t size, size_t offset, uint8_t prefix); #endif /* PPTRACE_OPCODES_H_ */ eztrace-1.1-2/src/pptrace/os/000077500000000000000000000000001265506773700160375ustar00rootroot00000000000000eztrace-1.1-2/src/pptrace/os/linux/000077500000000000000000000000001265506773700171765ustar00rootroot00000000000000eztrace-1.1-2/src/pptrace/os/linux/linux.c000066400000000000000000000601711265506773700205060ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * linux.c * * Implementation of the tracing interface using the linux _ptrace system call * * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #include #include #include #include #include #ifdef __PPTRACE_USE_PRCTL #include #endif // __PPTRACE_USE_PRCTL #include #include #include #include #include #include #include #include #define CONTSIGNAL NULL static int ptrace_bits = __WORDSIZE; // Size of a word in the traced process #ifndef MAP_32BIT #define MAP_32BIT 0 #endif #if __x86_64__ // x86_64 #if __WORDSIZE == 64 // Registers name #define REG_IP rip #define REG_AX rax #define REG_ORIG_AX orig_rax #define REG_BX rbx #define REG_CX rcx #define REG_DX rdx #define REG_SI rsi #define REG_DI rdi #define REG_BP rbp #define REG_R10 r10 #define REG_R8 r8 #define REG_R9 r9 #define REG_FORMAT "rip=0x%016lx rax=0x%016lx orig_rax=0x%016lx rbx=0x%016lx rcx=0x%016lx rdx=0x%016lx rsi=0x%016lx rdi=0x%016lx rbp=0x%016lx r10=0x%016lx r8=0x%016lx r9=0x%016lx" #define REG_FORMAT_VALUES(regs) regs.rip, regs.rax, regs.orig_rax, regs.rbx, regs.rcx, regs.rdx, regs.rsi, regs.rdi, regs.rbp, regs.r10, regs.r8, regs.r9 // Debugging #define FORMAT_WORD_HEX "%02lx %02lx %02lx %02lx %02lx %02lx %02lx %02lx" #define FORMAT_WORD_POINTER "0x%016lx" #define ARG_FORMAT_WORD(data) (data) & 0xff, (data >> 8) & 0xff, (data >> 16) & 0xff, (data >> 24) & 0xff, (data >> 32) & 0xff,\ (data >> 40) & 0xff, (data >> 48) & 0xff, (data >> 56) & 0xff #else // if __WORDSIZE != 64 // Register names #define REG_IP eip #define REG_AX eax #define REG_ORIG_AX orig_eax #define REG_BX ebx #define REG_CX ecx #define REG_DX edx #define REG_SI esi #define REG_DI edi #define REG_BP ebp #define REG_R10 edi // dummy, doesn't exist in 32bits #define REG_R8 esi // dummy, doesn't exist in 32bits #define REG_R9 ebp // dummy, doesn't exist in 32bits #define REG_FORMAT "eip=0x%08lx eax=0x%08lx orig_eax=0x%08lx ebx=0x%08lx ecx=0x%08lx edx=0x%08lx esi=0x%08lx edi=0x%08lx ebp=0x%08lx" #define REG_FORMAT_VALUES(regs) regs.eip, regs.eax, regs.orig_eax, regs.ebx, regs.ecx, regs.edx, regs.esi, regs.edi, regs.ebp // Debugging #define FORMAT_WORD_HEX "%02lx %02lx %02lx %02lx" #define FORMAT_WORD_POINTER "0x%08lx" #define ARG_FORMAT_WORD(data) (data) & 0xff, (data >> 8) & 0xff, (data >> 16) & 0xff, (data >> 24) & 0xff #endif // __WORDSIZE == 64 #elif __arm__ // ARMv7 // Register names #define REG_R0 ARM_r0 #define REG_R1 ARM_r1 #define REG_R2 ARM_r2 #define REG_R3 ARM_r3 #define REG_R4 ARM_r4 #define REG_R5 ARM_r5 #define REG_R6 ARM_r6 #define REG_R7 ARM_r7 #define REG_R8 ARM_r8 #define REG_SP ARM_sp #define REG_FP ARM_fp #define REG_PC ARM_pc #define REG_FORMAT "ARM_r0=0x%08lx ARM_r1=0x%08lx ARM_r2=0x%08lx ARM_r3=0x%08lx ARM_r4=0x%08lx ARM_r5=0x%08lx ARM_r6=0x%08lx ARM_r7=0x%08lx ARM_r8=0x%08lx ARM_r9=0x%08lx ARM_sp=0x%08lx ARM_fp=0x%08lx ARM_pc=0x%08lx" #define REG_FORMAT_VALUES(regs) regs.ARM_r0, regs.ARM_r1, regs.ARM_r2, regs.ARM_r3, regs.ARM_r4, regs.ARM_r5, regs.ARM_r6, regs.ARM_r7, regs.ARM_r8, regs.ARM_sp, regs.ARM_fp, regs.ARM_pc // Debugging #define FORMAT_WORD_HEX "%02lx %02lx %02lx %02lx" #define FORMAT_WORD_POINTER "0x%08lx" #define ARG_FORMAT_WORD(data) (data) & 0xff, (data >> 8) & 0xff, (data >> 16) & 0xff, (data >> 24) & 0xff #endif // __arm__ void trace_set_bits(int bits) { ptrace_bits = bits; } int trace_get_bits() { return ptrace_bits; } /* * A wrapper to test for errors * TODO: Correct error handling in that part of the code */ static inline long __ptrace(enum __ptrace_request request, pid_t pid, void *addr, void *data, const char *file, int line) { errno = 0; long result = ptrace(request, pid, addr, data); if (errno && result == -1) { pptrace_fubar("at %s:%d: ptrace(%lu, %d, %p, %p): %s", file, line, (long) request, pid, addr, data, strerror(errno)); } return result; } #define _ptrace(req, pid, addr, data) __ptrace(req, pid, addr, data, __FILE__, __LINE__) extern int pptrace_debug_level; pid_t trace_run(char *path, char **argv, char **envp, int debug) { int status; int fds[2]; pipe(fds); char plop; pid_t child = fork(); if (pptrace_debug_level > PPTRACE_DEBUG_LEVEL_ALL) debug = 1; if ((debug == 0 && child != 0) || (debug && child == 0)) { #ifdef __PPTRACE_USE_PRCTL #ifdef PR_SET_PTRACER prctl(PR_SET_PTRACER, child, 0, 0, 0); #endif // PR_SET_PTRACER #endif // __PPTRACE_USE_PRCTL if (child == 0) _ptrace(PTRACE_TRACEME, 0, NULL, NULL); read(fds[0], &plop, sizeof(char)); close(fds[0]); if (path == NULL) { // No execution is asked (fork only) so return to the calling function kill(getpid(), SIGTRAP); // signal the parent to emulate execve call. return 0; } pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "execve(%s, ...)\n", path); execve(path, argv, envp); pptrace_debug(PPTRACE_DEBUG_LEVEL_VERBOSE, "Execution of %s failed\n", path); exit(-1); } pid_t tpid = debug ? child : getppid(); if (debug == 0) _ptrace(PTRACE_ATTACH, tpid, NULL, NULL); plop = 'a'; write(fds[1], &plop, sizeof(char)); close(fds[1]); waitpid(tpid, &status, 0); while (!WIFEXITED(status) && (!WIFSTOPPED(status) || WSTOPSIG(status) != SIGTRAP)) { _ptrace(PTRACE_CONT, tpid, NULL, NULL); waitpid(tpid, &status, 0); } pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "execve(%s, ...) passed\n", path); if (WIFEXITED(status)) { pptrace_debug( PPTRACE_DEBUG_LEVEL_VERBOSE, "Process %d exited (probably due to execution of %s failed)\n", tpid, path); return -1; } return tpid; } word_uint get_ip(pid_t child) { REG_STRUCT regs; _ptrace(PTRACE_GETREGS, child, NULL, ®s); #if __arm__ // ARMv7 return regs.REG_PC; #elif __x86_64__ // x86_64 return regs.REG_IP; #endif } void set_ip(pid_t child, word_uint rip) { REG_STRUCT regs; _ptrace(PTRACE_GETREGS, child, NULL, ®s); #if __arm__ // ARMv7 regs.REG_PC = rip; #elif __x86_64__ // x86_64 regs.REG_IP = rip; #endif _ptrace(PTRACE_SETREGS, child, NULL, ®s); } void trace_get_regs(pid_t child, REG_STRUCT* regs) { _ptrace(PTRACE_GETREGS, child, NULL, regs); } void trace_set_regs(pid_t child, REG_STRUCT* regs) { _ptrace(PTRACE_SETREGS, child, NULL, regs); } uint8_t trace_replace(pid_t child, word_uint addr, uint8_t newbyte) { int wordsize = ptrace_bits / 8; word_uint addrmask = ~((word_uint) (wordsize - 1)); int shift = (8 * (addr % wordsize)); word_uint data64 = 0; word_uint addr64 = addr & addrmask; /* todo: does it work on 32-bit systems (eg. ARM) ? */ word_uint mask = ~(((word_uint) 0xff) << shift); word_uint newvalue = newbyte; word_uint oldvalue = 0; newvalue <<= shift; data64 = _ptrace(PTRACE_PEEKTEXT, child, (void*)addr64, NULL); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "Replacing [" FORMAT_WORD_HEX "] from address " FORMAT_WORD_POINTER " by ", ARG_FORMAT_WORD(data64), addr64); oldvalue = data64 >> shift; oldvalue &= 0xff; data64 = (data64 & mask) | newvalue; pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "[" FORMAT_WORD_HEX "]\n", ARG_FORMAT_WORD(data64)); _ptrace(PTRACE_POKETEXT, child, (void* )addr64, (void* )data64); return (uint8_t) oldvalue; } void trace_read(pid_t child, word_uint fromaddr, uint8_t* buffer, size_t length) { word_uint data; word_uint curAddr; unsigned word_size = sizeof(word_uint); for (curAddr = 0; curAddr < length; curAddr += word_size) { data = _ptrace(PTRACE_PEEKTEXT, child, (void*)(curAddr+fromaddr), NULL); memcpy(buffer + curAddr, (void*) (&data), curAddr + word_size < length ? word_size : (length - curAddr)); } } void trace_copy(pid_t child, word_uint fromaddr, word_uint toaddr, size_t length) { word_uint data; word_uint curAddr; int extraBytes = length % sizeof(word_uint); pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "Copying buffer of %ld bytes from address " FORMAT_WORD_POINTER " to address " FORMAT_WORD_POINTER "\n", length, fromaddr, toaddr); for (curAddr = 0; curAddr < length - extraBytes; curAddr += sizeof(word_uint)) { data = _ptrace(PTRACE_PEEKTEXT, child, (void*)(curAddr+fromaddr), NULL); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "Copying word [" FORMAT_WORD_HEX "] from address " FORMAT_WORD_POINTER " to address " FORMAT_WORD_POINTER "\n", ARG_FORMAT_WORD(data), curAddr+fromaddr, curAddr+toaddr); _ptrace(PTRACE_POKETEXT, child, (void* )(curAddr + toaddr), (void* )data); } if (extraBytes > 0) { extraBytes <<= 3; // in bits word_uint mask = ((1L << (extraBytes)) - 1); data = _ptrace(PTRACE_PEEKTEXT, child, (void*)(curAddr+fromaddr), NULL); data &= mask; pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "Copying %d extra bytes (word [" FORMAT_WORD_HEX "] from address " FORMAT_WORD_POINTER " to address " FORMAT_WORD_POINTER ")\n", extraBytes >> 3, ARG_FORMAT_WORD(data), curAddr+fromaddr, curAddr+toaddr); word_uint destData = _ptrace(PTRACE_PEEKTEXT, child, (void*)(curAddr+toaddr), NULL); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "Replacing [" FORMAT_WORD_HEX "] by ", ARG_FORMAT_WORD(destData)); destData &= ~(mask); destData |= data; pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "[" FORMAT_WORD_HEX "]\n", ARG_FORMAT_WORD(destData)); _ptrace(PTRACE_POKETEXT, child, (void* )(curAddr + toaddr), (void* )destData); } } int trace_singlestep(pid_t child) { int status = 0; _ptrace(PTRACE_SINGLESTEP, child, NULL, NULL); waitpid(child, &status, 0); return status; } int trace_syscall(pid_t child) { int status = 0; _ptrace(PTRACE_SYSCALL, child, NULL, NULL); waitpid(child, &status, 0); return status; } int trace_continue(pid_t child) { int status = 0; _ptrace(PTRACE_CONT, child, NULL, NULL); waitpid(child, &status, 0); return status; } void trace_write(pid_t child, word_uint addr, uint8_t* buffer, size_t length) { word_uint data; word_uint curAddr; int extraBytes = length % sizeof(word_uint); pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "Inserting buffer of %ld bytes at address " FORMAT_WORD_POINTER "\n", length, addr); for (curAddr = 0; curAddr < length - extraBytes; curAddr += sizeof(word_uint)) { memcpy((void*) (&data), (void*) (buffer + curAddr), sizeof(word_uint)); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "Inserting word [" FORMAT_WORD_HEX "] at address " FORMAT_WORD_POINTER "\n", ARG_FORMAT_WORD(data), curAddr+addr); _ptrace(PTRACE_POKETEXT, child, (void* )(curAddr + addr), (void* )data); } if (extraBytes > 0) { data = 0; memcpy((void*) (&data), (void*) (buffer + curAddr), extraBytes); extraBytes <<= 3; // This is not needed, stupid endianness // data >>= (64 - extraBytes); word_uint mask = ((1L << (extraBytes)) - 1); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "Inserting %d extra bytes (word [" FORMAT_WORD_HEX "] at address " FORMAT_WORD_POINTER ")\n", extraBytes >> 3, ARG_FORMAT_WORD(data), curAddr+addr); data &= mask; word_uint destData = _ptrace(PTRACE_PEEKTEXT, child, (void*)(curAddr+addr), NULL); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "Replacing [" FORMAT_WORD_HEX "] by ", ARG_FORMAT_WORD(destData)); destData &= ~(mask); destData |= data; pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "[" FORMAT_WORD_HEX "]\n", ARG_FORMAT_WORD(destData)); _ptrace(PTRACE_POKETEXT, child, (void* )(curAddr + addr), (void* )destData); } } /* push a value on the stack. * return the value that is overwritten */ word_uint do_push(pid_t child __attribute__((unused)), word_uint *sp __attribute__((unused)), word_uint value __attribute__((unused))) { #if __arm__ // ARMv7 word_uint ret =-1; trace_read(child, *sp, (uint8_t *) &ret, sizeof(word_uint)); trace_write(child, *sp, (uint8_t *) &value, sizeof(word_uint)); *sp = *(uint8_t*)sp - sizeof(word_uint); return ret; #else /* TODO */ fprintf(stderr, "do_push not implemented on this architecture\n"); abort(); #endif } /* Undo a push: pop a value from the stack and replace it by the value that * has been overwritten by do_push * returns the popped value */ word_uint do_pop(pid_t child __attribute__((unused)), word_uint *sp __attribute__((unused)), word_uint prev_value __attribute__((unused))) { #if __arm__ // ARMv7 word_uint ret; *sp = *(uint8_t*)sp + sizeof(word_uint); trace_read(child, *sp, (uint8_t *) &ret, sizeof(word_uint)); trace_write(child, *sp, (uint8_t *) &prev_value, sizeof(word_uint)); return ret; #else /* TODO */ fprintf(stderr, "do_pop not implemented on this architecture\n"); abort(); #endif } /* return value of a function/syscall */ word_uint get_retval(REG_STRUCT regs) { #if __arm__ // ARMv7 return regs.REG_R0; #elif __x86_64__ // x86_64 return regs.REG_AX; #endif } /* print value stored in a register */ void print_reg_value(pid_t child, word_uint addr) { word_uint data = 0; data = _ptrace(PTRACE_PEEKTEXT, child, (void*)addr, NULL); printf("[" FORMAT_WORD_HEX "] from address " FORMAT_WORD_POINTER "\n", ARG_FORMAT_WORD(data), addr); } word_uint trace_mmap(pid_t child, word_uint addr, size_t length, int prot) { int i; // Save user registers REG_STRUCT regs; _ptrace(PTRACE_GETREGS, child, NULL, ®s); REG_STRUCT saved_regs; _ptrace(PTRACE_GETREGS, child, NULL, &saved_regs); #if __WORDSIZE == 64 if(ptrace_bits == 32) { #endif #if __arm__ // ARMv7 /* Linux syscall on 32-bits ARMv7 (svc #0 = 00 EF) number __NR_mmap (90) r7 = __NR_mmap r0 = arg1 => addr r1 = arg2 => length r2 = arg3 => prot r3 = arg4 => flags = MAP_ANONYMOUS | MAP_PRIVATE sp+12 = arg5 => fd = -1 sp+16 = arg6 => offset = 0 return r0 = return value = addr */ word_uint prev_val1 = -1; word_uint prev_val2 = -1; regs.REG_R7 = 192; // __NR_mmap2 32-bits regs.REG_R0 = addr; regs.REG_R1 = length; regs.REG_R2 = prot; regs.REG_R3 = MAP_ANONYMOUS | MAP_PRIVATE; // backup the values from sp prev_val1 = do_push(child, (word_uint *) &saved_regs.REG_SP, -1); prev_val2 = do_push(child, (word_uint *) &saved_regs.REG_SP, 0); #elif __x86_64__ // x86_64 /* Linux syscall on 32-bits (int 0x80 = CD 80) number __NR_mmap (90) eax = __NR_mmap ebx = arg1 => addr ecx = arg2 => length edx = arg3 => prot esi = arg4 => flags = MAP_ANONYMOUS | MAP_PRIVATE edi = arg5 => fd = -1 ebp = arg6 => offset = 0 return rax = return value = addr */ regs.REG_AX = 192; // __NR_mmap2 32-bits regs.REG_BX = addr; regs.REG_CX = length; regs.REG_DX = prot; regs.REG_SI = MAP_ANONYMOUS | MAP_PRIVATE; regs.REG_DI = -1; regs.REG_BP = 0; #endif #if __WORDSIZE == 64 } else { /* Linux syscall on 64-bits (syscall - 0f 05) number __NR_mmap (9) rax = __NR_mmap rdi = arg1 => addr rsi = arg2 => length rdx = arg3 => prot r10 = arg4 => flags = MAP_ANONYMOUS | MAP_PRIVATE | MAP_32BIT r8 = arg5 => fd = -1 r9 = arg6 => offset = 0 return rax = return value = addr */ regs.REG_AX = 9; // __NR_mmap 64-bits regs.REG_DI = addr; regs.REG_SI = length; regs.REG_DX = prot; regs.REG_R10 = MAP_ANONYMOUS | MAP_PRIVATE | MAP_32BIT; regs.REG_R8 = -1; regs.REG_R9 = 0; } #endif // Pushing new user registers _ptrace(PTRACE_SETREGS, child, NULL, ®s); #if __arm__ // ARMv7 // Inserting svc #0 (00 00 00 ef) uint8_t opcode[] = {0x00, 0x00, 0x00, 0xef}; int size = 4; #elif __x86_64__ // x86_64 // Inserting syscall (0f 05) / int 0x80 (cd 80) uint8_t opcode[] = {0x0f, 0x05, 0xcd, 0x80}; int off = ptrace_bits == 32 ? 2 : 0; int size = 2; #endif for (i = 0; i < size; i++) #if __arm__ // ARMv7 opcode[i] = trace_replace(child, saved_regs.REG_PC + i, opcode[i]); #elif __x86_64__ // x86_64 opcode[i + off] = trace_replace(child, saved_regs.REG_IP + i, opcode[i + off]); #endif // Two step execution with PTRACE_SYSCALL to return _ptrace(PTRACE_SYSCALL, child, NULL, NULL); waitpid(child, NULL, 0); // The syscall was called _ptrace(PTRACE_SYSCALL, child, NULL, NULL); waitpid(child, NULL, 0); // The syscall has returned // Getting back the result from the syscall _ptrace(PTRACE_GETREGS, child, NULL, ®s); // Inserting back the original opcode for (i = 0; i < size; i++) #if __arm__ // ARMv7 opcode[i] = trace_replace(child, saved_regs.REG_PC + i, opcode[i]); #elif __x86_64__ // x86_64 opcode[i + off] = trace_replace(child, saved_regs.REG_IP + i, opcode[i + off]); #endif #if __arm__ /* restore the values that were overwritten by do_push */ do_pop(child, (word_uint *) &saved_regs.REG_SP, prev_val2); do_pop(child, (word_uint *) &saved_regs.REG_SP, prev_val1); #endif // Restoring registers _ptrace(PTRACE_SETREGS, child, NULL, &saved_regs); // Returning the result of the syscall return get_retval(regs); } char *trace_get_zstring(pid_t child, word_uint addr) { unsigned int size = 1024; unsigned int index = 0; if (addr == 0) return NULL; uint8_t *buf = (uint8_t*) malloc(size); do { if (index >= size) { size += 1024; buf = (uint8_t*) realloc(buf, size); } trace_read(child, addr + index, buf + index, 1); index++; } while (buf[index - 1]); return (char*) buf; } int syscall_match_arg(pid_t child, int type, va_list* args, word_uint reg) { word_uint value; char *ptr; char **ptr2; char *buf; int r; switch (type) { case SYSCALL_ARGTYPE_INT: value = va_arg(*args, word_uint); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, " %ld == %ld?", reg, value); return (value == reg) ? 1 : 0; case SYSCALL_ARGTYPE_ZSTRING: ptr = va_arg(*args, char*); if (ptr == NULL) { pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, " NULL == %p?", (void*) reg); return reg == 0 ? 1 : 0; } buf = trace_get_zstring(child, reg); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, " \"%s\" (%p) == \"%s\"?", buf, (void*) reg, ptr); r = strcmp(ptr, buf); free(buf); return r == 0 ? 1 : 0; case SYSCALL_ARGTYPE_ZSTRING_RETURN: buf = trace_get_zstring(child, reg); ptr2 = va_arg(*args, char**); if (ptr2 == NULL) { *ptr2 = NULL; pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, " got NULL for getting zstring..."); } else { *ptr2 = trace_get_zstring(child, reg); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, " returning string %s...", *ptr2); } return 1; case SYSCALL_ARGTYPE_IGNORE: default: pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, " Ignoring %lx!", reg); return 1; } } int syscall_match_args(pid_t child, int syscall, va_list* args, REG_STRUCT regs) { int type; #define _sma_TEST_ARG(child, type, args, arg) \ do { \ type = va_arg(*args, int); \ if(type == SYSCALL_ARGTYPE_END) \ return 1; \ if(syscall_match_arg(child, type, args, arg) == 0) \ return 0; \ } while(0) // 64bits args: rdi,rsi,rdx,r10,r8,r9 // 32bits args: rbx,rcx,rdx,rsi,rdi,rbp // armv7 args: r0, r1, r2, r3, sp+12, sp+16 if (ptrace_bits == 32) { #if __arm__ // ARMv7 uint32_t buf[2]; trace_read(child, regs.REG_SP+(3*sizeof(uint32_t)), (uint8_t*) buf, 2*4); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "\tFound old_mmap call and reading memory from sp:\n"); pptrace_dump_buffer(PPTRACE_DEBUG_LEVEL_ALL, (uint8_t*) buf, 2*4); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "\nArgument check: "); _sma_TEST_ARG(child, type, args, regs.REG_R0); _sma_TEST_ARG(child, type, args, regs.REG_R1); _sma_TEST_ARG(child, type, args, regs.REG_R2); _sma_TEST_ARG(child, type, args, regs.REG_R3); _sma_TEST_ARG(child, type, args, buf[0]); _sma_TEST_ARG(child, type, args, buf[1]); #elif __x86_64__ // x86_64 if (syscall == TRACE_SYSCALL(mmap)) { uint32_t buf[6]; trace_read(child, regs.REG_BX, (uint8_t*) buf, 24); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "\tFound old_mmap call and reading memory from ebx:\n"); pptrace_dump_buffer(PPTRACE_DEBUG_LEVEL_ALL, (char*) buf, 24); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "\nArgument check: "); _sma_TEST_ARG(child, type, args, buf[0]); _sma_TEST_ARG(child, type, args, buf[1]); _sma_TEST_ARG(child, type, args, buf[2]); _sma_TEST_ARG(child, type, args, buf[3]); _sma_TEST_ARG(child, type, args, buf[4]); _sma_TEST_ARG(child, type, args, buf[5]); } else { _sma_TEST_ARG(child, type, args, regs.REG_BX); _sma_TEST_ARG(child, type, args, regs.REG_CX); _sma_TEST_ARG(child, type, args, regs.REG_DX); _sma_TEST_ARG(child, type, args, regs.REG_SI); _sma_TEST_ARG(child, type, args, regs.REG_DI); _sma_TEST_ARG(child, type, args, regs.REG_BP); } } else { _sma_TEST_ARG(child, type, args, regs.REG_DI); _sma_TEST_ARG(child, type, args, regs.REG_SI); _sma_TEST_ARG(child, type, args, regs.REG_DX); _sma_TEST_ARG(child, type, args, regs.REG_R10); _sma_TEST_ARG(child, type, args, regs.REG_R8); _sma_TEST_ARG(child, type, args, regs.REG_R9); #endif } return 1; } #if __WORDSIZE == 32 #define SYSCALLS_FORMAT "%u,%u" #define SYSCALLS_PRINT_ARGS(syscalls) (syscalls & 0xffff), ((syscalls >> 16) & 0xffff) #define TEST_SYSCALL(syscalls, syscall) (((syscall != 0) || (syscall == syscalls)) && (((syscalls & 0xffff) == syscall) || (((syscalls >> 16) & 0xffff) == syscall))) #else #define SYSCALLS_FORMAT "%u,%u,%u,%u" #define SYSCALLS_PRINT_ARGS(syscalls) (syscalls & 0xffff), ((syscalls >> 16) & 0xffff), ((syscalls >> 32) & 0xffff), ((syscalls >> 48) & 0xffff) #define TEST_SYSCALL(syscalls, syscall) (((syscall != 0) || (syscall == syscalls)) && (((syscalls & 0xffff) == syscall) || (((syscalls >> 16) & 0xffff) == syscall) || (((syscalls >> 32) & 0xffff) == syscall) || (((syscalls >> 48) & 0xffff) == syscall))) #endif int trace_wait_syscall(pid_t child, word_uint* retval, unsigned long syscall, ...) { // Wait for syscall and return the return value of the first encountered int status; REG_STRUCT regs; unsigned int in_syscall = 0; int in_execve = 0; va_list args; pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "Looking for syscalls "SYSCALLS_FORMAT"\n", SYSCALLS_PRINT_ARGS(syscall)); for (status = trace_syscall(child); !WIFEXITED(status) && !WIFSIGNALED(status); status = trace_syscall(child)) { if (WIFSTOPPED(status)) { int signal = WSTOPSIG(status); if (signal == SIGTRAP) { _ptrace(PTRACE_GETREGS, child, NULL, ®s); if (!in_syscall) { #if __arm__ // ARMv7 in_syscall = regs.REG_R7; #elif __x86_64__ // x86_64 in_syscall = regs.REG_ORIG_AX; #endif pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "Entering syscall %d\n", in_syscall); if (in_syscall == TRACE_SYSCALL(execve)) in_execve = 1; // execve generate 3 sigtraps: one at call, one at program loading and one at syscall return if (TEST_SYSCALL(syscall, in_syscall)) { pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "Found syscall entry %d with registers "REG_FORMAT"\n", in_syscall, REG_FORMAT_VALUES(regs)); // We are in the good syscall but have we the good arguments? va_start(args, syscall); pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "Checking arguments: "); if (!syscall_match_args(child, in_syscall, &args, regs)) { in_syscall = -in_syscall; // Arguments doesn't match pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, " failed!\n"); } else { pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, " ok\n"); } va_end(args); } } else if (in_execve) { pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "execve has stopped after loading the new program\n"); in_execve = 0; } else { // Exiting a syscall pptrace_debug(PPTRACE_DEBUG_LEVEL_ALL, "Exiting syscall %d\n", in_syscall); if (TEST_SYSCALL(syscall, in_syscall)) { pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "Found syscall %d with registers "REG_FORMAT"\n", in_syscall, REG_FORMAT_VALUES(regs)); if (retval != NULL) *retval = get_retval(regs); return 0; } in_syscall = 0; } } else if (signal == SIGSEGV || signal == SIGKILL || signal == SIGILL) { // Signal that terminates the process pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "Syscalls "SYSCALLS_FORMAT" not found\n", SYSCALLS_PRINT_ARGS(syscall)); return -1; } else pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "Stopped with unknown signal %d\n", signal); } else pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "Waitpid returned with the process unstopped\n"); } pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "Syscalls "SYSCALLS_FORMAT" not found\n", SYSCALLS_PRINT_ARGS(syscall)); return -1; } void trace_detach(pid_t child) { _ptrace(PTRACE_DETACH, child, NULL, NULL); } void trace_wait(pid_t child) { int status = 0; do { waitpid(child, &status, 0); } while (!WIFEXITED(status) && !WIFSIGNALED(status)); } eztrace-1.1-2/src/pptrace/os/linux/linux.h000066400000000000000000000257421265506773700205200ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include #include "types.h" // Copy/pasted from asm/unistd_32.h #define __NR32_restart_syscall 0 #define __NR32_exit 1 #define __NR32_fork 2 #define __NR32_read 3 #define __NR32_write 4 #define __NR32_open 5 #define __NR32_close 6 #define __NR32_waitpid 7 #define __NR32_creat 8 #define __NR32_link 9 #define __NR32_unlink 10 #define __NR32_execve 11 #define __NR32_chdir 12 #define __NR32_time 13 #define __NR32_mknod 14 #define __NR32_chmod 15 #define __NR32_lchown 16 #define __NR32_break 17 #define __NR32_oldstat 18 #define __NR32_lseek 19 #define __NR32_getpid 20 #define __NR32_mount 21 #define __NR32_umount 22 #define __NR32_setuid 23 #define __NR32_getuid 24 #define __NR32_stime 25 #define __NR32_ptrace 26 #define __NR32_alarm 27 #define __NR32_oldfstat 28 #define __NR32_pause 29 #define __NR32_utime 30 #define __NR32_stty 31 #define __NR32_gtty 32 #define __NR32_access 33 #define __NR32_nice 34 #define __NR32_ftime 35 #define __NR32_sync 36 #define __NR32_kill 37 #define __NR32_rename 38 #define __NR32_mkdir 39 #define __NR32_rmdir 40 #define __NR32_dup 41 #define __NR32_pipe 42 #define __NR32_times 43 #define __NR32_prof 44 #define __NR32_brk 45 #define __NR32_setgid 46 #define __NR32_getgid 47 #define __NR32_signal 48 #define __NR32_geteuid 49 #define __NR32_getegid 50 #define __NR32_acct 51 #define __NR32_umount2 52 #define __NR32_lock 53 #define __NR32_ioctl 54 #define __NR32_fcntl 55 #define __NR32_mpx 56 #define __NR32_setpgid 57 #define __NR32_ulimit 58 #define __NR32_oldolduname 59 #define __NR32_umask 60 #define __NR32_chroot 61 #define __NR32_ustat 62 #define __NR32_dup2 63 #define __NR32_getppid 64 #define __NR32_getpgrp 65 #define __NR32_setsid 66 #define __NR32_sigaction 67 #define __NR32_sgetmask 68 #define __NR32_ssetmask 69 #define __NR32_setreuid 70 #define __NR32_setregid 71 #define __NR32_sigsuspend 72 #define __NR32_sigpending 73 #define __NR32_sethostname 74 #define __NR32_setrlimit 75 #define __NR32_getrlimit 76 /* Back compatible 2Gig limited rlimit */ #define __NR32_getrusage 77 #define __NR32_gettimeofday 78 #define __NR32_settimeofday 79 #define __NR32_getgroups 80 #define __NR32_setgroups 81 #define __NR32_select 82 #define __NR32_symlink 83 #define __NR32_oldlstat 84 #define __NR32_readlink 85 #define __NR32_uselib 86 #define __NR32_swapon 87 #define __NR32_reboot 88 #define __NR32_readdir 89 #define __NR32_mmap 90 #define __NR32_munmap 91 #define __NR32_truncate 92 #define __NR32_ftruncate 93 #define __NR32_fchmod 94 #define __NR32_fchown 95 #define __NR32_getpriority 96 #define __NR32_setpriority 97 #define __NR32_profil 98 #define __NR32_statfs 99 #define __NR32_fstatfs 100 #define __NR32_ioperm 101 #define __NR32_socketcall 102 #define __NR32_syslog 103 #define __NR32_setitimer 104 #define __NR32_getitimer 105 #define __NR32_stat 106 #define __NR32_lstat 107 #define __NR32_fstat 108 #define __NR32_olduname 109 #define __NR32_iopl 110 #define __NR32_vhangup 111 #define __NR32_idle 112 #define __NR32_vm86old 113 #define __NR32_wait4 114 #define __NR32_swapoff 115 #define __NR32_sysinfo 116 #define __NR32_ipc 117 #define __NR32_fsync 118 #define __NR32_sigreturn 119 #define __NR32_clone 120 #define __NR32_setdomainname 121 #define __NR32_uname 122 #define __NR32_modify_ldt 123 #define __NR32_adjtimex 124 #define __NR32_mprotect 125 #define __NR32_sigprocmask 126 #define __NR32_create_module 127 #define __NR32_init_module 128 #define __NR32_delete_module 129 #define __NR32_get_kernel_syms 130 #define __NR32_quotactl 131 #define __NR32_getpgid 132 #define __NR32_fchdir 133 #define __NR32_bdflush 134 #define __NR32_sysfs 135 #define __NR32_personality 136 #define __NR32_afs_syscall 137 /* Syscall for Andrew File System */ #define __NR32_setfsuid 138 #define __NR32_setfsgid 139 #define __NR32__llseek 140 #define __NR32_getdents 141 #define __NR32__newselect 142 #define __NR32_flock 143 #define __NR32_msync 144 #define __NR32_readv 145 #define __NR32_writev 146 #define __NR32_getsid 147 #define __NR32_fdatasync 148 #define __NR32__sysctl 149 #define __NR32_mlock 150 #define __NR32_munlock 151 #define __NR32_mlockall 152 #define __NR32_munlockall 153 #define __NR32_sched_setparam 154 #define __NR32_sched_getparam 155 #define __NR32_sched_setscheduler 156 #define __NR32_sched_getscheduler 157 #define __NR32_sched_yield 158 #define __NR32_sched_get_priority_max 159 #define __NR32_sched_get_priority_min 160 #define __NR32_sched_rr_get_interval 161 #define __NR32_nanosleep 162 #define __NR32_mremap 163 #define __NR32_setresuid 164 #define __NR32_getresuid 165 #define __NR32_vm86 166 #define __NR32_query_module 167 #define __NR32_poll 168 #define __NR32_nfsservctl 169 #define __NR32_setresgid 170 #define __NR32_getresgid 171 #define __NR32_prctl 172 #define __NR32_rt_sigreturn 173 #define __NR32_rt_sigaction 174 #define __NR32_rt_sigprocmask 175 #define __NR32_rt_sigpending 176 #define __NR32_rt_sigtimedwait 177 #define __NR32_rt_sigqueueinfo 178 #define __NR32_rt_sigsuspend 179 #define __NR32_pread64 180 #define __NR32_pwrite64 181 #define __NR32_chown 182 #define __NR32_getcwd 183 #define __NR32_capget 184 #define __NR32_capset 185 #define __NR32_sigaltstack 186 #define __NR32_sendfile 187 #define __NR32_getpmsg 188 /* some people actually want streams */ #define __NR32_putpmsg 189 /* some people actually want streams */ #define __NR32_vfork 190 #define __NR32_ugetrlimit 191 /* SuS compliant getrlimit */ #define __NR32_mmap2 192 #define __NR32_truncate64 193 #define __NR32_ftruncate64 194 #define __NR32_stat64 195 #define __NR32_lstat64 196 #define __NR32_fstat64 197 #define __NR32_lchown32 198 #define __NR32_getuid32 199 #define __NR32_getgid32 200 #define __NR32_geteuid32 201 #define __NR32_getegid32 202 #define __NR32_setreuid32 203 #define __NR32_setregid32 204 #define __NR32_getgroups32 205 #define __NR32_setgroups32 206 #define __NR32_fchown32 207 #define __NR32_setresuid32 208 #define __NR32_getresuid32 209 #define __NR32_setresgid32 210 #define __NR32_getresgid32 211 #define __NR32_chown32 212 #define __NR32_setuid32 213 #define __NR32_setgid32 214 #define __NR32_setfsuid32 215 #define __NR32_setfsgid32 216 #define __NR32_pivot_root 217 #define __NR32_mincore 218 #define __NR32_madvise 219 #define __NR32_madvise1 219 /* delete when C lib stub is removed */ #define __NR32_getdents64 220 #define __NR32_fcntl64 221 /* 223 is unused */ #define __NR32_gettid 224 #define __NR32_readahead 225 #define __NR32_setxattr 226 #define __NR32_lsetxattr 227 #define __NR32_fsetxattr 228 #define __NR32_getxattr 229 #define __NR32_lgetxattr 230 #define __NR32_fgetxattr 231 #define __NR32_listxattr 232 #define __NR32_llistxattr 233 #define __NR32_flistxattr 234 #define __NR32_removexattr 235 #define __NR32_lremovexattr 236 #define __NR32_fremovexattr 237 #define __NR32_tkill 238 #define __NR32_sendfile64 239 #define __NR32_futex 240 #define __NR32_sched_setaffinity 241 #define __NR32_sched_getaffinity 242 #define __NR32_set_thread_area 243 #define __NR32_get_thread_area 244 #define __NR32_io_setup 245 #define __NR32_io_destroy 246 #define __NR32_io_getevents 247 #define __NR32_io_submit 248 #define __NR32_io_cancel 249 #define __NR32_fadvise64 250 /* 251 is available for reuse (was briefly sys_set_zone_reclaim) */ #define __NR32_exit_group 252 #define __NR32_lookup_dcookie 253 #define __NR32_epoll_create 254 #define __NR32_epoll_ctl 255 #define __NR32_epoll_wait 256 #define __NR32_remap_file_pages 257 #define __NR32_set_tid_address 258 #define __NR32_timer_create 259 #define __NR32_timer_settime (__NR32_timer_create+1) #define __NR32_timer_gettime (__NR32_timer_create+2) #define __NR32_timer_getoverrun (__NR32_timer_create+3) #define __NR32_timer_delete (__NR32_timer_create+4) #define __NR32_clock_settime (__NR32_timer_create+5) #define __NR32_clock_gettime (__NR32_timer_create+6) #define __NR32_clock_getres (__NR32_timer_create+7) #define __NR32_clock_nanosleep (__NR32_timer_create+8) #define __NR32_statfs64 268 #define __NR32_fstatfs64 269 #define __NR32_tgkill 270 #define __NR32_utimes 271 #define __NR32_fadvise64_64 272 #define __NR32_vserver 273 #define __NR32_mbind 274 #define __NR32_get_mempolicy 275 #define __NR32_set_mempolicy 276 #define __NR32_mq_open 277 #define __NR32_mq_unlink (__NR32_mq_open+1) #define __NR32_mq_timedsend (__NR32_mq_open+2) #define __NR32_mq_timedreceive (__NR32_mq_open+3) #define __NR32_mq_notify (__NR32_mq_open+4) #define __NR32_mq_getsetattr (__NR32_mq_open+5) #define __NR32_kexec_load 283 #define __NR32_waitid 284 /* #define __NR32_sys_setaltroot 285 */ #define __NR32_add_key 286 #define __NR32_request_key 287 #define __NR32_keyctl 288 #define __NR32_ioprio_set 289 #define __NR32_ioprio_get 290 #define __NR32_inotify_init 291 #define __NR32_inotify_add_watch 292 #define __NR32_inotify_rm_watch 293 #define __NR32_migrate_pages 294 #define __NR32_openat 295 #define __NR32_mkdirat 296 #define __NR32_mknodat 297 #define __NR32_fchownat 298 #define __NR32_futimesat 299 #define __NR32_fstatat64 300 #define __NR32_unlinkat 301 #define __NR32_renameat 302 #define __NR32_linkat 303 #define __NR32_symlinkat 304 #define __NR32_readlinkat 305 #define __NR32_fchmodat 306 #define __NR32_faccessat 307 #define __NR32_pselect6 308 #define __NR32_ppoll 309 #define __NR32_unshare 310 #define __NR32_set_robust_list 311 #define __NR32_get_robust_list 312 #define __NR32_splice 313 #define __NR32_sync_file_range 314 #define __NR32_tee 315 #define __NR32_vmsplice 316 #define __NR32_move_pages 317 #define __NR32_getcpu 318 #define __NR32_epoll_pwait 319 #define __NR32_utimensat 320 #define __NR32_signalfd 321 #define __NR32_timerfd_create 322 #define __NR32_eventfd 323 #define __NR32_fallocate 324 #define __NR32_timerfd_settime 325 #define __NR32_timerfd_gettime 326 #define __NR32_signalfd4 327 #define __NR32_eventfd2 328 #define __NR32_epoll_create1 329 #define __NR32_dup3 330 #define __NR32_pipe2 331 #define __NR32_inotify_init1 332 #define __NR32_preadv 333 #define __NR32_pwritev 334 #define __NR32_rt_tgsigqueueinfo 335 #define __NR32_perf_event_open 336 int trace_get_bits(); #ifdef __x86_64__ // x86_64 #define TRACE_SYSCALL(name) (trace_get_bits() == 32 ? __NR32_##name : __NR_##name) #define REG_STRUCT struct user_regs_struct #define MMAP_SYSCALLS (trace_get_bits() == 32 ? ((__NR32_mmap << 16) | (__NR32_mmap2)) : __NR_mmap) #elif __arm__ // ARMv7 #define TRACE_SYSCALL(name) (__NR_##name) #define REG_STRUCT struct user_regs #define MMAP_SYSCALLS ((__NR32_mmap << 16) | (__NR32_mmap2)) #endif #define TRACE_SYSCALLS(name1, name2) ((TRACE_SYSCALL(name1) << 16) & TRACE_SYSCALL(name2)) eztrace-1.1-2/src/pptrace/pptrace.c000066400000000000000000000502501265506773700172220ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * pptrace.c * * Public interface of the library * * Created on: 2 Aug. 2011 * Author: Damien Martin-Guillerez */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "eztrace_config.h" // To store informations about hijack to install typedef struct __pptrace_internal_hijack { char* function; // Function to hijack char* orig_symbol; // Name of the symbol to store the intercepted address char* replace_symbol; // Name of the interceptor symbol zzt_symbol* funSym; // Symbol of the function zzt_symbol* origSym; // Symbol to store the intercepted address zzt_symbol* replSym; // Interceptor symbol } pptrace_internal_hijack; // To store informations about libraries to load typedef struct __pptrace_internal_library { char* library; // The library name pptrace_internal_hijack** hijacks; // The hijacks to install zzt_word baseaddr; // Double-linked list struct __pptrace_internal_library* next; struct __pptrace_internal_library* prev; } pptrace_internal_library; // And finally the binary structure typedef struct __pptrace_internal_binary { char *name; // Name of the binary void *binary; // Binary structure char **debugger; // Argument list to debugger an argument matching "{name}" will be replaced by the binary name and arguments matching "{pid}" will be replaced by the program pid // List of libraries pptrace_internal_library* first; pptrace_internal_library* last; } pptrace_internal_binary; #define ALLOC(type) (type*)malloc(sizeof(type)); // Look out for a binary in the path char* get_program_path(char *name) { struct stat buf; if (stat(name, &buf) == 0) { // The address is relative return strdup(name); } // Looking in the path char *path = getenv("PATH"); if (path == NULL) return NULL; path = strdup(path); // copying to avoid corrupting the environment variable if (path == NULL) return NULL; char *ifs = getenv("IFS"); if (ifs == NULL) ifs = ":"; // for each path char *p; char rpath[1024]; for (p = strtok(path, ifs); p != NULL; p = strtok(NULL, ifs)) { // Add the path component if (p[strlen(p) - 1] != '/') snprintf(rpath, 1024, "%s/%s", p, name); else snprintf(rpath, 1024, "%s%s", p, name); // Test if it exists if (stat(rpath, &buf) == 0) { free(path); return strdup(rpath); } } free(path); return NULL; } void* pptrace_prepare_binary(char *binary) { pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Loading binary %s... ", binary); pptrace_clear_error(); pptrace_internal_binary* bin = ALLOC(pptrace_internal_binary) ; if (!bin) { pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "failed!\n"); pptrace_error("Allocation failed"); return NULL; } bin->debugger = NULL; bin->first = bin->last = NULL; bin->name = get_program_path(binary); if (!(bin->name)) { pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "failed!\n"); free(bin); pptrace_error("Allocation failed"); return NULL; } bin->binary = open_binary(bin->name); if (!(bin->binary)) { pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "failed!\n"); pptrace_error("Cannot open binary %s", binary); free(bin->name); free(bin); return NULL; } pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "ok\n"); return (void*) bin; } void pptrace_add_debugger(void *bin, char **argv) { pptrace_internal_binary* ibin = bin; ibin->debugger = argv; if (argv == NULL) pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Installing debugger %s\n"); else pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Uninstalling debugger\n", argv[0]); } void pptrace_free_hijack(pptrace_internal_hijack* hijack) { if (!hijack) return; if (hijack->origSym) free_symbol(hijack->origSym); if (hijack->replSym) free_symbol(hijack->replSym); if (hijack->funSym) free_symbol(hijack->funSym); if (hijack->orig_symbol) free(hijack->orig_symbol); if (hijack->replace_symbol) free(hijack->replace_symbol); if (hijack->function) free(hijack->function); free(hijack); } pptrace_internal_hijack* pptrace_get_hijack(pptrace_internal_binary *bin, char *library, void *lib, char *params) { char *params_copy; char *function; char *interceptee; char *interceptor; // Parsing of the result of __pptrace_hijack_list params_copy = strdup(params); function = strtok(params_copy, " "); interceptee = strtok(NULL, " "); interceptor = strtok(NULL, " "); if (function == NULL || interceptee == NULL || interceptor == NULL) { pptrace_error("Wrong order to intercept: %s\n", params); free(params_copy); return NULL; } pptrace_internal_hijack *hijack = ALLOC(pptrace_internal_hijack) ; pptrace_debug(PPTRACE_DEBUG_LEVEL_VERBOSE, "Got order to intercept %s with %s using %s\n", function, interceptor, interceptee); if (!hijack) { pptrace_error("Allocation failed"); free(params_copy); return NULL; } hijack->orig_symbol = hijack->replace_symbol = hijack->function = NULL; hijack->origSym = hijack->replSym = hijack->funSym = NULL; hijack->orig_symbol = strdup(interceptee); if (!hijack->orig_symbol) { pptrace_free_hijack(hijack); pptrace_error("Allocation failed"); free(params_copy); return NULL; } hijack->replace_symbol = strdup(interceptor); if (!hijack->replace_symbol) { pptrace_free_hijack(hijack); pptrace_error("Allocation failed"); free(params_copy); return NULL; } hijack->function = strdup(function); if (!hijack->function) { pptrace_free_hijack(hijack); pptrace_error("Allocation failed"); free(params_copy); return NULL; } free(params_copy); hijack->funSym = get_symbol(bin->binary, hijack->function); if (!hijack->funSym) { pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Failed to find symbol %s in binary %s, ignoring!\n", hijack->function, library); pptrace_free_hijack(hijack); return NULL; } hijack->origSym = get_symbol(lib, hijack->orig_symbol); if (!hijack->origSym) { pptrace_error("Failed to find symbol %s in binary %s", hijack->orig_symbol, library); pptrace_free_hijack(hijack); return NULL; } hijack->replSym = get_symbol(lib, hijack->replace_symbol); if (!hijack->replSym) { pptrace_error("Failed to find symbol %s in binary %s", hijack->replace_symbol, library); pptrace_free_hijack(hijack); return NULL; } return hijack; } void pptrace_free_hijacks(pptrace_internal_hijack** hijacks) { int i; if (!hijacks) return; for (i = 0; hijacks[i] != NULL; i++) pptrace_free_hijack(hijacks[i]); free(hijacks); } pptrace_internal_hijack** pptrace_get_hijacks(pptrace_internal_binary *bin, char *library, void *lib, char **params) { int s, i, j; for (s = 0; params[s] != NULL; s++) ; pptrace_internal_hijack** hijacks = (pptrace_internal_hijack**) malloc( sizeof(pptrace_internal_hijack*) * (s + 1)); if (!hijacks) { pptrace_error("Allocation failed"); return NULL; } for (i = 0; i < s + 1; i++) hijacks[i] = NULL; for (i = j = 0; j < s; i++, j++) { hijacks[i] = pptrace_get_hijack(bin, library, lib, params[j]); if (!hijacks[i]) i--; // ignoring this line } return hijacks; } void __pptrace_get_module_name(const char* libname, char *module_name, size_t buffer_size) { #define LIBEZTRACE_PREFIX "libeztrace-autostart-" memset(module_name, '\0', buffer_size); /* search for "libeztrace-autostart-" */ char* res = strstr(libname, LIBEZTRACE_PREFIX); if(res) { /* found it */ res = &res[strlen(LIBEZTRACE_PREFIX)]; /* now search for the suffix (".so" / ".dynlib") */ char* suffix = strstr(res, DYNLIB_SUFFIX); if(suffix) { /* found it */ assert(suffix-res < buffer_size); strncpy(module_name, res, suffix-res); } } } pptrace_internal_hijack** pptrace_load_hijacks(pptrace_internal_binary *bin, char *library, void *lib) { void *bin_bin = open_binary(library); char module_name[1024]; __pptrace_get_module_name(library, module_name, 1024); char hijack_symbol[1024]; __get_pptrace_symbol_external(hijack_symbol, 1024, module_name); char** params = read_zstring_array(bin_bin, hijack_symbol); if (!params) { __get_pptrace_symbol_external(hijack_symbol, 1024, ""); params = read_zstring_array(bin_bin, hijack_symbol); if(!params) { pptrace_error("%s library does not contain symbol %s, probably wrong library format", library, hijack_symbol); close_binary(bin_bin); return NULL; } } close_binary(bin_bin); pptrace_internal_hijack **result = pptrace_get_hijacks(bin, library, lib, params); free_zstring_array(params); return result; } void pptrace_free_library(pptrace_internal_library *lib) { if (!lib) return; if (lib->library) { free(lib->library); } if (lib->hijacks) { pptrace_free_hijacks(lib->hijacks); } free(lib); } void pptrace_insert_library(pptrace_internal_binary* binary, pptrace_internal_library* lib) { lib->next = NULL; lib->prev = binary->last; if (binary->last) { binary->last->next = lib; binary->last = lib; } else { binary->first = binary->last = lib; } } void pptrace_remove_last_library(pptrace_internal_binary* binary) { if (binary->last) { pptrace_internal_library* lib = binary->last; binary->last = lib->prev; if (lib->prev) { lib->prev->next = NULL; } if (binary->first == lib) binary->first = NULL; } } int pptrace_load_module(void *bin, char *library) { int r = pptrace_add_preload(bin, library); if (r < 0) return r; pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Fetching hijacks of library %s\n", library); pptrace_internal_binary* binary = (pptrace_internal_binary*) bin; pptrace_internal_library* lib = binary->last; void *libr = open_binary(library); if (!binary) { pptrace_remove_last_library(binary); pptrace_free_library(lib); pptrace_error("Failed to open library %s", library); return -1; } lib->hijacks = pptrace_load_hijacks(binary, library, libr); if (!lib->hijacks) { pptrace_remove_last_library(binary); pptrace_free_library(lib); return -1; } close_binary(libr); lib->baseaddr = 0; pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Hijacks of library %s fetched\n", library); return 0; } int pptrace_add_preload(void *bin, char *library) { pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Loading library %s... ", library); pptrace_clear_error(); if (!bin || !library) { pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "failed!\n"); pptrace_error("Invalid argument"); return -1; } pptrace_internal_binary* binary = (pptrace_internal_binary*) bin; pptrace_internal_library* lib = ALLOC(pptrace_internal_library) ; if (!lib) { pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "failed!\n"); pptrace_error("Allocation failed"); return -1; } lib->library = strdup(library); lib->baseaddr = -1; if (!(lib->library)) { free(lib); pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "failed!\n"); pptrace_error("Allocation failed"); return -1; } lib->hijacks = NULL; pptrace_insert_library(binary, lib); pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "ok\n"); return 0; } char* pptrace_create_preload(pptrace_internal_library *first) { const char* ldpreload = "LD_PRELOAD="; char *result = (char*) malloc(1024); unsigned int size = 1024; unsigned int nsize = strlen(ldpreload); strcpy(result, ldpreload); while (first != NULL) { while (size - nsize < strlen(first->library) + 2) { size += 1024; result = (char*) realloc(result, size); } strcpy(result + nsize, first->library); nsize += strlen(first->library); strcpy(result + nsize, ":"); nsize++; first = first->next; } char *envpreload = getenv("LD_PRELOAD"); if (envpreload != NULL) { while (size - nsize < strlen(envpreload) + 1) { size += 1024; result = (char*) realloc(result, size); } strcpy(result + nsize, envpreload); } else if (nsize > 0) { nsize--; // remove the trailing ':' result[nsize] = 0; } return result; } pid_t pptrace_launch_preload(char *path, char **argv, char **envp, pptrace_internal_library *first, int debug) { // Adding LD_PRELOAD=libraries in envp int i, size = 0; while (envp[size] != NULL) size++; char **envp2 = (char**) malloc(sizeof(char*) * (size + 2)); for (i = 0; i < size; i++) envp2[i] = envp[i]; envp2[size] = pptrace_create_preload(first); envp2[size + 1] = NULL; pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "\nLD_PRELOAD is %s\n", envp2[size]); pid_t child = trace_run(path, argv, envp2, debug); free(envp2[size]); free(envp2); return child; } void pptrace_free_binary(pptrace_internal_binary* binary) { pptrace_internal_library *lib; if (!binary) return; if (binary->binary) { close_binary(binary->binary); } while (binary->first) { lib = binary->first; binary->first = lib->next; pptrace_free_library(lib); } binary->last = NULL; if (binary->name) { free(binary->name); } free(binary); } int pptrace_count_unmatched_libraries(pptrace_internal_binary* binary, int max) { int count = 0; pptrace_internal_library *result = binary->first; while (result != NULL && count < max) { if (result->baseaddr == 0) count++; result = result->next; } return count; } pptrace_internal_library* pptrace_search_library( pptrace_internal_binary* binary, char *libname) { pptrace_internal_library *result = binary->first; int libnamelen = strlen(libname); while (result != NULL) { int len = libnamelen - strlen(result->library); pptrace_debug(PPTRACE_DEBUG_LEVEL_DEBUG, "Comparing %s and %s\n", result->library, libname + len); if (len >= 0 && strcmp(result->library, libname + len) == 0) // the searched library ends with the short name of the lib return result; result = result->next; } return NULL; } void pptrace_apply_library_baseaddr(pptrace_internal_library *lib, zzt_word baseaddr) { int i; lib->baseaddr = baseaddr; if (lib->hijacks) { for (i = 0; lib->hijacks[i]; i++) { lib->hijacks[i]->origSym->section_addr += baseaddr; lib->hijacks[i]->replSym->section_addr += baseaddr; } } } int pptrace_wait_library(pid_t child, pptrace_internal_binary* binary) { char *library; // Wait for dlopen(argv[1]) pptrace_debug(PPTRACE_DEBUG_LEVEL_VERBOSE, "Waiting for open(*, O_RDONLY) (syscall %d)... ", TRACE_SYSCALL(open)); word_uint fd; int r = trace_wait_syscall(child, &fd, TRACE_SYSCALL(open), SYSCALL_ARGTYPE_ZSTRING_RETURN, &library, SYSCALL_ARGTYPE_IGNORE, SYSCALL_ARGTYPE_END); if (r < 0 || library == NULL) { pptrace_debug(PPTRACE_DEBUG_LEVEL_VERBOSE, "failed!\n"); return -1; } pptrace_debug(PPTRACE_DEBUG_LEVEL_VERBOSE, "ok (fd = %d, library = %s)\n", fd, library); if ((int) fd < 0) { pptrace_debug(PPTRACE_DEBUG_LEVEL_VERBOSE, "open() failed ==> ignoring\n"); return 0; } pptrace_internal_library* lib = pptrace_search_library(binary, library); free(library); if (!lib || lib->baseaddr) { pptrace_debug(PPTRACE_DEBUG_LEVEL_VERBOSE, "Not an awaited library, ignoring\n"); return 0; } pptrace_debug( PPTRACE_DEBUG_LEVEL_VERBOSE, "Waiting for mmap(*, *, PROT_READ|PROT_EXEC, *, %d, *) (syscall %d)... ", fd, MMAP_SYSCALLS); word_uint baseaddr = 0; r = trace_wait_syscall(child, &baseaddr, MMAP_SYSCALLS, SYSCALL_ARGTYPE_IGNORE, SYSCALL_ARGTYPE_IGNORE, SYSCALL_ARGTYPE_INT, (word_uint) (PROT_READ | PROT_EXEC), SYSCALL_ARGTYPE_IGNORE, SYSCALL_ARGTYPE_INT, (word_uint) fd, SYSCALL_ARGTYPE_IGNORE, SYSCALL_ARGTYPE_END); if (baseaddr == 0 || r < 0) { pptrace_debug(PPTRACE_DEBUG_LEVEL_VERBOSE, "failed!\n"); return -1; } pptrace_debug(PPTRACE_DEBUG_LEVEL_VERBOSE, "ok (addr = %016lx)\n", baseaddr); pptrace_debug(PPTRACE_DEBUG_LEVEL_VERBOSE, "Waiting for close(%d) (syscall %d)... ", fd, TRACE_SYSCALL(close)); if (trace_wait_syscall(child, NULL, TRACE_SYSCALL(close), SYSCALL_ARGTYPE_INT, fd, SYSCALL_ARGTYPE_END) < 0) { pptrace_debug(PPTRACE_DEBUG_LEVEL_VERBOSE, "failed!\n"); return -1; } pptrace_debug(PPTRACE_DEBUG_LEVEL_VERBOSE, "ok (addr = %016lx)\n", baseaddr); pptrace_apply_library_baseaddr(lib, (zzt_word) baseaddr); return 0; } int pptrace_wait_libraries(pid_t child, pptrace_internal_binary* binary) { while (pptrace_count_unmatched_libraries(binary, 1)) { if (pptrace_wait_library(child, binary)) return -1; } return 0; } /* Install all the detected hijacks into the child process. * Return the number of symbols that were successfully installed * or -1 if an error occured. */ int pptrace_install_hijacks(pid_t child, pptrace_internal_binary* binary) { int i; pptrace_internal_library* lib; int nb_installed = 0; for (lib = binary->first; lib != NULL; lib = lib->next) { if (lib->hijacks) { for (i = 0; lib->hijacks[i] != NULL; i++) { if (lib->hijacks[i]->funSym != NULL && lib->hijacks[i]->funSym->symbol_offset) { // Replacing symbol only when the symbol is not in a dynamic library if (hijack(binary->binary, child, lib->hijacks[i]->funSym, lib->hijacks[i]->origSym, lib->hijacks[i]->replSym) < 0) { fprintf(stderr, "Failed to install hijack of symbol %s\n", lib->hijacks[i]->function); } else { nb_installed ++; pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Function %s instrumented.\n", lib->hijacks[i]->function); } } } } } return nb_installed; } int pptrace_run(void *bin, char **argv, char **envp) { pptrace_clear_error(); if (!bin) { pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "failed!\n"); pptrace_error("Invalid argument"); return -1; } pptrace_internal_binary* binary = (pptrace_internal_binary*) bin; trace_set_bits(get_binary_bits(binary->binary)); pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Running binary %s... ", binary->name); pid_t child = pptrace_launch_preload(binary->name, argv, envp, binary->first, (binary->debugger != NULL) ? 1 : 0); if (child <= 0) { pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "failed!\n"); pptrace_error("Failed to run binary %s", binary->name); pptrace_free_binary(binary); return -1; } pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "ok (pid = %d)\n", child); pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Getting libraries' addresses\n"); if (pptrace_wait_libraries(child, binary)) { pptrace_error( "Failed to wait for open of the library, exiting after detaching child process..."); pptrace_free_binary(binary); return -1; } pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Installing hijacks\n"); if (pptrace_install_hijacks(child, binary) < 0) { trace_detach(child); pptrace_error( "Failed to install hijacks, exiting after detaching child process..."); pptrace_free_binary(binary); return -1; } if (binary->debugger != NULL) { pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Giving the control to the debugger %s\n", binary->debugger[0]); char pid[10]; int i; snprintf(pid, 10, "%d", child); pid[9] = 0; for (i = 0; binary->debugger[i] != NULL; i++) { if (strcmp(binary->debugger[i], "{pid}") == 0) { binary->debugger[i] = pid; } else if (strcmp(binary->debugger[i], "{name}") == 0) { binary->debugger[i] = binary->name; } } char *debugger = get_program_path(binary->debugger[0]); if (debugger == NULL) { pptrace_fubar("debugger %s was not found!", binary->debugger[0]); } trace_detach(child); execve(debugger, binary->debugger, envp); pptrace_fubar("failed to launch debugger!"); } else { pptrace_free_binary(binary); pptrace_debug(PPTRACE_DEBUG_LEVEL_INFO, "Detaching and waiting the end of the process\n"); trace_detach(child); trace_wait(child); } return 0; } eztrace-1.1-2/src/pptrace/pptrace.h000066400000000000000000000041471265506773700172330ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * pptrace.h -- Public interface of PPTrace. Used by EZTrace * * - pptrace_prepare_binary(binary): open *binary* and returns an opaque * structure that is to be used by all other methods here. * - pptrace_load_module(bin, library): add *library* to be an hijack * library. This library should have a symbolic name * __pptrace_hijack_list is an array of string (char*). * Each string contain, separated by a space, the name of symbol to hijack, * the name of the symbol in the library to write the original address, * and the name of the replacement symbol. * *bin* is the opaque structure returned by pptrace_prepare_binary(). * Returns non-zero on failure. * * - pptrace_add_debugger(bin, argv): adds the program ran by the *argv* * vector to the binary *bin* to be the program debugger. An argument * matching '{name}' will be replaced by the target binary name and * an argument matching '{pid}' will be replaced by the target program * identifier. * * - pptrace_add_preload(bin, library): adds *library* to be a preload library. * This library will be added to the preload without doing anything else. * *bin* is the opaque structure returned by pptrace_prepare_binary(). * Returns non-zero on failure. * * - pptrace_run(void *bin, char **argv, char **envp): executes the binary * with the given argv and envp (see execve). * *bin* is the opaque structure returned by pptrace_prepare_binary(). * Returns non-zero on failure and free the *bin* structure. * * Created on: 2 August 2011 * Author: Damien Martin-Guillerez */ #ifndef PPTRACE_PPTRACE_H #define PPTRACE_PPTRACE_H void* pptrace_prepare_binary(char *binary); void pptrace_add_debugger(void *bin, char **argv); int pptrace_load_module(void *bin, char *library); int pptrace_add_preload(void *bin, char *library); int pptrace_run(void *bin, char **argv, char **envp); #endif // PPTRACE_PPTRACE_H eztrace-1.1-2/src/pptrace/tracing.c000066400000000000000000000017401265506773700172130ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * tracing.c * * Wrapper to include the good library for tracing processes * * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #include #include #include #include #include //#ifndef __PPTRACE_TRACE_TYPE #include "os/linux/linux.c" //#else //#if __PPTRACE_TRACE_TYPE == PPTRACE_TRACE_TYPE_BSD //#include "tracing/bsd.c" //#elif __PPTRACE_TRACE_TYPE == PPTRACE_ARCH_TYPE_MACOSX //#include "tracing/macosx.c" //#else // if ! (__PPTRACE_TRACE_TYPE == PPTRACE_ARCH_TYPE_MACOSX || __PPTRACE_TRACE_TYPE == PPTRACE_ARCH_TYPE_BSD) //#include "tracing/linux.c" //#endif // ! (__PPTRACE_TRACE_TYPE == PPTRACE_ARCH_TYPE_MACOSX || __PPTRACE_TRACE_TYPE == PPTRACE_ARCH_TYPE_BSD) //#endif // !defined(__PPTRACE_TRACE_TYPE) eztrace-1.1-2/src/pptrace/tracing.h000066400000000000000000000126131265506773700172210ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * tracing.h -- API for tracing process using ptrace() or similar * * - trace_run(path, argv, envp, debug): executes a process and trace it * Arguments should be the same as execve. The returned value * is the pid of the traced process. * If path is NULL, the process is only forked and trace_run * act as fork, the traced process return 0 and the tracing * returned the pid of the traced process. debug tells * the trace_run function that we would like to debug at the * detachment of the process (so run the program in background). * - trace_detach(child): detach (stop tracing) the process *child*. * - trace_wait(child): wait for the end of the process *child*. * - trace_set_bits(bits): tells the tracing system the size of a word * in the trace process (default is the wordsize of the host process). * - get_ip(child): returns the instruction pointer of process *child*. * - set_ip(child, rip): set to *rip* the instruction pointer of process * *child*. * - trace_read(child, fromaddr, buffer, length): reads *length* bytes * into *buffer* from *child* memory starting at address *fromaddr*. * - trace_write(child, fromaddr, buffer, length): write *length* bytes * from *buffer* to *child* memory starting at address *fromaddr*. * - trace_replace(child, addr, newbyte): set the byte at address *addr* * of *child* memory to *newbyte*. The previous value of this address * is returned by this function. * - trace_copy(child, fromaddr, toaddr, length): copies *length* bytes * from address *fromaddr* to address *toaddr* of *child* memory. * - trace_singlestep(child): executes one instruction of *child* and * stops after. * - trace_continue(child): Continue the child until a signal is caught. * - trace_syscall(child): Continue the child until a signal is caught or * a syscall is issued. * - trace_mmap(child, addr, length, prot): do, inside *child*, a * mmap(addr, length, prot, MAP_ANONYMOUS | MAP_PRIVATE | MAP_32BIT, -1, 0). * This function return the result of the syscall. * - trace_wait_syscall(child, retval, syscall, ...): wait for syscall number * *syscall* to happen in *child*. Result of the syscall is store in *retval*. * The arguments after are a series of SYSCALL_ARGTYPE_* ended * by SYSCALL_ARGTYPE_END. * SYSCALL_ARGTYPE_INT waits for an integer that matches the next * argument * SYSCALL_ARGTYPE_ZSTRING waits for a null terminated string that * matches the next argument * SYSCALL_ARGTYPE_ZSTRING waits for a null terminated string that * will be returned in the pointer given as next argument * SYSCALL_ARGTYPE_IGNORE waits for any argument * trace_wait_syscall returns < 0 when the wait did not encountered * the awaited syscall and 0 on success. * For use with several similar syscalls, multiple syscall numbers can be fit * together in syscall using high bits range (2 byte per syscall number) * - trace_get_regs(pid_t child, REG_STRUCT* regs): returns the registers * of process *child* into *regs*. * - trace_set_regs(pid_t child, REG_STRUCT* regs): set the registers of * process *child* to be *regs*. * Created on: 2 juil. 2011 * Author: Damien Martin-Guillerez */ #ifndef PPTRACE_TRACING_H_ #define PPTRACE_TRACING_H_ #include #include #include //#ifndef __PPTRACE_TRACE_TYPE #include //#else //#if __PPTRACE_TRACE_TYPE == PPTRACE_TRACE_TYPE_BSD //#include //#elif __PPTRACE_TRACE_TYPE == PPTRACE_ARCH_TYPE_MACOSX //#include //#else // if ! (__PPTRACE_TRACE_TYPE == PPTRACE_ARCH_TYPE_MACOSX || __PPTRACE_TRACE_TYPE == PPTRACE_ARCH_TYPE_BSD) //#include //#endif // ! (__PPTRACE_TRACE_TYPE == PPTRACE_ARCH_TYPE_MACOSX || __PPTRACE_TRACE_TYPE == PPTRACE_ARCH_TYPE_BSD) //#endif // !defined(__PPTRACE_TRACE_TYPE) #define SYSCALL_ARGTYPE_END 0 #define SYSCALL_ARGTYPE_INT 1 #define SYSCALL_ARGTYPE_ZSTRING 2 #define SYSCALL_ARGTYPE_ZSTRING_RETURN 3 // Return the value of the string #define SYSCALL_ARGTYPE_IGNORE 4 pid_t trace_run(char *path, char **argv, char **envp, int debug); void trace_detach(pid_t child); void trace_wait(pid_t child); void trace_set_bits(int bits); word_uint get_ip(pid_t child); void set_ip(pid_t child, word_uint rip); #ifdef __x86_64__ // x86_64 void trace_get_regs(pid_t child, REG_STRUCT* regs); void trace_set_regs(pid_t child, REG_STRUCT* regs); #endif void trace_read(pid_t child, word_uint fromaddr, uint8_t* buffer, size_t length); void trace_write(pid_t child, word_uint addr, uint8_t* buffer, size_t length); uint8_t trace_replace(pid_t child, word_uint addr, uint8_t newbyte); void trace_copy(pid_t child, word_uint fromaddr, word_uint toaddr, size_t length); int trace_singlestep(pid_t child); int trace_syscall(pid_t child); int trace_continue(pid_t child); word_uint trace_mmap(pid_t child, word_uint addr, size_t length, int prot); int trace_wait_syscall(pid_t child, word_uint *retval, unsigned long syscall, ...); // Wait for syscall and return the return value of the first encountered syscall void print_reg_value(pid_t, word_uint); #endif /* PPTRACE_TRACING_H_ */ eztrace-1.1-2/src/pptrace/types.h000066400000000000000000000012171265506773700167340ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #ifndef TYPES_H #define TYPES_H // without explicit distinguishing between architectures, this code is portable on both x86_64 and ARMv7 #if __WORDSIZE == 64 typedef uint64_t word_uint; typedef int64_t word_int; #define WORD_HEX_FORMAT "%lx" #define WORD_DEC_FORMAT "%ld" #else // __WORDSIZE != 64 typedef uint32_t word_uint; typedef int32_t word_int; #define WORD_HEX_FORMAT "%x" #define WORD_DEC_FORMAT "%d" #endif // __WORDSIZE == 64 #endif // TYPES_H #if __arm__ #define ARM_INSTR_SIZE 32 #endif eztrace-1.1-2/test-driver000077500000000000000000000110401265506773700153630ustar00rootroot00000000000000#! /bin/sh # test-driver - basic testsuite driver script. scriptversion=2013-07-13.22; # UTC # Copyright (C) 2011-2014 Free Software Foundation, Inc. # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2, or (at your option) # any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # This file is maintained in Automake, please report # bugs to or send patches to # . # Make unconditional expansion of undefined variables an error. This # helps a lot in preventing typo-related bugs. set -u usage_error () { echo "$0: $*" >&2 print_usage >&2 exit 2 } print_usage () { cat <$log_file 2>&1 estatus=$? if test $enable_hard_errors = no && test $estatus -eq 99; then tweaked_estatus=1 else tweaked_estatus=$estatus fi case $tweaked_estatus:$expect_failure in 0:yes) col=$red res=XPASS recheck=yes gcopy=yes;; 0:*) col=$grn res=PASS recheck=no gcopy=no;; 77:*) col=$blu res=SKIP recheck=no gcopy=yes;; 99:*) col=$mgn res=ERROR recheck=yes gcopy=yes;; *:yes) col=$lgn res=XFAIL recheck=no gcopy=yes;; *:*) col=$red res=FAIL recheck=yes gcopy=yes;; esac # Report the test outcome and exit status in the logs, so that one can # know whether the test passed or failed simply by looking at the '.log' # file, without the need of also peaking into the corresponding '.trs' # file (automake bug#11814). echo "$res $test_name (exit status: $estatus)" >>$log_file # Report outcome to console. echo "${col}${res}${std}: $test_name" # Register the test result, and other relevant metadata. echo ":test-result: $res" > $trs_file echo ":global-test-result: $res" >> $trs_file echo ":recheck: $recheck" >> $trs_file echo ":copy-in-global-log: $gcopy" >> $trs_file # Local Variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC" # time-stamp-end: "; # UTC" # End: eztrace-1.1-2/test/000077500000000000000000000000001265506773700141505ustar00rootroot00000000000000eztrace-1.1-2/test/automake/000077500000000000000000000000001265506773700157565ustar00rootroot00000000000000eztrace-1.1-2/test/automake/Makefile.am000066400000000000000000000032031265506773700200100ustar00rootroot00000000000000# Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 # See COPYING in top-level directory. if AMEXTERNLITL TLCFLAGS=$(TL_CPPFLAGS) TLLDFLAGS=$(TL_LDFLAGS) TLLIBADD=$(TL_LIB) else # AMEXTERNLITL TLCFLAGS = -I$(top_srcdir)/extlib/litl/src -I$(top_builddir)/extlib/litl/src TLLDFLAGS = $(top_builddir)/extlib/litl/src/liblitl.la TLLIBADD=$(TL_LIB) endif # AMINTERNLITL if AMEXTERNGTG GTGCFLAGS=$(GTG_CPPFLAGS) GTGLDFLAGS=$(GTG_LDFLAGS) GTGDEPENDENCIES = GTGLIBADD=$(GTG_LIB) else GTGCFLAGS = -I$(top_srcdir)/extlib/gtg/inc -I$(top_builddir)/extlib/gtg GTGLDFLAGS = $(top_builddir)/extlib/gtg/src/libgtg.la GTGDEPENDENCIES = $(GTGLDFLAGS) GTGLIBADD= endif if GTG_OUT_OF_ORDER GTGCFLAGS+=-DGTG_OUT_OF_ORDER endif AM_CFLAGS = -W -Wall -Wextra -I$(srcdir)/../../core/ -I$(top_builddir)/src/core -I$(top_builddir)/src/pptrace $(TLCFLAGS) AM_CPPFLAGS = $(TLCFLAGS) AM_LDFLAGS= $(TLLDFLAGS) CTESTS = teststdio \ testmemory \ teststatic if OPENMP_FOUND CTESTS += testopenmpsimple testopenmplock testopenmpnestlock endif if USE_MPI CTESTS += testmpiring endif if USE_PTHREAD CTESTS += testpthreaddummy_thread testpthreadtest testpthreadcond #testpthreadcond_SOURCES = testpthreadcond.c #testpthreadcond_DEPENDENCIES=../pthread/cond #testpthreaddummy_thread_SOURCES = testpthreaddummy_thread.c #testpthreaddummy_thread_DEPENDENCIES=../pthread/dummy_thread #testpthreadtest_SOURCES = testpthreadtest.c #testpthreadtest_DEPENDENCIES=../pthread/test_pthread endif check_PROGRAMS = $(CTESTS) TESTS = $(CTESTS) #teststdio_SOURCES = teststdio.c #teststdio_DEPENDENCIES=../stdio/stdio #teststatic_SOURCES = teststatic.c #teststatic_DEPENDENCIES=../static/static eztrace-1.1-2/test/automake/Makefile.in000066400000000000000000001232071265506773700200300ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @GTG_OUT_OF_ORDER_TRUE@am__append_1 = -DGTG_OUT_OF_ORDER @OPENMP_FOUND_TRUE@am__append_2 = testopenmpsimple testopenmplock testopenmpnestlock @USE_MPI_TRUE@am__append_3 = testmpiring @USE_PTHREAD_TRUE@am__append_4 = testpthreaddummy_thread testpthreadtest testpthreadcond check_PROGRAMS = $(am__EXEEXT_4) TESTS = $(am__EXEEXT_4) subdir = test/automake ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = testcommon.h CONFIG_CLEAN_VPATH_FILES = @OPENMP_FOUND_TRUE@am__EXEEXT_1 = testopenmpsimple$(EXEEXT) \ @OPENMP_FOUND_TRUE@ testopenmplock$(EXEEXT) \ @OPENMP_FOUND_TRUE@ testopenmpnestlock$(EXEEXT) @USE_MPI_TRUE@am__EXEEXT_2 = testmpiring$(EXEEXT) @USE_PTHREAD_TRUE@am__EXEEXT_3 = testpthreaddummy_thread$(EXEEXT) \ @USE_PTHREAD_TRUE@ testpthreadtest$(EXEEXT) \ @USE_PTHREAD_TRUE@ testpthreadcond$(EXEEXT) am__EXEEXT_4 = teststdio$(EXEEXT) testmemory$(EXEEXT) \ teststatic$(EXEEXT) $(am__EXEEXT_1) $(am__EXEEXT_2) \ $(am__EXEEXT_3) testmemory_SOURCES = testmemory.c testmemory_OBJECTS = testmemory.$(OBJEXT) testmemory_LDADD = $(LDADD) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = testmpiring_SOURCES = testmpiring.c testmpiring_OBJECTS = testmpiring.$(OBJEXT) testmpiring_LDADD = $(LDADD) testopenmplock_SOURCES = testopenmplock.c testopenmplock_OBJECTS = testopenmplock.$(OBJEXT) testopenmplock_LDADD = $(LDADD) testopenmpnestlock_SOURCES = testopenmpnestlock.c testopenmpnestlock_OBJECTS = testopenmpnestlock.$(OBJEXT) testopenmpnestlock_LDADD = $(LDADD) testopenmpsimple_SOURCES = testopenmpsimple.c testopenmpsimple_OBJECTS = testopenmpsimple.$(OBJEXT) testopenmpsimple_LDADD = $(LDADD) testpthreadcond_SOURCES = testpthreadcond.c testpthreadcond_OBJECTS = testpthreadcond.$(OBJEXT) testpthreadcond_LDADD = $(LDADD) testpthreaddummy_thread_SOURCES = testpthreaddummy_thread.c testpthreaddummy_thread_OBJECTS = testpthreaddummy_thread.$(OBJEXT) testpthreaddummy_thread_LDADD = $(LDADD) testpthreadtest_SOURCES = testpthreadtest.c testpthreadtest_OBJECTS = testpthreadtest.$(OBJEXT) testpthreadtest_LDADD = $(LDADD) teststatic_SOURCES = teststatic.c teststatic_OBJECTS = teststatic.$(OBJEXT) teststatic_LDADD = $(LDADD) teststdio_SOURCES = teststdio.c teststdio_OBJECTS = teststdio.$(OBJEXT) teststdio_LDADD = $(LDADD) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = testmemory.c testmpiring.c testopenmplock.c \ testopenmpnestlock.c testopenmpsimple.c testpthreadcond.c \ testpthreaddummy_thread.c testpthreadtest.c teststatic.c \ teststdio.c DIST_SOURCES = testmemory.c testmpiring.c testopenmplock.c \ testopenmpnestlock.c testopenmpsimple.c testpthreadcond.c \ testpthreaddummy_thread.c testpthreadtest.c teststatic.c \ teststdio.c am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__tty_colors_dummy = \ mgn= red= grn= lgn= blu= brg= std=; \ am__color_tests=no am__tty_colors = { \ $(am__tty_colors_dummy); \ if test "X$(AM_COLOR_TESTS)" = Xno; then \ am__color_tests=no; \ elif test "X$(AM_COLOR_TESTS)" = Xalways; then \ am__color_tests=yes; \ elif test "X$$TERM" != Xdumb && { test -t 1; } 2>/dev/null; then \ am__color_tests=yes; \ fi; \ if test $$am__color_tests = yes; then \ red=''; \ grn=''; \ lgn=''; \ blu=''; \ mgn=''; \ brg=''; \ std=''; \ fi; \ } am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__recheck_rx = ^[ ]*:recheck:[ ]* am__global_test_result_rx = ^[ ]*:global-test-result:[ ]* am__copy_in_global_log_rx = ^[ ]*:copy-in-global-log:[ ]* # A command that, given a newline-separated list of test names on the # standard input, print the name of the tests that are to be re-run # upon "make recheck". am__list_recheck_tests = $(AWK) '{ \ recheck = 1; \ while ((rc = (getline line < ($$0 ".trs"))) != 0) \ { \ if (rc < 0) \ { \ if ((getline line2 < ($$0 ".log")) < 0) \ recheck = 0; \ break; \ } \ else if (line ~ /$(am__recheck_rx)[nN][Oo]/) \ { \ recheck = 0; \ break; \ } \ else if (line ~ /$(am__recheck_rx)[yY][eE][sS]/) \ { \ break; \ } \ }; \ if (recheck) \ print $$0; \ close ($$0 ".trs"); \ close ($$0 ".log"); \ }' # A command that, given a newline-separated list of test names on the # standard input, create the global log from their .trs and .log files. am__create_global_log = $(AWK) ' \ function fatal(msg) \ { \ print "fatal: making $@: " msg | "cat >&2"; \ exit 1; \ } \ function rst_section(header) \ { \ print header; \ len = length(header); \ for (i = 1; i <= len; i = i + 1) \ printf "="; \ printf "\n\n"; \ } \ { \ copy_in_global_log = 1; \ global_test_result = "RUN"; \ while ((rc = (getline line < ($$0 ".trs"))) != 0) \ { \ if (rc < 0) \ fatal("failed to read from " $$0 ".trs"); \ if (line ~ /$(am__global_test_result_rx)/) \ { \ sub("$(am__global_test_result_rx)", "", line); \ sub("[ ]*$$", "", line); \ global_test_result = line; \ } \ else if (line ~ /$(am__copy_in_global_log_rx)[nN][oO]/) \ copy_in_global_log = 0; \ }; \ if (copy_in_global_log) \ { \ rst_section(global_test_result ": " $$0); \ while ((rc = (getline line < ($$0 ".log"))) != 0) \ { \ if (rc < 0) \ fatal("failed to read from " $$0 ".log"); \ print line; \ }; \ printf "\n"; \ }; \ close ($$0 ".trs"); \ close ($$0 ".log"); \ }' # Restructured Text title. am__rst_title = { sed 's/.*/ & /;h;s/./=/g;p;x;s/ *$$//;p;g' && echo; } # Solaris 10 'make', and several other traditional 'make' implementations, # pass "-e" to $(SHELL), and POSIX 2008 even requires this. Work around it # by disabling -e (using the XSI extension "set +e") if it's set. am__sh_e_setup = case $$- in *e*) set +e;; esac # Default flags passed to test drivers. am__common_driver_flags = \ --color-tests "$$am__color_tests" \ --enable-hard-errors "$$am__enable_hard_errors" \ --expect-failure "$$am__expect_failure" # To be inserted before the command running the test. Creates the # directory for the log if needed. Stores in $dir the directory # containing $f, in $tst the test, in $log the log. Executes the # developer- defined test setup AM_TESTS_ENVIRONMENT (if any), and # passes TESTS_ENVIRONMENT. Set up options for the wrapper that # will run the test scripts (or their associated LOG_COMPILER, if # thy have one). am__check_pre = \ $(am__sh_e_setup); \ $(am__vpath_adj_setup) $(am__vpath_adj) \ $(am__tty_colors); \ srcdir=$(srcdir); export srcdir; \ case "$@" in \ */*) am__odir=`echo "./$@" | sed 's|/[^/]*$$||'`;; \ *) am__odir=.;; \ esac; \ test "x$$am__odir" = x"." || test -d "$$am__odir" \ || $(MKDIR_P) "$$am__odir" || exit $$?; \ if test -f "./$$f"; then dir=./; \ elif test -f "$$f"; then dir=; \ else dir="$(srcdir)/"; fi; \ tst=$$dir$$f; log='$@'; \ if test -n '$(DISABLE_HARD_ERRORS)'; then \ am__enable_hard_errors=no; \ else \ am__enable_hard_errors=yes; \ fi; \ case " $(XFAIL_TESTS) " in \ *[\ \ ]$$f[\ \ ]* | *[\ \ ]$$dir$$f[\ \ ]*) \ am__expect_failure=yes;; \ *) \ am__expect_failure=no;; \ esac; \ $(AM_TESTS_ENVIRONMENT) $(TESTS_ENVIRONMENT) # A shell command to get the names of the tests scripts with any registered # extension removed (i.e., equivalently, the names of the test logs, with # the '.log' extension removed). The result is saved in the shell variable # '$bases'. This honors runtime overriding of TESTS and TEST_LOGS. Sadly, # we cannot use something simpler, involving e.g., "$(TEST_LOGS:.log=)", # since that might cause problem with VPATH rewrites for suffix-less tests. # See also 'test-harness-vpath-rewrite.sh' and 'test-trs-basic.sh'. am__set_TESTS_bases = \ bases='$(TEST_LOGS)'; \ bases=`for i in $$bases; do echo $$i; done | sed 's/\.log$$//'`; \ bases=`echo $$bases` RECHECK_LOGS = $(TEST_LOGS) AM_RECURSIVE_TARGETS = check recheck TEST_SUITE_LOG = test-suite.log TEST_EXTENSIONS = @EXEEXT@ .test LOG_DRIVER = $(SHELL) $(top_srcdir)/test-driver LOG_COMPILE = $(LOG_COMPILER) $(AM_LOG_FLAGS) $(LOG_FLAGS) am__set_b = \ case '$@' in \ */*) \ case '$*' in \ */*) b='$*';; \ *) b=`echo '$@' | sed 's/\.log$$//'`; \ esac;; \ *) \ b='$*';; \ esac am__test_logs1 = $(TESTS:=.log) am__test_logs2 = $(am__test_logs1:@EXEEXT@.log=.log) TEST_LOGS = $(am__test_logs2:.test.log=.log) TEST_LOG_DRIVER = $(SHELL) $(top_srcdir)/test-driver TEST_LOG_COMPILE = $(TEST_LOG_COMPILER) $(AM_TEST_LOG_FLAGS) \ $(TEST_LOG_FLAGS) am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/testcommon.h.in \ $(top_srcdir)/depcomp $(top_srcdir)/test-driver DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ @AMEXTERNLITL_FALSE@TLCFLAGS = -I$(top_srcdir)/extlib/litl/src -I$(top_builddir)/extlib/litl/src @AMEXTERNLITL_TRUE@TLCFLAGS = $(TL_CPPFLAGS) @AMEXTERNLITL_FALSE@TLLDFLAGS = $(top_builddir)/extlib/litl/src/liblitl.la @AMEXTERNLITL_TRUE@TLLDFLAGS = $(TL_LDFLAGS) @AMEXTERNLITL_FALSE@TLLIBADD = $(TL_LIB) @AMEXTERNLITL_TRUE@TLLIBADD = $(TL_LIB) @AMEXTERNGTG_FALSE@GTGCFLAGS = -I$(top_srcdir)/extlib/gtg/inc \ @AMEXTERNGTG_FALSE@ -I$(top_builddir)/extlib/gtg \ @AMEXTERNGTG_FALSE@ $(am__append_1) @AMEXTERNGTG_TRUE@GTGCFLAGS = $(GTG_CPPFLAGS) $(am__append_1) @AMEXTERNGTG_FALSE@GTGLDFLAGS = $(top_builddir)/extlib/gtg/src/libgtg.la @AMEXTERNGTG_TRUE@GTGLDFLAGS = $(GTG_LDFLAGS) @AMEXTERNGTG_FALSE@GTGDEPENDENCIES = $(GTGLDFLAGS) @AMEXTERNGTG_TRUE@GTGDEPENDENCIES = @AMEXTERNGTG_FALSE@GTGLIBADD = @AMEXTERNGTG_TRUE@GTGLIBADD = $(GTG_LIB) AM_CFLAGS = -W -Wall -Wextra -I$(srcdir)/../../core/ -I$(top_builddir)/src/core -I$(top_builddir)/src/pptrace $(TLCFLAGS) AM_CPPFLAGS = $(TLCFLAGS) AM_LDFLAGS = $(TLLDFLAGS) CTESTS = teststdio testmemory teststatic $(am__append_2) \ $(am__append_3) $(am__append_4) all: all-am .SUFFIXES: .SUFFIXES: .c .lo .log .o .obj .test .test$(EXEEXT) .trs $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu test/automake/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu test/automake/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): testcommon.h: $(top_builddir)/config.status $(srcdir)/testcommon.h.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ clean-checkPROGRAMS: @list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list testmemory$(EXEEXT): $(testmemory_OBJECTS) $(testmemory_DEPENDENCIES) $(EXTRA_testmemory_DEPENDENCIES) @rm -f testmemory$(EXEEXT) $(AM_V_CCLD)$(LINK) $(testmemory_OBJECTS) $(testmemory_LDADD) $(LIBS) testmpiring$(EXEEXT): $(testmpiring_OBJECTS) $(testmpiring_DEPENDENCIES) $(EXTRA_testmpiring_DEPENDENCIES) @rm -f testmpiring$(EXEEXT) $(AM_V_CCLD)$(LINK) $(testmpiring_OBJECTS) $(testmpiring_LDADD) $(LIBS) testopenmplock$(EXEEXT): $(testopenmplock_OBJECTS) $(testopenmplock_DEPENDENCIES) $(EXTRA_testopenmplock_DEPENDENCIES) @rm -f testopenmplock$(EXEEXT) $(AM_V_CCLD)$(LINK) $(testopenmplock_OBJECTS) $(testopenmplock_LDADD) $(LIBS) testopenmpnestlock$(EXEEXT): $(testopenmpnestlock_OBJECTS) $(testopenmpnestlock_DEPENDENCIES) $(EXTRA_testopenmpnestlock_DEPENDENCIES) @rm -f testopenmpnestlock$(EXEEXT) $(AM_V_CCLD)$(LINK) $(testopenmpnestlock_OBJECTS) $(testopenmpnestlock_LDADD) $(LIBS) testopenmpsimple$(EXEEXT): $(testopenmpsimple_OBJECTS) $(testopenmpsimple_DEPENDENCIES) $(EXTRA_testopenmpsimple_DEPENDENCIES) @rm -f testopenmpsimple$(EXEEXT) $(AM_V_CCLD)$(LINK) $(testopenmpsimple_OBJECTS) $(testopenmpsimple_LDADD) $(LIBS) testpthreadcond$(EXEEXT): $(testpthreadcond_OBJECTS) $(testpthreadcond_DEPENDENCIES) $(EXTRA_testpthreadcond_DEPENDENCIES) @rm -f testpthreadcond$(EXEEXT) $(AM_V_CCLD)$(LINK) $(testpthreadcond_OBJECTS) $(testpthreadcond_LDADD) $(LIBS) testpthreaddummy_thread$(EXEEXT): $(testpthreaddummy_thread_OBJECTS) $(testpthreaddummy_thread_DEPENDENCIES) $(EXTRA_testpthreaddummy_thread_DEPENDENCIES) @rm -f testpthreaddummy_thread$(EXEEXT) $(AM_V_CCLD)$(LINK) $(testpthreaddummy_thread_OBJECTS) $(testpthreaddummy_thread_LDADD) $(LIBS) testpthreadtest$(EXEEXT): $(testpthreadtest_OBJECTS) $(testpthreadtest_DEPENDENCIES) $(EXTRA_testpthreadtest_DEPENDENCIES) @rm -f testpthreadtest$(EXEEXT) $(AM_V_CCLD)$(LINK) $(testpthreadtest_OBJECTS) $(testpthreadtest_LDADD) $(LIBS) teststatic$(EXEEXT): $(teststatic_OBJECTS) $(teststatic_DEPENDENCIES) $(EXTRA_teststatic_DEPENDENCIES) @rm -f teststatic$(EXEEXT) $(AM_V_CCLD)$(LINK) $(teststatic_OBJECTS) $(teststatic_LDADD) $(LIBS) teststdio$(EXEEXT): $(teststdio_OBJECTS) $(teststdio_DEPENDENCIES) $(EXTRA_teststdio_DEPENDENCIES) @rm -f teststdio$(EXEEXT) $(AM_V_CCLD)$(LINK) $(teststdio_OBJECTS) $(teststdio_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testmemory.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testmpiring.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testopenmplock.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testopenmpnestlock.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testopenmpsimple.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testpthreadcond.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testpthreaddummy_thread.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testpthreadtest.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/teststatic.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/teststdio.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags # Recover from deleted '.trs' file; this should ensure that # "rm -f foo.log; make foo.trs" re-run 'foo.test', and re-create # both 'foo.log' and 'foo.trs'. Break the recipe in two subshells # to avoid problems with "make -n". .log.trs: rm -f $< $@ $(MAKE) $(AM_MAKEFLAGS) $< # Leading 'am--fnord' is there to ensure the list of targets does not # expand to empty, as could happen e.g. with make check TESTS=''. am--fnord $(TEST_LOGS) $(TEST_LOGS:.log=.trs): $(am__force_recheck) am--force-recheck: @: $(TEST_SUITE_LOG): $(TEST_LOGS) @$(am__set_TESTS_bases); \ am__f_ok () { test -f "$$1" && test -r "$$1"; }; \ redo_bases=`for i in $$bases; do \ am__f_ok $$i.trs && am__f_ok $$i.log || echo $$i; \ done`; \ if test -n "$$redo_bases"; then \ redo_logs=`for i in $$redo_bases; do echo $$i.log; done`; \ redo_results=`for i in $$redo_bases; do echo $$i.trs; done`; \ if $(am__make_dryrun); then :; else \ rm -f $$redo_logs && rm -f $$redo_results || exit 1; \ fi; \ fi; \ if test -n "$$am__remaking_logs"; then \ echo "fatal: making $(TEST_SUITE_LOG): possible infinite" \ "recursion detected" >&2; \ elif test -n "$$redo_logs"; then \ am__remaking_logs=yes $(MAKE) $(AM_MAKEFLAGS) $$redo_logs; \ fi; \ if $(am__make_dryrun); then :; else \ st=0; \ errmsg="fatal: making $(TEST_SUITE_LOG): failed to create"; \ for i in $$redo_bases; do \ test -f $$i.trs && test -r $$i.trs \ || { echo "$$errmsg $$i.trs" >&2; st=1; }; \ test -f $$i.log && test -r $$i.log \ || { echo "$$errmsg $$i.log" >&2; st=1; }; \ done; \ test $$st -eq 0 || exit 1; \ fi @$(am__sh_e_setup); $(am__tty_colors); $(am__set_TESTS_bases); \ ws='[ ]'; \ results=`for b in $$bases; do echo $$b.trs; done`; \ test -n "$$results" || results=/dev/null; \ all=` grep "^$$ws*:test-result:" $$results | wc -l`; \ pass=` grep "^$$ws*:test-result:$$ws*PASS" $$results | wc -l`; \ fail=` grep "^$$ws*:test-result:$$ws*FAIL" $$results | wc -l`; \ skip=` grep "^$$ws*:test-result:$$ws*SKIP" $$results | wc -l`; \ xfail=`grep "^$$ws*:test-result:$$ws*XFAIL" $$results | wc -l`; \ xpass=`grep "^$$ws*:test-result:$$ws*XPASS" $$results | wc -l`; \ error=`grep "^$$ws*:test-result:$$ws*ERROR" $$results | wc -l`; \ if test `expr $$fail + $$xpass + $$error` -eq 0; then \ success=true; \ else \ success=false; \ fi; \ br='==================='; br=$$br$$br$$br$$br; \ result_count () \ { \ if test x"$$1" = x"--maybe-color"; then \ maybe_colorize=yes; \ elif test x"$$1" = x"--no-color"; then \ maybe_colorize=no; \ else \ echo "$@: invalid 'result_count' usage" >&2; exit 4; \ fi; \ shift; \ desc=$$1 count=$$2; \ if test $$maybe_colorize = yes && test $$count -gt 0; then \ color_start=$$3 color_end=$$std; \ else \ color_start= color_end=; \ fi; \ echo "$${color_start}# $$desc $$count$${color_end}"; \ }; \ create_testsuite_report () \ { \ result_count $$1 "TOTAL:" $$all "$$brg"; \ result_count $$1 "PASS: " $$pass "$$grn"; \ result_count $$1 "SKIP: " $$skip "$$blu"; \ result_count $$1 "XFAIL:" $$xfail "$$lgn"; \ result_count $$1 "FAIL: " $$fail "$$red"; \ result_count $$1 "XPASS:" $$xpass "$$red"; \ result_count $$1 "ERROR:" $$error "$$mgn"; \ }; \ { \ echo "$(PACKAGE_STRING): $(subdir)/$(TEST_SUITE_LOG)" | \ $(am__rst_title); \ create_testsuite_report --no-color; \ echo; \ echo ".. contents:: :depth: 2"; \ echo; \ for b in $$bases; do echo $$b; done \ | $(am__create_global_log); \ } >$(TEST_SUITE_LOG).tmp || exit 1; \ mv $(TEST_SUITE_LOG).tmp $(TEST_SUITE_LOG); \ if $$success; then \ col="$$grn"; \ else \ col="$$red"; \ test x"$$VERBOSE" = x || cat $(TEST_SUITE_LOG); \ fi; \ echo "$${col}$$br$${std}"; \ echo "$${col}Testsuite summary for $(PACKAGE_STRING)$${std}"; \ echo "$${col}$$br$${std}"; \ create_testsuite_report --maybe-color; \ echo "$$col$$br$$std"; \ if $$success; then :; else \ echo "$${col}See $(subdir)/$(TEST_SUITE_LOG)$${std}"; \ if test -n "$(PACKAGE_BUGREPORT)"; then \ echo "$${col}Please report to $(PACKAGE_BUGREPORT)$${std}"; \ fi; \ echo "$$col$$br$$std"; \ fi; \ $$success || exit 1 check-TESTS: @list='$(RECHECK_LOGS)'; test -z "$$list" || rm -f $$list @list='$(RECHECK_LOGS:.log=.trs)'; test -z "$$list" || rm -f $$list @test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG) @set +e; $(am__set_TESTS_bases); \ log_list=`for i in $$bases; do echo $$i.log; done`; \ trs_list=`for i in $$bases; do echo $$i.trs; done`; \ log_list=`echo $$log_list`; trs_list=`echo $$trs_list`; \ $(MAKE) $(AM_MAKEFLAGS) $(TEST_SUITE_LOG) TEST_LOGS="$$log_list"; \ exit $$?; recheck: all $(check_PROGRAMS) @test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG) @set +e; $(am__set_TESTS_bases); \ bases=`for i in $$bases; do echo $$i; done \ | $(am__list_recheck_tests)` || exit 1; \ log_list=`for i in $$bases; do echo $$i.log; done`; \ log_list=`echo $$log_list`; \ $(MAKE) $(AM_MAKEFLAGS) $(TEST_SUITE_LOG) \ am__force_recheck=am--force-recheck \ TEST_LOGS="$$log_list"; \ exit $$? teststdio.log: teststdio$(EXEEXT) @p='teststdio$(EXEEXT)'; \ b='teststdio'; \ $(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) testmemory.log: testmemory$(EXEEXT) @p='testmemory$(EXEEXT)'; \ b='testmemory'; \ $(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) teststatic.log: teststatic$(EXEEXT) @p='teststatic$(EXEEXT)'; \ b='teststatic'; \ $(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) testopenmpsimple.log: testopenmpsimple$(EXEEXT) @p='testopenmpsimple$(EXEEXT)'; \ b='testopenmpsimple'; \ $(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) testopenmplock.log: testopenmplock$(EXEEXT) @p='testopenmplock$(EXEEXT)'; \ b='testopenmplock'; \ $(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) testopenmpnestlock.log: testopenmpnestlock$(EXEEXT) @p='testopenmpnestlock$(EXEEXT)'; \ b='testopenmpnestlock'; \ $(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) testmpiring.log: testmpiring$(EXEEXT) @p='testmpiring$(EXEEXT)'; \ b='testmpiring'; \ $(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) testpthreaddummy_thread.log: testpthreaddummy_thread$(EXEEXT) @p='testpthreaddummy_thread$(EXEEXT)'; \ b='testpthreaddummy_thread'; \ $(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) testpthreadtest.log: testpthreadtest$(EXEEXT) @p='testpthreadtest$(EXEEXT)'; \ b='testpthreadtest'; \ $(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) testpthreadcond.log: testpthreadcond$(EXEEXT) @p='testpthreadcond$(EXEEXT)'; \ b='testpthreadcond'; \ $(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) .test.log: @p='$<'; \ $(am__set_b); \ $(am__check_pre) $(TEST_LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_TEST_LOG_DRIVER_FLAGS) $(TEST_LOG_DRIVER_FLAGS) -- $(TEST_LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) @am__EXEEXT_TRUE@.test$(EXEEXT).log: @am__EXEEXT_TRUE@ @p='$<'; \ @am__EXEEXT_TRUE@ $(am__set_b); \ @am__EXEEXT_TRUE@ $(am__check_pre) $(TEST_LOG_DRIVER) --test-name "$$f" \ @am__EXEEXT_TRUE@ --log-file $$b.log --trs-file $$b.trs \ @am__EXEEXT_TRUE@ $(am__common_driver_flags) $(AM_TEST_LOG_DRIVER_FLAGS) $(TEST_LOG_DRIVER_FLAGS) -- $(TEST_LOG_COMPILE) \ @am__EXEEXT_TRUE@ "$$tst" $(AM_TESTS_FD_REDIRECT) distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am $(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS) $(MAKE) $(AM_MAKEFLAGS) check-TESTS check: check-am all-am: Makefile installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: -test -z "$(TEST_LOGS)" || rm -f $(TEST_LOGS) -test -z "$(TEST_LOGS:.log=.trs)" || rm -f $(TEST_LOGS:.log=.trs) -test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG) clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-checkPROGRAMS clean-generic clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: .MAKE: check-am install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-TESTS check-am clean \ clean-checkPROGRAMS clean-generic clean-libtool cscopelist-am \ ctags ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ recheck tags tags-am uninstall uninstall-am .PRECIOUS: Makefile #teststdio_SOURCES = teststdio.c #teststdio_DEPENDENCIES=../stdio/stdio #teststatic_SOURCES = teststatic.c #teststatic_DEPENDENCIES=../static/static # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/test/automake/testcommon.h.in000066400000000000000000000310371265506773700207300ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ // A refactoring of automake tests #ifndef __TEST_COMMON_H #define __TEST_COMMON_H #ifndef eztrace_extra #define eztrace_extra #endif #include #include #include #include #include #include #include #include #include #define TOP_BUILDDIR "@abs_top_builddir@/" #define EZTRACE "@abs_top_builddir@/src/core/eztrace" #define EZTRACE_CONVERT "@abs_top_builddir@/src/core/eztrace_convert" #define TL_READ "@LITL_PRINT@" char pwd[512]; char user[32]; int debug = 3; char trace[nproc][256]; pid_t pid; int nbdiffevent; char filecode[nproc][25]; char fileref[nproc][25]; char filetime[nproc][25]; char filearg1[nproc][25]; char filearg2[nproc][25]; /* struct used in order to record event */ struct realevent { int proc; unsigned long long int time; int arg1, arg2; }; struct event { char* code; int nbeventexpected; int realnbofevent; struct realevent tab_realevent[NBMAXREALEVENT]; }; struct event listevent[nproc][NBMAXEVENT]; #define DEBUG_INFO 1 #define DEBUG_VERBOSE 2 #define DEBUG_ALL 3 #ifndef nb_modules #define nb_modules 1 #endif char* libpath; #if nb_modules > 1 void __set_libpath() __attribute__((constructor)); void __set_libpath() { // handle the situation when more than one module is required char arr[512]; // get the old path and complete it by adding TOP_BUILDDIR strcpy(arr, path); libpath = malloc(sizeof(arr) + nb_modules * sizeof(TOP_BUILDDIR)); char *ptr = strtok(arr, ":"); strcat(libpath, TOP_BUILDDIR); strcat(libpath, (const char *) ptr); ptr = strtok(NULL, ":"); while (ptr != NULL) { strcat(libpath, ":"); strcat(libpath, TOP_BUILDDIR); strcat(libpath, (const char *) ptr); ptr = strtok(NULL, ":"); } } #endif /* function that delete all files created */ void clean() { int j; for (j = 0; j < nproc; j++) { unlink(trace[j]); unlink(filecode[j]); unlink(fileref[j]); unlink(filetime[j]); unlink(filearg1[j]); unlink(filearg2[j]); unlink("eztrace_output.trace"); } if (debug >= DEBUG_VERBOSE) fprintf(stderr, "all files deleted\n"); } /* function that return the number of the event choose for each proc, also complete the table of real event */ int getnbevent(int index, int numproc) { int i; FILE *fic, *fic2, *fic3, *fic4; int nb_event = 0; char ligne[128], ligne2[128], ligne3[128], ligne4[128]; char buffertime[25]; unsigned long long int time; // opening files fic = fopen(filecode[numproc], "r"); // ouvrir en lecture fic2 = fopen(filetime[numproc], "r"); fic3 = fopen(filearg1[numproc], "r"); fic4 = fopen(filearg2[numproc], "r"); if (fic == NULL || fic2 == NULL || fic3 == NULL || fic4 == NULL) { fprintf(stderr, "can't open one file in function getnbevent()\n"); return -1; } // count event and do the work nb_event = 0; while (fgets(ligne, 512, fic) != NULL) { assert(fgets(ligne2, 512, fic2) != NULL); assert(fgets(ligne3, 512, fic3) != NULL); assert(fgets(ligne4, 512, fic4) != NULL); if (strncmp(ligne, listevent[numproc][index].code, 5) == 0) { strncpy(buffertime, ligne2, 15); buffertime[15] = '\0'; time = atol(buffertime); listevent[numproc][index].tab_realevent[nb_event].time = time; #warning TODO: the way we retrieve parameters doesnt work with litl listevent[numproc][index].tab_realevent[nb_event].arg1 = atoi(ligne3); listevent[numproc][index].tab_realevent[nb_event].arg2 = atoi(ligne4); if (debug >= DEBUG_ALL) fprintf(stderr, "%d event %s found with time = %llu , arg1 = %d , arg2 = %d\n", nb_event + 1, listevent[numproc][index].code, listevent[numproc][index].tab_realevent[nb_event].time, listevent[numproc][index].tab_realevent[nb_event].arg1, listevent[numproc][index].tab_realevent[nb_event].arg2); nb_event++; } } listevent[numproc][index].tab_realevent[nb_event].time = 0; // closing files if (fclose(fic) == EOF || fclose(fic2) == EOF || fclose(fic3) == EOF || fclose(fic4) == EOF) { fprintf(stderr, "Problem closing one file in function getnbevent()\n"); return -1; } return nb_event; } void sysexec(char *cmd, ...) { // Variable length system method char command[1024]; command[0] = 0; va_list ap; va_start(ap, cmd); while (cmd != NULL) { strncat(command, cmd, 1024); cmd = va_arg(ap, char*); } va_end(ap); command[1023] = 0; if (debug >= DEBUG_ALL) fprintf(stderr, "%s\n", command); if (system(command) == -1) { fprintf(stderr, "Command %s failed!\n", command); exit(EXIT_FAILURE); } } /* Function that parse all element of each trace */ void parseevent() { int i; int j; for (j = 0; j < nproc; j++) { snprintf(fileref[j], 25, "testlog%d.txt", j); if (debug >= DEBUG_ALL) fprintf(stderr, "fileref %d = %s\n", j, fileref[j]); } for (j = 0; j < nproc; j++) { snprintf(filecode[j], 25, "testlog%d.txt", j + 100); if (debug >= DEBUG_ALL) fprintf(stderr, "filecode %d = %s\n", j, filecode[j]); snprintf(filetime[j], 25, "testlog%d.txt", j + 200); if (debug >= DEBUG_ALL) fprintf(stderr, "filetime %d = %s\n", j, filetime[j]); snprintf(filearg1[j], 25, "testlog%d.txt", j + 300); if (debug >= DEBUG_ALL) fprintf(stderr, "filearg1 %d = %s\n", j, filearg1[j]); snprintf(filearg2[j], 25, "testlog%d.txt", j + 400); if (debug >= DEBUG_ALL) fprintf(stderr, "filearg2 %d = %s\n", j, filearg2[j]); } for (j = 0; j < nproc; j++) { /* read the binary trace */ sysexec(TL_READ, " -f ", trace[j], " > ", fileref[j], NULL); /* remove the header */ sysexec("sed -i 1,2d ", fileref[j], " >/dev/null", NULL); /* retrieve the code, time and arguments of each event */ sysexec("awk '{print $4}' ", fileref[j], " > ", filecode[j], NULL); sysexec("awk '{print $1}' ", fileref[j], " > ", filetime[j], NULL); sysexec("awk '{print $5}' ", fileref[j], " > ", filearg1[j], NULL); sysexec("awk '{print $6}' ", fileref[j], " > ", filearg2[j], NULL); } /* check if the number of events is the one that we expect */ for (j = 0; j < nproc; j++) { for (i = 0; i < nbdiffevent; i++) { listevent[j][i].realnbofevent = getnbevent(i, j); if (listevent[j][i].realnbofevent != listevent[j][i].nbeventexpected) { fprintf( stderr, "Problem with code %s, expected number : %d, but there is %d event on the trace\n", listevent[j][i].code, listevent[j][i].nbeventexpected, listevent[j][i].realnbofevent); exit(EXIT_FAILURE); } if (debug >= DEBUG_INFO) fprintf(stderr, "code %s have the correct number of events for trace %d\n", listevent[j][i].code, j); } } if (debug >= DEBUG_INFO) fprintf(stderr, "parsing of event finish\n"); } // Test the existence and readability of file void testfilereadable(char *file) { struct stat st; if (stat(file, &st) < 0) { fprintf(stderr, "Can't stat file %s: %s\n", file, strerror(errno)); exit(EXIT_FAILURE); } if ((st.st_mode & S_IRUSR) == 0) { fprintf(stderr, "File %s is not readable\n", file); exit(EXIT_FAILURE); } } /* function that check the creation of all trace */ void testbintracecreation() { int j; for (j = 0; j < nproc; j++) { testfilereadable(trace[j]); if (debug >= DEBUG_INFO) fprintf(stderr, "trace[%d] correctly created\n", j); } if (debug >= DEBUG_INFO) fprintf(stderr, "bintrace correctly creates\n"); } // Parse common information from the environment static inline void parseenv() { /* debug info */ char *buffer = getenv("DEBUG_LEVEL"); if (buffer != NULL) debug = atoi(buffer); if (debug <= 0) setenv("EZTRACE_DEBUG", "-1", 1); /* bug on hydra, don't know why... else if(debug > 2) { setenv("EZTRACE_DEBUG", "2", 1); } */ /* we need some environment variable to retrieve the trace name */ if (getenv("USER") == NULL) setenv("USER", "foo", 1); strcpy(user, getenv("USER")); // The path assert(getcwd(pwd, sizeof(pwd)) != NULL); } // Actually run eztrace static inline void run_eztrace() { if (debug >= DEBUG_INFO) { if (nb_modules > 1) fprintf(stderr, "libpath= %s\n", libpath); else fprintf(stderr, "libpath= %s%s\n", TOP_BUILDDIR, path); } /* We execute the program with eztrace with the correct module*/ char *devnull = (debug == 0) ? " 2>/dev/null" : ""; if (nproc == 1) // without MPI if (nb_modules > 1) sysexec(eztrace_extra "EZTRACE_LIBRARY_PATH=", libpath, " EZTRACE_TRACE=", module, " ", EZTRACE, " -p ", TOP_BUILDDIR, nameprog, devnull, NULL); else sysexec(eztrace_extra "EZTRACE_LIBRARY_PATH=", TOP_BUILDDIR, path, " EZTRACE_TRACE=", module, " ", EZTRACE, " -p ", TOP_BUILDDIR, nameprog, devnull, NULL); else { // with MPI char numbuf[4]; sprintf(numbuf, "%d", nproc); if (nb_modules > 1) sysexec(eztrace_extra "EZTRACE_LIBRARY_PATH=", libpath, " EZTRACE_TRACE=", module, " mpirun -np ", numbuf, " ", EZTRACE, " -p ", TOP_BUILDDIR, nameprog, devnull, NULL); else sysexec(eztrace_extra "EZTRACE_LIBRARY_PATH=", TOP_BUILDDIR, path, " EZTRACE_TRACE=", module, " mpirun -np ", numbuf, " ", EZTRACE, " -p ", TOP_BUILDDIR, nameprog, devnull, NULL); } } // Run eztrace_convert static inline void run_eztrace_convert() { char traces[2048]; int i; traces[0] = 0; for (i = 0; i < nproc; i++) { strncat(traces, " ", 2048); strncat(traces, trace[i], 2048); } if (debug >= DEBUG_INFO) { if (nb_modules > 1) fprintf(stderr, "libpath= %s\n", libpath); else fprintf(stderr, "libpath= %s%s\n", TOP_BUILDDIR, path); } /* We execute the program with eztrace_convert with the correct module*/ char *devnull = (debug == 0) ? " 2>/dev/null >/dev/null" : ""; if (nb_modules > 1) sysexec("EZTRACE_LIBRARY_PATH=", libpath, " EZTRACE_TRACE=", module, " ", EZTRACE_CONVERT, traces, devnull, NULL); else sysexec("EZTRACE_LIBRARY_PATH=", TOP_BUILDDIR, path, " EZTRACE_TRACE=", module, " ", EZTRACE_CONVERT, traces, devnull, NULL); testfilereadable("eztrace_output.trace"); if (debug >= DEBUG_INFO) fprintf(stderr, "eztrace_convert ran with success!\n"); } // Fetch the traces static inline void fetch_traces() { char* trace_dir = "/tmp"; char buffertrace[256]; int i; if (getenv("EZTRACE_TRACE_DIR") != NULL) trace_dir = getenv("EZTRACE_TRACE_DIR"); if (debug >= DEBUG_VERBOSE) fprintf(stderr, "trace_dir = %s\n", trace_dir); snprintf(buffertrace, 256, "%s/%s_eztrace_log_rank_", trace_dir, user); if (nproc == 1) { snprintf(trace[0], 256, "%s1", buffertrace); if (debug >= DEBUG_VERBOSE) fprintf(stderr, "trace = %s\n", trace[0]); } else { for (i = 0; i < nproc; i++) { snprintf(trace[i], 256, "%s%d", buffertrace, i); if (debug >= DEBUG_VERBOSE) fprintf(stderr, "trace[%d] = %s\n", i, trace[i]); } } /* We need to check if the traces are created */ testbintracecreation(); } // test for pthread module /*Function use to make some test on pthread event */ void testpthread() { if (listevent[0][1].realnbofevent != listevent[0][2].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][0].code); exit(EXIT_FAILURE); } if (listevent[0][3].realnbofevent != listevent[0][4].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][1].code); exit(EXIT_FAILURE); } if (listevent[0][9].realnbofevent != listevent[0][10].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][2].code); exit(EXIT_FAILURE); } if (listevent[0][14].realnbofevent != listevent[0][15].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][3].code); exit(EXIT_FAILURE); } if (listevent[0][16].realnbofevent != listevent[0][17].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][4].code); exit(EXIT_FAILURE); } if (listevent[0][18].realnbofevent != listevent[0][19].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][5].code); exit(EXIT_FAILURE); } if (listevent[0][21].realnbofevent != listevent[0][22].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (debug >= DEBUG_INFO) fprintf(stderr, "test pthread finished\n"); } #endif // defined(__TESTCOMMON_H)_ eztrace-1.1-2/test/automake/testmemory.c000066400000000000000000000024571265506773700203420ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #define nproc 1 #define nameprog "test/memory/memory" #define NBMAXEVENT 55 #define NBMAXREALEVENT 85 #define module "memory" #define path "/src/modules/memory/.libs" #include "testcommon.h" /* Function use to init the event structure */ void init_tabevent() { int j; nbdiffevent = 0; for (j = 0; j < nproc; j++) { listevent[j][0].code = "50001"; listevent[j][0].nbeventexpected = 40; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][1].code = "50002"; listevent[j][1].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][2].code = "50003"; listevent[j][2].nbeventexpected = 10; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][3].code = "50010"; listevent[j][3].nbeventexpected = 40; } nbdiffevent++; } /* The main function */ int main() { parseenv(); run_eztrace(); fetch_traces(); /* Before checking the bintrace we need to init the structur of event */ init_tabevent(); /*After that we retrieve the event of the trace */ parseevent(); // Check for eztrace_convert success run_eztrace_convert(); clean(); return EXIT_SUCCESS; } eztrace-1.1-2/test/automake/testmpiring.c000066400000000000000000000524371265506773700205020ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #define nproc 3 #define nameprog "./test/mpi/mpi_ring" #define NBMAXEVENT 85 #define NBMAXREALEVENT 50 #define module "mpi" #define path "/src/modules/mpi/.libs" #include "testcommon.h" /* Function use to init the event structure */ void init_tabevent() { int j; nbdiffevent = 0; for (j = 0; j < nproc; j++) { listevent[j][0].code = "40010"; listevent[j][0].nbeventexpected = 1; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][1].code = "40001"; listevent[j][1].nbeventexpected = 10; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][2].code = "40002"; listevent[j][2].nbeventexpected = 10; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][3].code = "40003"; listevent[j][3].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][4].code = "40004"; listevent[j][4].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][5].code = "40005"; listevent[j][5].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][6].code = "40006"; listevent[j][6].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][7].code = "40007"; listevent[j][7].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][8].code = "40008"; listevent[j][8].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][9].code = "4000a"; listevent[j][9].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][10].code = "4000b"; listevent[j][10].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][11].code = "4000c"; listevent[j][11].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][12].code = "4000d"; listevent[j][12].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][13].code = "40101"; listevent[j][13].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][14].code = "40103"; listevent[j][14].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][15].code = "40105"; listevent[j][15].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][16].code = "40107"; listevent[j][16].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][17].code = "40201"; listevent[j][17].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][18].code = "40202"; listevent[j][18].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][19].code = "40203"; listevent[j][19].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][20].code = "40204"; listevent[j][20].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { // mpi_start_recv listevent[j][21].code = "41003"; listevent[j][21].nbeventexpected = 10; } nbdiffevent++; for (j = 0; j < nproc; j++) { // mpi_stop_recv listevent[j][22].code = "41004"; listevent[j][22].nbeventexpected = 10; } for (j = 0; j < nproc; j++) { // mpi_irecv listevent[j][23].code = "41005"; listevent[j][23].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][24].code = "42001"; listevent[j][24].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][25].code = "42002"; listevent[j][25].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][26].code = "42003"; listevent[j][26].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][27].code = "42004"; listevent[j][27].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][28].code = "42005"; listevent[j][28].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][29].code = "42006"; listevent[j][29].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][30].code = "42007"; listevent[j][30].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][31].code = "42008"; listevent[j][31].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][32].code = "42009"; listevent[j][32].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][33].code = "4200a"; listevent[j][33].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][34].code = "4200b"; listevent[j][34].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][35].code = "43101"; listevent[j][35].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][36].code = "43001"; listevent[j][36].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][37].code = "43002"; listevent[j][37].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][38].code = "43003"; listevent[j][38].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][39].code = "43004"; listevent[j][39].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][40].code = "43005"; listevent[j][40].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][41].code = "43006"; listevent[j][41].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][42].code = "43007"; listevent[j][42].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][43].code = "43008"; listevent[j][43].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][44].code = "43009"; listevent[j][44].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][45].code = "4300a"; listevent[j][45].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][46].code = "4300b"; listevent[j][46].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][47].code = "4300c"; listevent[j][47].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][48].code = "4300d"; listevent[j][48].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][49].code = "4300e"; listevent[j][49].nbeventexpected = 11; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][50].code = "43011"; listevent[j][50].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][51].code = "43012"; listevent[j][51].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][52].code = "43013"; listevent[j][52].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][53].code = "43014"; listevent[j][53].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][54].code = "43015"; listevent[j][54].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][55].code = "43016"; listevent[j][55].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][56].code = "43017"; listevent[j][56].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][57].code = "43018"; listevent[j][57].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][58].code = "43019"; listevent[j][58].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][59].code = "4301a"; listevent[j][59].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][60].code = "4301b"; listevent[j][60].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][61].code = "4301c"; listevent[j][61].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][62].code = "4301d"; listevent[j][62].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][63].code = "4301e"; listevent[j][63].nbeventexpected = 11; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][64].code = "44001"; listevent[j][64].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][65].code = "44002"; listevent[j][65].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][66].code = "45001"; listevent[j][66].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][67].code = "45002"; listevent[j][67].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][68].code = "45003"; listevent[j][68].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][69].code = "45004"; listevent[j][69].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][70].code = "45010"; listevent[j][70].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][71].code = "45100"; listevent[j][71].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][72].code = "49999"; listevent[j][72].nbeventexpected = 0; } nbdiffevent++; //init the event table; } /* function that test MPI communication */ void mpisendrecv() { /* FIXME: * This test doesn't work anymore with litl because of the way litl_print * prints the parameters */ return; int i; int index2; int proc = 0; int index; long long int timecom; for (i = 0; i < nproc; i++) { for (proc = 0; proc < nproc; proc++) { index = 0; index2 = 0; if (proc != i) { if (debug >= DEBUG_VERBOSE) fprintf(stderr, "send/recv test from trace %d to trace %d\n", i, proc); while (index < listevent[i][1].realnbofevent) { if (listevent[i][1].tab_realevent[index].arg2 == proc) { if (debug >= DEBUG_VERBOSE) fprintf(stderr, "send found from trace %d to trace %d\n", i, proc); if (index2 == listevent[proc][22].realnbofevent) { fprintf( stderr, "Problem in logged communication between %d and %d, there is a send from %d but no recv\n", i, proc, i); exit(EXIT_FAILURE); } while (index2 < listevent[proc][22].realnbofevent) { if (listevent[proc][22].tab_realevent[index2].arg2 == i) { timecom = listevent[proc][22].tab_realevent[index2].time - listevent[i][1].tab_realevent[index].time; if (timecom < 0) { fprintf( stderr, "problem during communication from %d to %d, negative time =%lli\n", i, proc, timecom); return EXIT_FAILURE; } if (debug >= DEBUG_VERBOSE) { fprintf(stderr, "time of send = %llu\n", listevent[i][1].tab_realevent[index].time); fprintf(stderr, "time of recv = %llu\n", listevent[proc][22].tab_realevent[index2].time); fprintf( stderr, "MPI comm detected, msg send from %d to %d, time of the communication = %lli\n", i, proc, timecom); } index2++; break; } index2++; if (debug >= DEBUG_VERBOSE) fprintf(stderr, "%d & %d \n", index2, listevent[proc][22].realnbofevent); if (index2 == listevent[proc][22].realnbofevent) { fprintf( stderr, "Problem in communication between %d and %d, there is a send from %d but no recv\n", i, proc, i); exit(EXIT_FAILURE); } } } index++; } } } } // we do the same for recv for (i = 0; i < nproc; i++) { for (proc = 0; proc < nproc; proc++) { index = 0; index2 = 0; if (proc != i) { if (debug >= DEBUG_VERBOSE) fprintf(stderr, "recv/send test from trace %d to trace %d\n", i, proc); while (index < listevent[i][22].realnbofevent) { if (listevent[i][22].tab_realevent[index].arg2 == proc) { if (debug >= DEBUG_VERBOSE) fprintf(stderr, "recv found from trace %d to trace %d\n", i, proc); if (index2 == listevent[proc][1].realnbofevent) { fprintf( stderr, "Problem in communication between %d and %d, there is recv from %d but no send\n", i, proc, i); exit(EXIT_FAILURE); } while (index2 < listevent[proc][1].realnbofevent) { if (listevent[proc][1].tab_realevent[index2].arg2 == i) { timecom = listevent[i][22].tab_realevent[index].time - listevent[proc][1].tab_realevent[index2].time; if (timecom < 0) { fprintf( stderr, "problem during communication from %d to %d, negative time =%lli\n", i, proc, timecom); return EXIT_FAILURE; } if (debug >= DEBUG_VERBOSE) { fprintf(stderr, "time of send = %llu\n", listevent[i][22].tab_realevent[index].time); fprintf(stderr, "time of recv = %llu\n", listevent[proc][1].tab_realevent[index2].time); fprintf( stderr, "MPI comm detected, msg send from %d to %d, time of the communication = %lli\n", i, proc, timecom); } index2++; break; } index2++; fprintf(stderr, "%d et %d \n", index2, listevent[proc][1].realnbofevent); if (index2 == listevent[proc][1].realnbofevent) { fprintf( stderr, "Problem in communication between %d and %d, there is a recv from %d but no send\n", i, proc, i); exit(EXIT_FAILURE); } } } index++; } } } } if (debug >= DEBUG_INFO) fprintf(stderr, "mpi communication test finished\n"); } /*Function use to make some test on mpi event */ int testmpi() { if (listevent[0][1].realnbofevent != listevent[0][2].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][0].code); exit(EXIT_FAILURE); } if (listevent[0][3].realnbofevent != listevent[0][4].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][1].code); exit(EXIT_FAILURE); } if (listevent[0][5].realnbofevent != listevent[0][6].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][2].code); exit(EXIT_FAILURE); } if (listevent[0][7].realnbofevent != listevent[0][8].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][3].code); exit(EXIT_FAILURE); } if (listevent[0][9].realnbofevent != listevent[0][10].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][4].code); exit(EXIT_FAILURE); } if (listevent[0][11].realnbofevent != listevent[0][12].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][5].code); exit(EXIT_FAILURE); } if (listevent[0][17].realnbofevent != listevent[0][18].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][19].realnbofevent != listevent[0][20].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][5].code); exit(EXIT_FAILURE); } if (listevent[0][21].realnbofevent != listevent[0][22].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][24].realnbofevent != listevent[0][25].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][27].realnbofevent != listevent[0][28].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][31].realnbofevent != listevent[0][32].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][33].realnbofevent != listevent[0][34].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][36].realnbofevent != listevent[0][50].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][2].code); exit(EXIT_FAILURE); } if (listevent[0][37].realnbofevent != listevent[0][51].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][3].code); exit(EXIT_FAILURE); } if (listevent[0][38].realnbofevent != listevent[0][52].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][4].code); exit(EXIT_FAILURE); } if (listevent[0][39].realnbofevent != listevent[0][53].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][5].code); exit(EXIT_FAILURE); } if (listevent[0][40].realnbofevent != listevent[0][54].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][41].realnbofevent != listevent[0][55].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][5].code); exit(EXIT_FAILURE); } if (listevent[0][42].realnbofevent != listevent[0][56].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][43].realnbofevent != listevent[0][57].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][44].realnbofevent != listevent[0][58].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][45].realnbofevent != listevent[0][59].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][46].realnbofevent != listevent[0][60].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][47].realnbofevent != listevent[0][61].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][48].realnbofevent != listevent[0][62].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][49].realnbofevent != listevent[0][63].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (debug >= DEBUG_INFO) fprintf(stderr, "test mpi finished\n"); } /* The main function */ int main() { parseenv(); run_eztrace(); fetch_traces(); /* Before checking the bintrace we need to init the structur of event */ init_tabevent(); /*After that we retrieve the event of the trace */ parseevent(); testmpi(); // Check for eztrace_convert success run_eztrace_convert(); if (nproc > 1) { // special test for mpi communication mpisendrecv(); } clean(); return EXIT_SUCCESS; } eztrace-1.1-2/test/automake/testopenmplock.c000066400000000000000000000175531265506773700212040ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #define nproc 1 #define nameprog "test/pthread/cond" #define NBMAXEVENT 55 #define NBMAXREALEVENT 85 #define module "pthread" #define path "/src/modules/omp/.libs" #include "testcommon.h" /* Function use to init the event structure */ void init_tabevent() { int j; nbdiffevent = 0; for (j = 0; j < nproc; j++) { listevent[j][0].code = "10001"; listevent[j][0].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][1].code = "10002"; listevent[j][1].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][2].code = "10003"; listevent[j][2].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][3].code = "10004"; listevent[j][3].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][4].code = "10005"; listevent[j][4].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][5].code = "10006"; listevent[j][5].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][6].code = "10007"; listevent[j][6].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][7].code = "1ffff"; listevent[j][7].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][8].code = "10010"; listevent[j][8].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][9].code = "10011"; listevent[j][9].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][10].code = "10020"; listevent[j][10].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][11].code = "10021"; listevent[j][11].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][12].code = "10030"; listevent[j][12].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][13].code = "10031"; listevent[j][13].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][14].code = "10040"; listevent[j][14].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][15].code = "10041"; listevent[j][15].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][16].code = "10042"; listevent[j][16].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][17].code = "10043"; listevent[j][17].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][18].code = "10050"; listevent[j][18].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][19].code = "10051"; listevent[j][19].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][20].code = "10060"; listevent[j][20].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][21].code = "10061"; listevent[j][21].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][22].code = "10070"; listevent[j][22].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][23].code = "10071"; listevent[j][23].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][24].code = "10072"; listevent[j][24].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][25].code = "10073"; listevent[j][25].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][26].code = "10080"; listevent[j][26].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][27].code = "10081"; listevent[j][27].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][28].code = "10082"; listevent[j][28].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][29].code = "10083"; listevent[j][29].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][30].code = "10090"; listevent[j][30].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][31].code = "10091"; listevent[j][31].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][32].code = "10092"; listevent[j][32].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][33].code = "10093"; listevent[j][33].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][34].code = "100a0"; listevent[j][34].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][35].code = "100a1"; listevent[j][35].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][36].code = "100b0"; listevent[j][36].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][37].code = "100b1"; listevent[j][37].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][38].code = "100b2"; listevent[j][38].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][39].code = "100b3"; listevent[j][39].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][40].code = "100b4"; listevent[j][40].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][41].code = "100b5"; listevent[j][41].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][42].code = "100b6"; listevent[j][42].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][43].code = "100b7"; listevent[j][43].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][44].code = "100b8"; listevent[j][44].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][45].code = "100b9"; listevent[j][45].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][46].code = "100ba"; listevent[j][46].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][47].code = "10101"; listevent[j][47].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][48].code = "10102"; listevent[j][48].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][49].code = "10103"; listevent[j][49].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][50].code = "10104"; listevent[j][50].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][51].code = "10111"; listevent[j][51].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][52].code = "10112"; listevent[j][52].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][53].code = "10113"; listevent[j][53].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][54].code = "10114"; listevent[j][54].nbeventexpected = 0; } nbdiffevent++; } /* The main function */ int main() { parseenv(); run_eztrace(); fetch_traces(); /* Before checking the bintrace we need to init the structur of event */ init_tabevent(); /*After that we retrieve the event of the trace */ parseevent(); // Check for eztrace_convert success run_eztrace_convert(); clean(); return EXIT_SUCCESS; } eztrace-1.1-2/test/automake/testopenmpnestlock.c000066400000000000000000000176251265506773700220760ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #define eztrace_extra "OMP_NUM_THREADS=2 " #define nproc 1 #define nameprog "test/pthread/cond" #define NBMAXEVENT 55 #define NBMAXREALEVENT 85 #define module "pthread" #define path "/src/modules/omp/.libs" #include "testcommon.h" /* Function use to init the event structure */ void init_tabevent() { int j; nbdiffevent = 0; for (j = 0; j < nproc; j++) { listevent[j][0].code = "10001"; listevent[j][0].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][1].code = "10002"; listevent[j][1].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][2].code = "10003"; listevent[j][2].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][3].code = "10004"; listevent[j][3].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][4].code = "10005"; listevent[j][4].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][5].code = "10006"; listevent[j][5].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][6].code = "10007"; listevent[j][6].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][7].code = "1ffff"; listevent[j][7].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][8].code = "10010"; listevent[j][8].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][9].code = "10011"; listevent[j][9].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][10].code = "10020"; listevent[j][10].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][11].code = "10021"; listevent[j][11].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][12].code = "10030"; listevent[j][12].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][13].code = "10031"; listevent[j][13].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][14].code = "10040"; listevent[j][14].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][15].code = "10041"; listevent[j][15].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][16].code = "10042"; listevent[j][16].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][17].code = "10043"; listevent[j][17].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][18].code = "10050"; listevent[j][18].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][19].code = "10051"; listevent[j][19].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][20].code = "10060"; listevent[j][20].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][21].code = "10061"; listevent[j][21].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][22].code = "10070"; listevent[j][22].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][23].code = "10071"; listevent[j][23].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][24].code = "10072"; listevent[j][24].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][25].code = "10073"; listevent[j][25].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][26].code = "10080"; listevent[j][26].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][27].code = "10081"; listevent[j][27].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][28].code = "10082"; listevent[j][28].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][29].code = "10083"; listevent[j][29].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][30].code = "10090"; listevent[j][30].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][31].code = "10091"; listevent[j][31].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][32].code = "10092"; listevent[j][32].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][33].code = "10093"; listevent[j][33].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][34].code = "100a0"; listevent[j][34].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][35].code = "100a1"; listevent[j][35].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][36].code = "100b0"; listevent[j][36].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][37].code = "100b1"; listevent[j][37].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][38].code = "100b2"; listevent[j][38].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][39].code = "100b3"; listevent[j][39].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][40].code = "100b4"; listevent[j][40].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][41].code = "100b5"; listevent[j][41].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][42].code = "100b6"; listevent[j][42].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][43].code = "100b7"; listevent[j][43].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][44].code = "100b8"; listevent[j][44].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][45].code = "100b9"; listevent[j][45].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][46].code = "100ba"; listevent[j][46].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][47].code = "10101"; listevent[j][47].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][48].code = "10102"; listevent[j][48].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][49].code = "10103"; listevent[j][49].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][50].code = "10104"; listevent[j][50].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][51].code = "10111"; listevent[j][51].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][52].code = "10112"; listevent[j][52].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][53].code = "10113"; listevent[j][53].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][54].code = "10114"; listevent[j][54].nbeventexpected = 0; } nbdiffevent++; } /* The main function */ int main() { parseenv(); run_eztrace(); fetch_traces(); /* Before checking the bintrace we need to init the structur of event */ init_tabevent(); /*After that we retrieve the event of the trace */ parseevent(); // Check for eztrace_convert success run_eztrace_convert(); clean(); return EXIT_SUCCESS; } eztrace-1.1-2/test/automake/testopenmpsimple.c000066400000000000000000000176331265506773700215440ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #define eztrace_extra "OMP_NUM_THREADS=2 " #define nproc 1 #define nameprog "test/openmp/openmp_simple" #define NBMAXEVENT 55 #define NBMAXREALEVENT 85 #define module "omp" #define path "/src/modules/omp/.libs" #include "testcommon.h" /* Function use to init the event structure */ void init_tabevent() { int j; nbdiffevent = 0; for (j = 0; j < nproc; j++) { listevent[j][0].code = "10001"; listevent[j][0].nbeventexpected = 9; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][1].code = "10002"; listevent[j][1].nbeventexpected = 18; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][2].code = "10003"; listevent[j][2].nbeventexpected = 18; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][3].code = "10004"; listevent[j][3].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][4].code = "10005"; listevent[j][4].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][5].code = "10006"; listevent[j][5].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][6].code = "10007"; listevent[j][6].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][7].code = "1ffff"; listevent[j][7].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][8].code = "10010"; listevent[j][8].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][9].code = "10011"; listevent[j][9].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][10].code = "10020"; listevent[j][10].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][11].code = "10021"; listevent[j][11].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][12].code = "10030"; listevent[j][12].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][13].code = "10031"; listevent[j][13].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][14].code = "10040"; listevent[j][14].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][15].code = "10041"; listevent[j][15].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][16].code = "10042"; listevent[j][16].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][17].code = "10043"; listevent[j][17].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][18].code = "10050"; listevent[j][18].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][19].code = "10051"; listevent[j][19].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][20].code = "10060"; listevent[j][20].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][21].code = "10061"; listevent[j][21].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][22].code = "10070"; listevent[j][22].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][23].code = "10071"; listevent[j][23].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][24].code = "10072"; listevent[j][24].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][25].code = "10073"; listevent[j][25].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][26].code = "10080"; listevent[j][26].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][27].code = "10081"; listevent[j][27].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][28].code = "10082"; listevent[j][28].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][29].code = "10083"; listevent[j][29].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][30].code = "10090"; listevent[j][30].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][31].code = "10091"; listevent[j][31].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][32].code = "10092"; listevent[j][32].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][33].code = "10093"; listevent[j][33].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][34].code = "100a0"; listevent[j][34].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][35].code = "100a1"; listevent[j][35].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][36].code = "100b0"; listevent[j][36].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][37].code = "100b1"; listevent[j][37].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][38].code = "100b2"; listevent[j][38].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][39].code = "100b3"; listevent[j][39].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][40].code = "100b4"; listevent[j][40].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][41].code = "100b5"; listevent[j][41].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][42].code = "100b6"; listevent[j][42].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][43].code = "100b7"; listevent[j][43].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][44].code = "100b8"; listevent[j][44].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][45].code = "100b9"; listevent[j][45].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][46].code = "100ba"; listevent[j][46].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][47].code = "10101"; listevent[j][47].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][48].code = "10102"; listevent[j][48].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][49].code = "10103"; listevent[j][49].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][50].code = "10104"; listevent[j][50].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][51].code = "10111"; listevent[j][51].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][52].code = "10112"; listevent[j][52].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][53].code = "10113"; listevent[j][53].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][54].code = "10114"; listevent[j][54].nbeventexpected = 0; } nbdiffevent++; } /* The main function */ int main() { parseenv(); run_eztrace(); fetch_traces(); /* Before checking the bintrace we need to init the structur of event */ init_tabevent(); /*After that we retrieve the event of the trace */ parseevent(); // Check for eztrace_convert success run_eztrace_convert(); clean(); return EXIT_SUCCESS; } eztrace-1.1-2/test/automake/testpthreadcond.c000066400000000000000000000073771265506773700213330ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #define nproc 1 #define nameprog "test/pthread/cond" #define NBMAXEVENT 55 #define NBMAXREALEVENT 85 #define module "pthread" #define path "/src/modules/pthread/.libs" #include "testcommon.h" /* Function use to init the event structure */ void init_tabevent() { int j; nbdiffevent = 0; for (j = 0; j < nproc; j++) { listevent[j][0].code = "20010"; listevent[j][0].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][1].code = "20011"; listevent[j][1].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][2].code = "20012"; listevent[j][2].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][3].code = "20020"; listevent[j][3].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][4].code = "20021"; listevent[j][4].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][5].code = "20022"; listevent[j][5].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][6].code = "20023"; listevent[j][6].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][7].code = "20030"; listevent[j][7].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][8].code = "20031"; listevent[j][8].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][9].code = "20033"; listevent[j][9].nbeventexpected = 1; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][10].code = "20034"; listevent[j][10].nbeventexpected = 1; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][11].code = "20035"; listevent[j][11].nbeventexpected = 1; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][12].code = "20040"; listevent[j][12].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][13].code = "20041"; listevent[j][13].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][14].code = "20042"; listevent[j][14].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][15].code = "20043"; listevent[j][15].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][16].code = "20050"; listevent[j][16].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][17].code = "20051"; listevent[j][17].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][18].code = "20052"; listevent[j][18].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][19].code = "20053"; listevent[j][19].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][20].code = "20054"; listevent[j][20].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][21].code = "20060"; listevent[j][21].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][22].code = "20061"; listevent[j][22].nbeventexpected = 0; } nbdiffevent++; } /* The main function */ int main() { parseenv(); run_eztrace(); fetch_traces(); /* Before checking the bintrace we need to init the structur of event */ init_tabevent(); /*After that we retrieve the event of the trace */ parseevent(); testpthread(); // Check for eztrace_convert success run_eztrace_convert(); clean(); return EXIT_SUCCESS; } eztrace-1.1-2/test/automake/testpthreaddummy_thread.c000066400000000000000000000074151265506773700230630ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #define nproc 1 #define nameprog "test/pthread/dummy_thread" #define NBMAXEVENT 55 #define NBMAXREALEVENT 85 #define module "pthread" #define path "/src/modules/pthread/.libs" #include "testcommon.h" /* Function use to init the event structure */ void init_tabevent() { int j; nbdiffevent = 0; for (j = 0; j < nproc; j++) { listevent[j][0].code = "20010"; listevent[j][0].nbeventexpected = 23; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][1].code = "20011"; listevent[j][1].nbeventexpected = 22; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][2].code = "20012"; listevent[j][2].nbeventexpected = 22; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][3].code = "20020"; listevent[j][3].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][4].code = "20021"; listevent[j][4].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][5].code = "20022"; listevent[j][5].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][6].code = "20023"; listevent[j][6].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][7].code = "20030"; listevent[j][7].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][8].code = "20031"; listevent[j][8].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][9].code = "20033"; listevent[j][9].nbeventexpected = 20; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][10].code = "20034"; listevent[j][10].nbeventexpected = 20; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][11].code = "20035"; listevent[j][11].nbeventexpected = 20; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][12].code = "20040"; listevent[j][12].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][13].code = "20041"; listevent[j][13].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][14].code = "20042"; listevent[j][14].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][15].code = "20043"; listevent[j][15].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][16].code = "20050"; listevent[j][16].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][17].code = "20051"; listevent[j][17].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][18].code = "20052"; listevent[j][18].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][19].code = "20053"; listevent[j][19].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][20].code = "20054"; listevent[j][20].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][21].code = "20060"; listevent[j][21].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][22].code = "20061"; listevent[j][22].nbeventexpected = 0; } nbdiffevent++; } /* The main function */ int main() { parseenv(); run_eztrace(); fetch_traces(); /* Before checking the bintrace we need to init the structur of event */ init_tabevent(); /*After that we retrieve the event of the trace */ parseevent(); testpthread(); // Check for eztrace_convert success run_eztrace_convert(); clean(); return EXIT_SUCCESS; } eztrace-1.1-2/test/automake/testpthreadtest.c000066400000000000000000000074251265506773700213610ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #define nproc 1 #define nameprog "test/pthread/test_pthread" #define NBMAXEVENT 55 #define NBMAXREALEVENT 85 #define module "pthread" #define path "/src/modules/pthread/.libs" #include "testcommon.h" /* Function use to init the event structure */ void init_tabevent() { int j; nbdiffevent = 0; for (j = 0; j < nproc; j++) { listevent[j][0].code = "20010"; listevent[j][0].nbeventexpected = 23; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][1].code = "20011"; listevent[j][1].nbeventexpected = 22; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][2].code = "20012"; listevent[j][2].nbeventexpected = 22; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][3].code = "20020"; listevent[j][3].nbeventexpected = 40; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][4].code = "20021"; listevent[j][4].nbeventexpected = 40; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][5].code = "20022"; listevent[j][5].nbeventexpected = 40; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][6].code = "20023"; listevent[j][6].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][7].code = "20030"; listevent[j][7].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][8].code = "20031"; listevent[j][8].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][9].code = "20033"; listevent[j][9].nbeventexpected = 20; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][10].code = "20034"; listevent[j][10].nbeventexpected = 20; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][11].code = "20035"; listevent[j][11].nbeventexpected = 20; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][12].code = "20040"; listevent[j][12].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][13].code = "20041"; listevent[j][13].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][14].code = "20042"; listevent[j][14].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][15].code = "20043"; listevent[j][15].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][16].code = "20050"; listevent[j][16].nbeventexpected = 20; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][17].code = "20051"; listevent[j][17].nbeventexpected = 20; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][18].code = "20052"; listevent[j][18].nbeventexpected = 20; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][19].code = "20053"; listevent[j][19].nbeventexpected = 20; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][20].code = "20054"; listevent[j][20].nbeventexpected = 40; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][21].code = "20060"; listevent[j][21].nbeventexpected = 4; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][22].code = "20061"; listevent[j][22].nbeventexpected = 4; } nbdiffevent++; } /* The main function */ int main() { parseenv(); run_eztrace(); fetch_traces(); /* Before checking the bintrace we need to init the structur of event */ init_tabevent(); /*After that we retrieve the event of the trace */ parseevent(); testpthread(); // Check for eztrace_convert success run_eztrace_convert(); clean(); return EXIT_SUCCESS; } eztrace-1.1-2/test/automake/teststatic.c000066400000000000000000000026131265506773700203130ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #define nproc 1 #define nameprog "test/static/static" #define NBMAXEVENT 50 #define NBMAXREALEVENT 50 #define module "staticlib" #define path "/test/static/.libs" #include "testcommon.h" /* Function use to init the event structure */ void init_tabevent() { int j; nbdiffevent = 0; for (j = 0; j < nproc; j++) { listevent[j][0].code = "990001"; listevent[j][0].nbeventexpected = 8; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][1].code = "990002"; listevent[j][1].nbeventexpected = 8; } nbdiffevent++; } /*Function use to make some test on stdio event */ void teststatic() { if (listevent[0][0].realnbofevent != listevent[0][1].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][0].code); exit(EXIT_FAILURE); } if (debug >= DEBUG_INFO) fprintf(stderr, "test static finished\n"); } /* The main function */ int main() { parseenv(); run_eztrace(); fetch_traces(); /* Before checking the bintrace we need to init the structur of event */ init_tabevent(); /*After that we retrieve the event of the trace */ parseevent(); // checks teststatic(); run_eztrace_convert(); // clean-up clean(); return EXIT_SUCCESS; } eztrace-1.1-2/test/automake/teststdio.c000066400000000000000000000157411265506773700201540ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #define nproc 1 #define nameprog "test/stdio/stdio" #define NBMAXEVENT 50 #define NBMAXREALEVENT 50 #define module "stdio" #define path "/src/modules/stdio/.libs" #include "testcommon.h" /* Function use to init the event structure */ void init_tabevent() { int j; nbdiffevent = 0; for (j = 0; j < nproc; j++) { listevent[j][0].code = "30110"; listevent[j][0].nbeventexpected = 20; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][1].code = "30120"; listevent[j][1].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][2].code = "30130"; listevent[j][2].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][3].code = "30140"; listevent[j][3].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][4].code = "30210"; listevent[j][4].nbeventexpected = 21; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][5].code = "30220"; listevent[j][5].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][6].code = "30230"; listevent[j][6].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][7].code = "30240"; listevent[j][7].nbeventexpected = 0; // (debug > 0) ? 1 : 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][8].code = "30310"; listevent[j][8].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][9].code = "30320"; listevent[j][9].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][10].code = "30330"; listevent[j][10].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][11].code = "30340"; listevent[j][11].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][12].code = "30350"; listevent[j][12].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][13].code = "30111"; listevent[j][13].nbeventexpected = 20; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][14].code = "30121"; listevent[j][14].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][15].code = "30131"; listevent[j][15].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][16].code = "30141"; listevent[j][16].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][17].code = "30211"; listevent[j][17].nbeventexpected = 21; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][18].code = "30221"; listevent[j][18].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][19].code = "30231"; listevent[j][19].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][20].code = "30241"; listevent[j][20].nbeventexpected = 0; // (debug > 0) ? 1 : 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][21].code = "30311"; listevent[j][21].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][22].code = "30321"; listevent[j][22].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][23].code = "30331"; listevent[j][23].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][24].code = "30341"; listevent[j][24].nbeventexpected = 0; } nbdiffevent++; for (j = 0; j < nproc; j++) { listevent[j][25].code = "30351"; listevent[j][25].nbeventexpected = 0; } nbdiffevent++; } /*Function use to make some test on stdio event */ void teststdio() { if (listevent[0][0].realnbofevent != listevent[0][13].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][0].code); exit(EXIT_FAILURE); } if (listevent[0][1].realnbofevent != listevent[0][14].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][1].code); exit(EXIT_FAILURE); } if (listevent[0][2].realnbofevent != listevent[0][15].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][2].code); exit(EXIT_FAILURE); } if (listevent[0][3].realnbofevent != listevent[0][16].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][3].code); exit(EXIT_FAILURE); } if (listevent[0][4].realnbofevent != listevent[0][17].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][4].code); exit(EXIT_FAILURE); } if (listevent[0][5].realnbofevent != listevent[0][18].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][5].code); exit(EXIT_FAILURE); } if (listevent[0][6].realnbofevent != listevent[0][19].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][6].code); exit(EXIT_FAILURE); } if (listevent[0][7].realnbofevent != listevent[0][20].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][7].code); exit(EXIT_FAILURE); } if (listevent[0][8].realnbofevent != listevent[0][21].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][8].code); exit(EXIT_FAILURE); } if (listevent[0][9].realnbofevent != listevent[0][22].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][9].code); exit(EXIT_FAILURE); } if (listevent[0][10].realnbofevent != listevent[0][23].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][10].code); exit(EXIT_FAILURE); } if (listevent[0][11].realnbofevent != listevent[0][24].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][11].code); exit(EXIT_FAILURE); } if (listevent[0][12].realnbofevent != listevent[0][25].realnbofevent) { fprintf(stderr, "Number of start/stop for event %s isn't the same", listevent[0][12].code); exit(EXIT_FAILURE); } if (debug >= DEBUG_INFO) fprintf(stderr, "test stdio finished\n"); } /* The main function */ int main() { parseenv(); run_eztrace(); fetch_traces(); /* Before checking the bintrace we need to init the structur of event */ init_tabevent(); /*After that we retrieve the event of the trace */ parseevent(); teststdio(); // Check for eztrace_convert success run_eztrace_convert(); clean(); return EXIT_SUCCESS; } eztrace-1.1-2/test/memory/000077500000000000000000000000001265506773700154605ustar00rootroot00000000000000eztrace-1.1-2/test/memory/Makefile.am000066400000000000000000000002501265506773700175110ustar00rootroot00000000000000# Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 # See COPYING in top-level directory. check_PROGRAMS = memory memory_SOURCES = memory.c memory_LDFLAGS = -lpthread eztrace-1.1-2/test/memory/Makefile.in000066400000000000000000000463061265506773700175360ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ check_PROGRAMS = memory$(EXEEXT) subdir = test/memory ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am_memory_OBJECTS = memory.$(OBJEXT) memory_OBJECTS = $(am_memory_OBJECTS) memory_LDADD = $(LDADD) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = memory_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(memory_LDFLAGS) $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(memory_SOURCES) DIST_SOURCES = $(memory_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ memory_SOURCES = memory.c memory_LDFLAGS = -lpthread all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu test/memory/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu test/memory/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): clean-checkPROGRAMS: @list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list memory$(EXEEXT): $(memory_OBJECTS) $(memory_DEPENDENCIES) $(EXTRA_memory_DEPENDENCIES) @rm -f memory$(EXEEXT) $(AM_V_CCLD)$(memory_LINK) $(memory_OBJECTS) $(memory_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/memory.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am $(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS) check: check-am all-am: Makefile installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-checkPROGRAMS clean-generic clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: .MAKE: check-am install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ clean-checkPROGRAMS clean-generic clean-libtool cscopelist-am \ ctags ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/test/memory/memory.c000066400000000000000000000061171265506773700171410ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include #include #include #include #include #include /* Number of iterations */ #define ITER 10 /* Number of threads */ #define NTH 2 typedef union { unsigned long long tick; struct { unsigned low; unsigned high; }; } tick_t; int fd[2][2]; sem_t thread_ready; #define TICK_DIFF(t1, t2) \ ((t2).tick - (t1).tick) #define TIME_DIFF(t1, t2) \ ((t2.tv_sec - t1.tv_sec) * 1000000 + (t2.tv_usec - t1.tv_usec)) // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("DEBUG_LEVEL"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 2) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stderr, fmt, va); va_end(va); } } // end of debugging part /* Fake computation of usec microseconds */ void compute(int usec) { struct timeval tv1, tv2; gettimeofday(&tv1, NULL); do { gettimeofday(&tv2, NULL); } while (TIME_DIFF(tv1, tv2) < usec); } void test_malloc() { int i, j; char*buffer[ITER]; for (i = 0; i < ITER; i++) { int alloc_size = (1 + i) * 1024; debug("\tloop %d/%d: allocating %d bytes\n", i, ITER, alloc_size); buffer[i] = malloc(alloc_size); for (j = 0; j < (1 + i) * 1024; j++) { buffer[i][j] = 'a'; } /* compute for 1ms */ compute(50000); free(buffer[i]); compute(10000); } } void test_realloc() { int i, j; char*buffer[ITER]; for (i = 0; i < ITER; i++) { int alloc_size = (1 + i) * 1024; debug("\tloop %d/%d: allocating %d bytes\n", i, ITER, alloc_size); buffer[i] = malloc(alloc_size); for (j = 0; j < (1 + i) * 1024; j++) { buffer[i][j] = 'a'; } /* compute for 1ms */ compute(20000); alloc_size *= 2; debug("\t\tloop %d/%d: reallocating %d bytes\n", i, ITER, alloc_size); buffer[i] = realloc(buffer[i], alloc_size); compute(20000); free(buffer[i]); compute(10000); } } void test_calloc() { int i, j; char*buffer[ITER]; for (i = 0; i < ITER; i++) { int alloc_size = (1 + i) * 1024; debug("\tloop %d/%d: allocating %d bytes\n", i, ITER, alloc_size); buffer[i] = calloc(alloc_size, sizeof(uint8_t)); for (j = 0; j < (1 + i) * 1024; j++) { buffer[i][j] = 'a'; } /* compute for 1ms */ compute(50000); free(buffer[i]); compute(10000); } } int main(int argc, char**argv) { char* buffer[ITER]; int i, j; debug("Testing malloc\n"); test_malloc(); debug("1/2 done\n"); compute(100000); test_malloc(); debug("2/2 done\n"); compute(100000); debug("Testing realloc\n"); test_realloc(); debug("realloc done\n"); compute(100000); debug("Testing calloc\n"); test_calloc(); debug("calloc done\n"); return 0; } eztrace-1.1-2/test/module_generator/000077500000000000000000000000001265506773700175035ustar00rootroot00000000000000eztrace-1.1-2/test/module_generator/example.tpl000066400000000000000000000046461265506773700216710ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. # There are deliberately trailing whitespace everywhere. This # (<-- see?) is for stressing the script parser. # Sorry for the inconvenience. BEGIN_MODULE NAME example_lib DESC "module for the example library" LANGUAGE C ID 09 BEGIN_INCLUDE #include END_INCLUDE int example_do_event( int n) BEGIN EVENT("Do new function") END void appli_function1(double* array, int size) BEGIN RECORD_STATE("running appli_function1") END double example_function1(double* array, int array_size) int example_function2(int* array, int array_size) BEGIN RECORD_STATE("running example_function2") END int example_fcall( int* array, int array_size ) BEGIN CALL_FUNC END int example_push (int* array,int array_size) BEGIN PUSH_STATE("doing function example_push") END int example_event(int* array, int array_size) BEGIN EVENT("example_event called") END int example_set_var(int* array, int array_size) BEGIN SET_VAR("variable name", 5) END int example_add_var(int* array, int array_size) BEGIN ADD_VAR("variable name", 1) END int example_sub_var ( int* array, int array_size) BEGIN SUB_VAR("variable name", 4) END int example_set_var2 ( int* array, int array_size) BEGIN SET_VAR("another variable name", 21) END int example_set_var3( int* array, int array_size) BEGIN ADD_VAR("another variable name", 10) END int example_set_var4( int* array, int array_size) BEGIN SUB_VAR("another variable name", 3) END int example_set_var5( int* array, int array_size) BEGIN SET_VAR("another variable name", 13) END int example_set_var6( int* array, int array_size) BEGIN ADD_VAR("variable name", 2) CALL_FUNC SUB_VAR("variable name", 1) END int example_many_args( int arg1, int arg2, int arg3, int arg4, int arg5, int arg6, int arg7) BEGIN ADD_VAR("variable name", 2) CALL_FUNC SUB_VAR("variable name", 1) END DEFINE_SAMPLING_FUNCTION (example_sampling, 1000) int example_sampling(struct ezt_sampling_callback_instance *instance) { double *ptr = NULL; if(!instance->plugin_data) { instance->plugin_data = malloc(sizeof(double)); ptr = instance->plugin_data; *ptr = 0; } ptr = instance->plugin_data; (*ptr) ++; if(*ptr>1) { SAMPLING_RECORD(*ptr, "Value of PTR"); } return 0; } END_DEFINE END_MODULE eztrace-1.1-2/test/module_generator/example_application/000077500000000000000000000000001265506773700235215ustar00rootroot00000000000000eztrace-1.1-2/test/module_generator/example_application/Makefile000066400000000000000000000006611265506773700251640ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. BIN = libexample.so main CC = gcc CFLAGS = -O0 all: $(BIN) main: main.c example.h $(CC) $(CFLAGS) -o main main.c -L. -lexample libexample.so: example.o $(CC) $(CFLAGS) --shared -o libexample.so example.o -ldl example.o: example.c example.h $(CC) $(CFLAGS) -o example.o -c example.c -fPIC clean: rm -f $(BIN) *.o eztrace-1.1-2/test/module_generator/example_application/example.c000066400000000000000000000032211265506773700253160ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include "example.h" #define TIME_DIFF(t1, t2) \ ((t2.tv_sec - t1.tv_sec) * 1000000 + (t2.tv_usec - t1.tv_usec)) void compute(unsigned usec) { struct timeval tv1, tv2; gettimeofday(&tv1, NULL); do { gettimeofday(&tv2, NULL); } while (TIME_DIFF(tv1, tv2) < usec); } int example_do_event(int n) { fprintf(stderr, "Doing function #%d\n", n); return n + 1; } /* dummy function #1 */ double example_function1(double *array, int array_size) { compute(10); return 0; } /* dummy function #2 */ int example_function2(int *array, int array_size) { compute(10); return 0; } int example_fcall(int *array, int array_size) { compute(10); return 0; } int example_push(int *array, int array_size) { compute(10); return 0; } int example_pop(int *array, int array_size) { compute(10); return 0; } int example_event(int *array, int array_size) { compute(10); return 0; } int example_set_var(int *array, int array_size) { compute(10); return 0; } int example_set_var2(int *array, int array_size) { compute(10); return 0; } int example_set_var3(int *array, int array_size) { compute(10); return 0; } int example_set_var4(int *array, int array_size) { compute(10); return 0; } int example_set_var5(int *array, int array_size) { compute(10); return 0; } int example_add_var(int *array, int array_size) { compute(10); return 0; } int example_sub_var(int *array, int array_size) { compute(10); return 0; } eztrace-1.1-2/test/module_generator/example_application/example.h000066400000000000000000000016571265506773700253360ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #ifndef __EXAMPLE_H__ #define __EXAMPLE_H__ void compute(unsigned usec); int example_do_event(int n); /* dummy function #1 */ double example_function1(double*, int); /* dummy function #2 */ int example_function2(int*, int); int example_fcall(int *array, int array_size); int example_push(int *array, int array_size); int example_pop(int *array, int array_size); int example_event(int *array, int array_size); int example_set_var(int *array, int array_size); int example_add_var(int *array, int array_size); int example_sub_var(int *array, int array_size); int example_set_var2(int *array, int array_size); int example_set_var3(int *array, int array_size); int example_set_var4(int *array, int array_size); int example_set_var5(int *array, int array_size); #endif /* __EXAMPLE_H__ */ eztrace-1.1-2/test/module_generator/example_application/main.c000066400000000000000000000035661265506773700246230ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ /* simple program that calls the libexample library */ #include #include #include "example.h" #define SIZE (1024*1024) void appli_function1(double* array, int size) { fprintf(stderr, "appli function1 (%p, %d)\n", array, size); compute(10); } int main(int argc, char**argv) { double *double_array = NULL; int *int_array = NULL; int func_num = 0; func_num = example_do_event(func_num); example_function1(double_array, SIZE); compute(200000); func_num = example_do_event(func_num); example_function2(int_array, SIZE); compute(200000); func_num = example_do_event(func_num); example_fcall(int_array, SIZE); compute(200000); func_num = example_do_event(func_num); example_push(int_array, SIZE); compute(200000); func_num = example_do_event(func_num); example_pop(int_array, SIZE); compute(200000); func_num = example_do_event(func_num); example_event(int_array, SIZE); compute(200000); func_num = example_do_event(func_num); example_set_var(int_array, SIZE); compute(200000); func_num = example_do_event(func_num); example_add_var(int_array, SIZE); compute(200000); func_num = example_do_event(func_num); example_sub_var(int_array, SIZE); compute(200000); func_num = example_do_event(func_num); example_set_var2(int_array, SIZE); compute(200000); func_num = example_do_event(func_num); example_set_var3(int_array, SIZE); compute(200000); func_num = example_do_event(func_num); example_set_var4(int_array, SIZE); compute(200000); func_num = example_do_event(func_num); example_set_var5(int_array, SIZE); compute(200000); func_num = example_do_event(func_num); appli_function1(double_array, SIZE); compute(200000); return 0; } eztrace-1.1-2/test/mpi/000077500000000000000000000000001265506773700147355ustar00rootroot00000000000000eztrace-1.1-2/test/mpi/Makefile.am000066400000000000000000000004161265506773700167720ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. CC =$(MPICC) AM_CFLAGS = -DWITH_MPI if USE_MPI check_PROGRAMS = mpi_ring mpi_multiring mpi_spawn test_mpi waitall waitany persistent mpi_ping allgather endif eztrace-1.1-2/test/mpi/Makefile.in000066400000000000000000000544641265506773700170170ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @USE_MPI_TRUE@check_PROGRAMS = mpi_ring$(EXEEXT) \ @USE_MPI_TRUE@ mpi_multiring$(EXEEXT) mpi_spawn$(EXEEXT) \ @USE_MPI_TRUE@ test_mpi$(EXEEXT) waitall$(EXEEXT) \ @USE_MPI_TRUE@ waitany$(EXEEXT) persistent$(EXEEXT) \ @USE_MPI_TRUE@ mpi_ping$(EXEEXT) allgather$(EXEEXT) subdir = test/mpi ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = allgather_SOURCES = allgather.c allgather_OBJECTS = allgather.$(OBJEXT) allgather_LDADD = $(LDADD) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = mpi_multiring_SOURCES = mpi_multiring.c mpi_multiring_OBJECTS = mpi_multiring.$(OBJEXT) mpi_multiring_LDADD = $(LDADD) mpi_ping_SOURCES = mpi_ping.c mpi_ping_OBJECTS = mpi_ping.$(OBJEXT) mpi_ping_LDADD = $(LDADD) mpi_ring_SOURCES = mpi_ring.c mpi_ring_OBJECTS = mpi_ring.$(OBJEXT) mpi_ring_LDADD = $(LDADD) mpi_spawn_SOURCES = mpi_spawn.c mpi_spawn_OBJECTS = mpi_spawn.$(OBJEXT) mpi_spawn_LDADD = $(LDADD) persistent_SOURCES = persistent.c persistent_OBJECTS = persistent.$(OBJEXT) persistent_LDADD = $(LDADD) test_mpi_SOURCES = test_mpi.c test_mpi_OBJECTS = test_mpi.$(OBJEXT) test_mpi_LDADD = $(LDADD) waitall_SOURCES = waitall.c waitall_OBJECTS = waitall.$(OBJEXT) waitall_LDADD = $(LDADD) waitany_SOURCES = waitany.c waitany_OBJECTS = waitany.$(OBJEXT) waitany_LDADD = $(LDADD) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = allgather.c mpi_multiring.c mpi_ping.c mpi_ring.c \ mpi_spawn.c persistent.c test_mpi.c waitall.c waitany.c DIST_SOURCES = allgather.c mpi_multiring.c mpi_ping.c mpi_ring.c \ mpi_spawn.c persistent.c test_mpi.c waitall.c waitany.c am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = $(MPICC) CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AM_CFLAGS = -DWITH_MPI all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu test/mpi/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu test/mpi/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): clean-checkPROGRAMS: @list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list allgather$(EXEEXT): $(allgather_OBJECTS) $(allgather_DEPENDENCIES) $(EXTRA_allgather_DEPENDENCIES) @rm -f allgather$(EXEEXT) $(AM_V_CCLD)$(LINK) $(allgather_OBJECTS) $(allgather_LDADD) $(LIBS) mpi_multiring$(EXEEXT): $(mpi_multiring_OBJECTS) $(mpi_multiring_DEPENDENCIES) $(EXTRA_mpi_multiring_DEPENDENCIES) @rm -f mpi_multiring$(EXEEXT) $(AM_V_CCLD)$(LINK) $(mpi_multiring_OBJECTS) $(mpi_multiring_LDADD) $(LIBS) mpi_ping$(EXEEXT): $(mpi_ping_OBJECTS) $(mpi_ping_DEPENDENCIES) $(EXTRA_mpi_ping_DEPENDENCIES) @rm -f mpi_ping$(EXEEXT) $(AM_V_CCLD)$(LINK) $(mpi_ping_OBJECTS) $(mpi_ping_LDADD) $(LIBS) mpi_ring$(EXEEXT): $(mpi_ring_OBJECTS) $(mpi_ring_DEPENDENCIES) $(EXTRA_mpi_ring_DEPENDENCIES) @rm -f mpi_ring$(EXEEXT) $(AM_V_CCLD)$(LINK) $(mpi_ring_OBJECTS) $(mpi_ring_LDADD) $(LIBS) mpi_spawn$(EXEEXT): $(mpi_spawn_OBJECTS) $(mpi_spawn_DEPENDENCIES) $(EXTRA_mpi_spawn_DEPENDENCIES) @rm -f mpi_spawn$(EXEEXT) $(AM_V_CCLD)$(LINK) $(mpi_spawn_OBJECTS) $(mpi_spawn_LDADD) $(LIBS) persistent$(EXEEXT): $(persistent_OBJECTS) $(persistent_DEPENDENCIES) $(EXTRA_persistent_DEPENDENCIES) @rm -f persistent$(EXEEXT) $(AM_V_CCLD)$(LINK) $(persistent_OBJECTS) $(persistent_LDADD) $(LIBS) test_mpi$(EXEEXT): $(test_mpi_OBJECTS) $(test_mpi_DEPENDENCIES) $(EXTRA_test_mpi_DEPENDENCIES) @rm -f test_mpi$(EXEEXT) $(AM_V_CCLD)$(LINK) $(test_mpi_OBJECTS) $(test_mpi_LDADD) $(LIBS) waitall$(EXEEXT): $(waitall_OBJECTS) $(waitall_DEPENDENCIES) $(EXTRA_waitall_DEPENDENCIES) @rm -f waitall$(EXEEXT) $(AM_V_CCLD)$(LINK) $(waitall_OBJECTS) $(waitall_LDADD) $(LIBS) waitany$(EXEEXT): $(waitany_OBJECTS) $(waitany_DEPENDENCIES) $(EXTRA_waitany_DEPENDENCIES) @rm -f waitany$(EXEEXT) $(AM_V_CCLD)$(LINK) $(waitany_OBJECTS) $(waitany_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/allgather.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mpi_multiring.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mpi_ping.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mpi_ring.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mpi_spawn.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/persistent.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test_mpi.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/waitall.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/waitany.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am $(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS) check: check-am all-am: Makefile installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-checkPROGRAMS clean-generic clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: .MAKE: check-am install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ clean-checkPROGRAMS clean-generic clean-libtool cscopelist-am \ ctags ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/test/mpi/allgather.c000066400000000000000000000016031265506773700170440ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include "mpi.h" #include #include int main(int argc, char **argv) { int rank, size; int errors = 0; MPI_Comm comm = MPI_COMM_WORLD; int sendarray[100]; int *rbuf; MPI_Init(&argc, &argv); MPI_Comm_rank(MPI_COMM_WORLD, &rank); MPI_Comm_size(MPI_COMM_WORLD, &size); /* Exactly 2 processes can participate */ if (size < 2) { fprintf(stderr, "Number of processors must be at least 2\n"); fflush(stderr); MPI_Abort(MPI_COMM_WORLD, 1); } rbuf = (int *) malloc(size * 100 * sizeof(int)); MPI_Allgather(sendarray, 100, MPI_INT, rbuf, 100, MPI_INT, comm); MPI_Finalize(); if (errors) { printf("[%d] done with ERRORS(%d)!\n", rank, errors); fflush(stdout); } return errors; } eztrace-1.1-2/test/mpi/mpi_multiring.c000066400000000000000000000060141265506773700177610ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include #define LEN 1024 #define LOOPS 2 #define NB_MSG 4 static int comm_rank = -1; static int comm_size = -1; static char host_name[1024] = ""; static unsigned char **main_buffer = NULL; /* fill the buffer */ void fill_buffer(unsigned char** buffer, int buffer_size) { int i, j; for (i = 0; i < NB_MSG; i++) for (j = 0; j < buffer_size; j++) buffer[i][j] = 'a' + (j % 26); } /* fill the buffer with 0 */ void zero_buffer(unsigned char** buffer, int buffer_size) { int i, j; for (i = 0; i < NB_MSG; i++) for (j = 0; j < buffer_size; j++) buffer[i][j] = 0; } /* check wether the buffer contains errornous data * return 1 if it contains an error */ int check_buffer(unsigned char** buffer, int buffer_size) { int i, j; for (i = 0; i < NB_MSG; i++) for (j = 0; j < buffer_size; j++) if (buffer[i][j] != 'a' + (i % 26)) return 1; return 0; } void compute(unsigned usec) { double t1, t2; t1 = MPI_Wtime(); do { t2 = MPI_Wtime(); } while ((t2 - t1) * 1e6 < usec); } int main(int argc, char **argv) { int ping_side; int rank_dst; int start_len = LEN; int iterations = LOOPS; int i, j; MPI_Init(&argc, &argv); MPI_Comm_size(MPI_COMM_WORLD, &comm_size); MPI_Comm_rank(MPI_COMM_WORLD, &comm_rank); if (gethostname(host_name, 1023) < 0) { perror("gethostname"); exit(1); } if (comm_size < 2) { fprintf(stderr, "This program requires at least 2 MPI processes, aborting...\n"); goto out; } fprintf(stdout, "(%s): My rank is %d\n", host_name, comm_rank); ping_side = !(comm_rank & 1); main_buffer = malloc(sizeof(unsigned char*) * NB_MSG); for (i = 0; i < NB_MSG; i++) main_buffer[i] = malloc(start_len); fill_buffer(main_buffer, start_len); int size = 1024; //MPI_Barrier(MPI_COMM_WORLD); for (i = 0; i < iterations; i++) { for (j = 0; j < comm_rank; j++) compute(100); if (!comm_rank) { for (j = 0; j < NB_MSG; j++) MPI_Send(main_buffer[j], size, MPI_CHAR, (comm_rank + 1) % comm_size, 0, MPI_COMM_WORLD); } else { for (j = 0; j < NB_MSG; j++) MPI_Recv(main_buffer[j], size, MPI_CHAR, (comm_rank + comm_size - 1) % comm_size, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); } compute(100); if (!comm_rank) { for (j = 0; j < NB_MSG; j++) MPI_Recv(main_buffer[j], size, MPI_CHAR, (comm_rank + comm_size - 1) % comm_size, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); } else { for (j = 0; j < NB_MSG; j++) MPI_Send(main_buffer[j], size, MPI_CHAR, (comm_rank + 1) % comm_size, 0, MPI_COMM_WORLD); } } MPI_Barrier(MPI_COMM_WORLD); out: for (i = 0; i < NB_MSG; i++) free(main_buffer[i]); MPI_Finalize(); return 0; } eztrace-1.1-2/test/mpi/mpi_openmp.c000066400000000000000000000046251265506773700172530ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include //#define LEN (1024*1024*100) #define LEN (10*1024*1024) #define LOOPS 5 static int comm_rank = -1; static int comm_size = -1; static char host_name[1024] = ""; static unsigned char *main_buffer = NULL; /* fill the buffer */ void fill_buffer(double* buffer, int buffer_size) { int i; for (i = 0; i < buffer_size; i++) buffer[i] = (double) i; } /* fill the buffer with 0 */ void zero_buffer(double* buffer, int buffer_size) { int i; for (i = 0; i < buffer_size; i++) buffer[i] = 0; } /* 'Compute' for a fixed duration */ void compute(unsigned usec) { double t1, t2; t1 = MPI_Wtime(); do { t2 = MPI_Wtime(); } while (((t2 - t1) * 1e6) < (double) usec); } int main(int argc, char **argv) { int ping_side; int rank_dst; int required = MPI_THREAD_SERIALIZED; int provided; MPI_Init_thread(&argc, &argv, required, &provided); if (required != provided) { fprintf(stderr, "MPI does not support thread safety level %d\n", required); return 1; } MPI_Comm_size(MPI_COMM_WORLD, &comm_size); MPI_Comm_rank(MPI_COMM_WORLD, &comm_rank); if (gethostname(host_name, 1023) < 0) { perror("gethostname"); exit(1); } if (comm_size != 2) { fprintf(stderr, "This program requires 2 MPI processes, aborting...\n"); goto out; } fprintf(stdout, "(%s): My rank is %d\n", host_name, comm_rank); ping_side = !(comm_rank & 1); rank_dst = ping_side ? (comm_rank | 1) : (comm_rank & ~1); int i; int nb_iter = LOOPS; int size = LEN; int iter = 0; double *A = malloc(size * sizeof(double)); double *B = malloc(size * sizeof(double)); fill_buffer(A, size); zero_buffer(B, size); MPI_Request req[2]; MPI_Barrier(MPI_COMM_WORLD); for (iter = 0; iter < nb_iter; iter++) { fprintf(stderr, "[%d] loop %d\n", comm_rank, iter); #pragma omp parallel for for (i = 0; i < size; i++) { A[i] = B[i] + A[i]; } MPI_Isend(A, size, MPI_DOUBLE, rank_dst, 0, MPI_COMM_WORLD, &req[0]); MPI_Recv(B, size, MPI_DOUBLE, rank_dst, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); MPI_Wait(&req[0], MPI_STATUS_IGNORE); } MPI_Barrier(MPI_COMM_WORLD); free(A); free(B); out: MPI_Finalize(); return 0; } eztrace-1.1-2/test/mpi/mpi_ping.c000066400000000000000000000043711265506773700167100ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include #define LEN 16 #define LOOPS 10000 #define WARMUP 100 static unsigned char *main_buffer = NULL; void SEND(char* buffer, int len, int dest, int tag) { MPI_Send(buffer, len, MPI_CHAR, dest, tag, MPI_COMM_WORLD); } void RECV(char* buffer, int len, int src, int tag) { MPI_Recv(buffer, len, MPI_CHAR, src, tag, MPI_COMM_WORLD, MPI_STATUS_IGNORE); } void fill_buffer(char *buffer, int len) { int i; for (i = 0; i < len; i++) { buffer[i] = 'a' + (i % 26); } } void compute(unsigned usec) { double t1, t2; t1 = MPI_Wtime(); do { t2 = MPI_Wtime(); } while ((t2 - t1) * 1e6 < usec); } int main(int argc, char **argv) { int comm_rank = -1; int comm_size = -1; char host_name[1024] = ""; int dest; int len = LEN; int iterations = LOOPS; MPI_Init(&argc, &argv); MPI_Comm_size(MPI_COMM_WORLD, &comm_size); MPI_Comm_rank(MPI_COMM_WORLD, &comm_rank); if (gethostname(host_name, 1023) < 0) { perror("gethostname"); exit(1); } if (comm_size != 2) { fprintf(stderr, "This program requires 2 MPI processes, aborting...\n"); goto out; } fprintf(stdout, "(%s): My rank is %d\n", host_name, comm_rank); dest = (comm_rank + 1) % 2; main_buffer = malloc(len); fill_buffer(main_buffer, len); int i; for (i = 0; i < WARMUP; i++) { if (!comm_rank) { SEND(main_buffer, len, dest, 0); RECV(main_buffer, len, dest, 0); } else { RECV(main_buffer, len, dest, 0); SEND(main_buffer, len, dest, 0); } } double t1, t2; t1 = MPI_Wtime(); MPI_Barrier(MPI_COMM_WORLD); for (i = 0; i < iterations; i++) { if (!comm_rank) { SEND(main_buffer, len, dest, 0); RECV(main_buffer, len, dest, 0); } else { RECV(main_buffer, len, dest, 0); SEND(main_buffer, len, dest, 0); } } MPI_Barrier(MPI_COMM_WORLD); t2 = MPI_Wtime(); if (!comm_rank) { double latency = 1e6 * (t2 - t1) / (2 * iterations); printf("%d\t%d\t%lf\n", iterations, len, latency); } out: free(main_buffer); MPI_Finalize(); return 0; } eztrace-1.1-2/test/mpi/mpi_ring.c000066400000000000000000000056461265506773700167200ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 0) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stdout, fmt, va); va_end(va); } } // end of debugging part #define LEN 1024 #define LOOPS 10 static int comm_rank = -1; static int comm_size = -1; static char host_name[1024] = ""; static unsigned char *main_buffer = NULL; /* fill the buffer */ void fill_buffer(unsigned char* buffer, int buffer_size) { int i; for (i = 0; i < buffer_size; i++) buffer[i] = 'a' + (i % 26); } /* fill the buffer with 0 */ void zero_buffer(unsigned char* buffer, int buffer_size) { int i; for (i = 0; i < buffer_size; i++) buffer[i] = 0; } /* check wether the buffer contains errornous data * return 1 if it contains an error */ int check_buffer(unsigned char* buffer, int buffer_size) { int i; for (i = 0; i < buffer_size; i++) if (buffer[i] != 'a' + (i % 26)) return 1; return 0; } void compute(unsigned usec) { double t1, t2; t1 = MPI_Wtime(); do { t2 = MPI_Wtime(); } while ((t2 - t1) * 1e6 < usec); } int main(int argc, char **argv) { int ping_side; int rank_dst; int start_len = LEN; int iterations = LOOPS; MPI_Init(&argc, &argv); MPI_Comm_size(MPI_COMM_WORLD, &comm_size); MPI_Comm_rank(MPI_COMM_WORLD, &comm_rank); if (gethostname(host_name, 1023) < 0) { perror("gethostname"); exit(1); } if (comm_size < 2) { fprintf(stderr, "This program requires at least 2 MPI processes, aborting...\n"); goto out; } debug("(%s): My rank is %d\n", host_name, comm_rank); ping_side = !(comm_rank & 1); main_buffer = malloc(start_len); fill_buffer(main_buffer, start_len); int size = 1024; int i; MPI_Barrier(MPI_COMM_WORLD); for (i = 0; i < iterations; i++) { if (!comm_rank) { MPI_Send(main_buffer, size, MPI_CHAR, (comm_rank + 1) % comm_size, 0, MPI_COMM_WORLD); MPI_Recv(main_buffer, size, MPI_CHAR, (comm_rank + comm_size - 1) % comm_size, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); } else { MPI_Recv(main_buffer, size, MPI_CHAR, (comm_rank + comm_size - 1) % comm_size, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); compute(100); MPI_Send(main_buffer, size, MPI_CHAR, (comm_rank + 1) % comm_size, 0, MPI_COMM_WORLD); } MPI_Barrier(MPI_COMM_WORLD); } out: free(main_buffer); MPI_Finalize(); return 0; } eztrace-1.1-2/test/mpi/mpi_spawn.c000066400000000000000000000016541265506773700171040ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include "mpi.h" #include #include #define NUM_SPAWNS 2 /* 'Compute' for a fixed duration */ void compute(unsigned usec) { double t1, t2; t1 = MPI_Wtime(); do { t2 = MPI_Wtime(); } while (((t2 - t1) * 1e6) < (double) usec); } int main(int argc, char *argv[]) { int np = NUM_SPAWNS; int errcodes[NUM_SPAWNS]; MPI_Comm parentcomm, intercomm; MPI_Init(&argc, &argv); MPI_Comm_get_parent(&parentcomm); compute(100000); if (parentcomm == MPI_COMM_NULL) { MPI_Comm_spawn("./mpi_spawn", MPI_ARGV_NULL, np, MPI_INFO_NULL, 0, MPI_COMM_WORLD, &intercomm, errcodes); printf("I'm the parent.\n"); compute(1000000); } else { printf("I'm the spawned.\n"); } fflush(stdout); MPI_Finalize(); return 0; } eztrace-1.1-2/test/mpi/persistent.c000066400000000000000000000035501265506773700173040ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include int main(int argc, char **argv) { int numtasks, rank; int rank_dst, ping_side; // Initialise MPI MPI_Init(&argc, &argv); MPI_Comm_rank(MPI_COMM_WORLD, &rank); MPI_Comm_size(MPI_COMM_WORLD, &numtasks); if (numtasks != 2) { printf("Need 2 processes\n"); MPI_Abort(MPI_COMM_WORLD, 1); exit(1); } ping_side = !(rank & 1); rank_dst = ping_side ? (rank | 1) : (rank & ~1); if (ping_side) { int x = 42, y; MPI_Request send_request; MPI_Request recv_request; MPI_Send_init(&x, 1, MPI_INT, rank_dst, 1, MPI_COMM_WORLD, &send_request); MPI_Start(&send_request); MPI_Wait(&send_request, MPI_STATUS_IGNORE); MPI_Start(&send_request); MPI_Wait(&send_request, MPI_STATUS_IGNORE); MPI_Recv_init(&y, 1, MPI_INT, rank_dst, 1, MPI_COMM_WORLD, &recv_request); MPI_Start(&recv_request); MPI_Wait(&recv_request, MPI_STATUS_IGNORE); if (y == 42) printf("success\n"); else printf("failure\n"); MPI_Start(&recv_request); MPI_Wait(&recv_request, MPI_STATUS_IGNORE); if (y == 42) printf("success\n"); else printf("failure\n"); } else { int x, y; MPI_Recv(&x, 1, MPI_INT, rank_dst, 1, MPI_COMM_WORLD, MPI_STATUS_IGNORE); MPI_Recv(&y, 1, MPI_INT, rank_dst, 1, MPI_COMM_WORLD, MPI_STATUS_IGNORE); MPI_Send(&y, 1, MPI_INT, rank_dst, 1, MPI_COMM_WORLD); MPI_Send(&y, 1, MPI_INT, rank_dst, 1, MPI_COMM_WORLD); if (x == 42) printf("success\n"); else printf("failure\n"); if (y == 42) printf("success\n"); else printf("failure\n"); } MPI_Barrier(MPI_COMM_WORLD); MPI_Finalize(); exit(0); } eztrace-1.1-2/test/mpi/test_mpi.c000066400000000000000000000433011265506773700167260ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include #define LEN 1024 #define LOOPS 10 static int comm_rank = -1; static int comm_size = -1; static char host_name[1024] = ""; static unsigned char *main_buffer = NULL; /* fill the buffer */ void fill_buffer(unsigned char* buffer, int buffer_size) { int i; for (i = 0; i < buffer_size; i++) buffer[i] = 'a' + (i % 26); } /* fill the buffer with 0 */ void zero_buffer(unsigned char* buffer, int buffer_size) { int i; for (i = 0; i < buffer_size; i++) buffer[i] = 0; } /* check wether the buffer contains errornous data * return 1 if it contains an error */ int check_buffer(unsigned char* buffer, int buffer_size) { int i; for (i = 0; i < buffer_size; i++) if (buffer[i] != 'a' + (i % 26)) return 1; return 0; } /* 'Compute' for a fixed duration */ void compute(unsigned usec) { double t1, t2; t1 = MPI_Wtime(); do { t2 = MPI_Wtime(); } while (((t2 - t1) * 1e6) < (double) usec); } int main(int argc, char **argv) { int ping_side; int rank_dst; int start_len = LEN; int iterations = LOOPS; MPI_Init(&argc, &argv); MPI_Comm_size(MPI_COMM_WORLD, &comm_size); MPI_Comm_rank(MPI_COMM_WORLD, &comm_rank); if (gethostname(host_name, 1023) < 0) { perror("gethostname"); exit(1); } if (comm_size != 2) { fprintf(stderr, "This program requires 2 MPI processes, aborting...\n"); goto out; } fprintf(stdout, "(%s): My rank is %d\n", host_name, comm_rank); ping_side = !(comm_rank & 1); rank_dst = ping_side ? (comm_rank | 1) : (comm_rank & ~1); main_buffer = malloc(start_len); fill_buffer(main_buffer, start_len); MPI_Barrier(MPI_COMM_WORLD); /* Test */ if (ping_side) { int size = start_len; int nb_samples; MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { fill_buffer(main_buffer, size); MPI_Send(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); MPI_Recv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Send/MPI_Recv failed !\n", ping_side); goto out; } } fprintf(stderr, "[%d] MPI_Send/MPI_Recv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { fill_buffer(main_buffer, size); MPI_Send(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); MPI_Recv(main_buffer, size, MPI_CHAR, MPI_ANY_SOURCE, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Send/MPI_Recv ANYSRC failed !\n", ping_side); goto out; } } fprintf(stderr, "[%d] MPI_Send/MPI_Recv ANYSRC passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { fill_buffer(main_buffer, size); MPI_Send(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); MPI_Recv(main_buffer, size, MPI_CHAR, MPI_ANY_SOURCE, MPI_ANY_TAG, MPI_COMM_WORLD, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Send/MPI_Recv ANYSRC+ANYTAG failed !\n", ping_side); goto out; } } fprintf(stderr, "[%d] MPI_Send/MPI_Recv ANYSRC+ANYTAG passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { fill_buffer(main_buffer, size); MPI_Send(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); MPI_Recv(main_buffer, size, MPI_CHAR, rank_dst, MPI_ANY_TAG, MPI_COMM_WORLD, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Send/MPI_Recv ANYTAG failed !\n", ping_side); goto out; } } fprintf(stderr, "[%d] MPI_Send/MPI_Recv ANYTAG passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { fill_buffer(main_buffer, size); MPI_Ssend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); MPI_Recv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Ssend/MPI_Recv failed !\n", ping_side); goto out; } } fprintf(stderr, "[%d] MPI_Ssend/MPI_Recv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { fill_buffer(main_buffer, size); MPI_Rsend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); MPI_Recv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Rsend/MPI_Recv failed !\n", ping_side); goto out; } } fprintf(stderr, "[%d] MPI_Rsend/MPI_Recv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); /* non blocking functions */ for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Request req; fill_buffer(main_buffer, size); MPI_Isend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); compute(100); MPI_Wait(&req, MPI_STATUS_IGNORE); zero_buffer(main_buffer, size); MPI_Irecv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Isend/MPI_Irecv failed !\n", ping_side); goto out; } } fprintf(stderr, "[%d] MPI_Isend/MPI_Irecv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Request req; fill_buffer(main_buffer, size); MPI_Issend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); compute(100); MPI_Wait(&req, MPI_STATUS_IGNORE); zero_buffer(main_buffer, size); MPI_Irecv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Issend/MPI_Irecv failed !\n", ping_side); goto out; } } fprintf(stderr, "[%d] MPI_Issend/MPI_Irecv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Request req; fill_buffer(main_buffer, size); MPI_Irsend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); compute(100); MPI_Wait(&req, MPI_STATUS_IGNORE); zero_buffer(main_buffer, size); MPI_Irecv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Irsend/MPI_Irecv failed !\n", ping_side); goto out; } } fprintf(stderr, "[%d] MPI_Irsend/MPI_Irecv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); /* MPI_Bsend */ int bufsize = 1024 + MPI_BSEND_OVERHEAD; char *buf = malloc(bufsize); MPI_Buffer_attach(buf, bufsize); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Request req; fill_buffer(main_buffer, size); MPI_Bsend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); MPI_Irecv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Irsend/MPI_Irecv failed !\n", ping_side); goto out; } } fprintf(stderr, "[%d] MPI_Bsend/MPI_Irecv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); /* MPI_Ibsend */ for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Request req; fill_buffer(main_buffer, size); MPI_Bsend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); compute(100); zero_buffer(main_buffer, size); MPI_Irecv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Irsend/MPI_Irecv failed !\n", ping_side); goto out; } } MPI_Buffer_detach(&buf, &bufsize); fprintf(stderr, "[%d] MPI_Ibsend/MPI_Irecv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); /* MPI_Waitall */ for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Request req[4]; int vars[4]; int i; for (i = 0; i < 4; i++) { vars[i] = i * i; MPI_Isend(&vars[i], 1, MPI_INTEGER, rank_dst, 0, MPI_COMM_WORLD, &req[i]); } MPI_Waitall(4, req, MPI_STATUS_IGNORE); compute(100); for (i = 0; i < 4; i++) { vars[i] = -1; MPI_Irecv(&vars[i], 1, MPI_INTEGER, rank_dst, 0, MPI_COMM_WORLD, &req[i]); } MPI_Waitall(4, req, MPI_STATUS_IGNORE); for (i = 0; i < 4; i++) { if (vars[i] != i * i) { fprintf(stderr, "[%d] MPI_Waitall failed !\n", ping_side); goto out; } } } fprintf(stderr, "[%d] MPI_Waitall passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); } else { int size = start_len; int nb_samples; MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Recv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Send/MPI_Recv failed !\n", ping_side); goto out; } fill_buffer(main_buffer, size); MPI_Send(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); } fprintf(stderr, "[%d] MPI_Send/MPI_Recv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Recv(main_buffer, size, MPI_CHAR, MPI_ANY_SOURCE, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Send/MPI_Recv ANYSRC failed !\n", ping_side); goto out; } fill_buffer(main_buffer, size); MPI_Send(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); } fprintf(stderr, "[%d] MPI_Send/MPI_Recv ANYSRC passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Recv(main_buffer, size, MPI_CHAR, MPI_ANY_SOURCE, MPI_ANY_TAG, MPI_COMM_WORLD, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Send/MPI_Recv ANYSRC+ANYTAG failed !\n", ping_side); goto out; } fill_buffer(main_buffer, size); MPI_Send(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); } fprintf(stderr, "[%d] MPI_Send/MPI_Recv ANYSRC+ANYTAG passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Recv(main_buffer, size, MPI_CHAR, rank_dst, MPI_ANY_TAG, MPI_COMM_WORLD, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Send/MPI_Recv ANYTAG failed !\n", ping_side); goto out; } fill_buffer(main_buffer, size); MPI_Send(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); } fprintf(stderr, "[%d] MPI_Send/MPI_Recv ANYTAG passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Recv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Ssend/MPI_Recv failed !\n", ping_side); goto out; } fill_buffer(main_buffer, size); MPI_Ssend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); } fprintf(stderr, "[%d] MPI_Ssend/MPI_Recv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Recv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Rsend/MPI_Recv failed !\n", ping_side); goto out; } fill_buffer(main_buffer, size); MPI_Rsend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); } fprintf(stderr, "[%d] MPI_Rsend/MPI_Recv passed\n", ping_side); /* non blocking functions */ MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Request req; MPI_Irecv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Isend/MPI_Irecv failed !\n", ping_side); goto out; } fill_buffer(main_buffer, size); MPI_Isend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); zero_buffer(main_buffer, size); } fprintf(stderr, "[%d] MPI_Isend/MPI_Irecv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Request req; MPI_Irecv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Isend/MPI_Irecv failed !\n", ping_side); goto out; } fill_buffer(main_buffer, size); MPI_Issend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); zero_buffer(main_buffer, size); } fprintf(stderr, "[%d] MPI_Issend/MPI_Irecv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Request req; MPI_Irecv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Irsend/MPI_Irecv failed !\n", ping_side); goto out; } fill_buffer(main_buffer, size); MPI_Irsend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); zero_buffer(main_buffer, size); } fprintf(stderr, "[%d] MPI_Irsend/MPI_Irecv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); /* MPI_Bsend */ int bufsize = 1024 + MPI_BSEND_OVERHEAD; char *buf = malloc(bufsize); MPI_Buffer_attach(buf, bufsize); for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Request req; MPI_Irecv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Irsend/MPI_Irecv failed !\n", ping_side); goto out; } fill_buffer(main_buffer, size); MPI_Bsend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD); zero_buffer(main_buffer, size); } fprintf(stderr, "[%d] MPI_Bsend/MPI_Irecv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); /* MPI_Ibsend */ for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Request req; MPI_Irecv(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); if (check_buffer(main_buffer, size)) { fprintf(stderr, "[%d] MPI_Irsend/MPI_Irecv failed !\n", ping_side); goto out; } fill_buffer(main_buffer, size); MPI_Ibsend(main_buffer, size, MPI_CHAR, rank_dst, 0, MPI_COMM_WORLD, &req); MPI_Wait(&req, MPI_STATUS_IGNORE); zero_buffer(main_buffer, size); } MPI_Buffer_detach(&buf, &bufsize); fprintf(stderr, "[%d] MPI_Ibsend/MPI_Irecv passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); /* MPI_Ibsend */ for (nb_samples = 0; nb_samples < iterations; nb_samples++) { MPI_Request req[4]; int vars[4]; int i; for (i = 0; i < 4; i++) { vars[i] = -1; MPI_Irecv(&vars[i], 1, MPI_INTEGER, rank_dst, 0, MPI_COMM_WORLD, &req[i]); } MPI_Waitall(4, req, MPI_STATUS_IGNORE); compute(100); for (i = 0; i < 4; i++) { MPI_Isend(&vars[i], 1, MPI_INTEGER, rank_dst, 0, MPI_COMM_WORLD, &req[i]); } MPI_Waitall(4, req, MPI_STATUS_IGNORE); for (i = 0; i < 4; i++) { if (vars[i] != i * i) { fprintf(stderr, "[%d] MPI_Waitall failed !\n", ping_side); goto out; } } } fprintf(stderr, "[%d] MPI_Waitall passed\n", ping_side); MPI_Barrier(MPI_COMM_WORLD); } free(main_buffer); out: MPI_Finalize(); return 0; } eztrace-1.1-2/test/mpi/waitall.c000066400000000000000000000024771265506773700165500ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include "mpi.h" #include int main(int argc, char *argv[]) { int rank, size; int i, index; int buffer[400]; MPI_Request request[4]; MPI_Status status[4]; MPI_Init(&argc, &argv); MPI_Comm_size(MPI_COMM_WORLD, &size); if (size != 4) { printf("Please run with 4 processes.\n"); fflush(stdout); MPI_Finalize(); return 1; } MPI_Comm_rank(MPI_COMM_WORLD, &rank); if (rank == 0) { for (i = 0; i < size * 100; i++) buffer[i] = i / 100; for (i = 0; i < size - 1; i++) { MPI_Isend(&buffer[i * 100], 100, MPI_INT, i + 1, 123, MPI_COMM_WORLD, &request[i]); } while (1) { /* just for testing if eztrace works when some of the requests are already successful when calling mpi_waitall */ int flag; MPI_Status status; MPI_Test(&request[0], &flag, &status); if (flag) { break; } } MPI_Waitall(size - 1, request, status); MPI_Waitall(size - 1, request, status); } else { MPI_Recv(buffer, 100, MPI_INT, 0, 123, MPI_COMM_WORLD, &status[0]); printf("%d: buffer[0] = %d\n", rank, buffer[0]); fflush(stdout); } MPI_Finalize(); return 0; } eztrace-1.1-2/test/mpi/waitany.c000066400000000000000000000021461265506773700165600ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include "mpi.h" #include int main(int argc, char *argv[]) { int rank, size; int i, index; int buffer[400]; MPI_Request request[4]; MPI_Status status[4]; MPI_Init(&argc, &argv); MPI_Comm_size(MPI_COMM_WORLD, &size); if (size != 4) { printf("Please run with 4 processes.\n"); fflush(stdout); MPI_Finalize(); return 1; } MPI_Comm_rank(MPI_COMM_WORLD, &rank); if (rank == 0) { for (i = 0; i < size * 100; i++) buffer[i] = i / 100; for (i = 0; i < size - 1; i++) { MPI_Isend(&buffer[i * 100], 100, MPI_INT, i + 1, 123, MPI_COMM_WORLD, &request[i]); } for (i = 0; i < size - 1; i++) { MPI_Waitany(size - 1, request, &index, status); fprintf(stderr, "index=%d\n", index); } } else { MPI_Recv(buffer, 100, MPI_INT, 0, 123, MPI_COMM_WORLD, &status[0]); printf("%d: buffer[0] = %d\n", rank, buffer[0]); fflush(stdout); } MPI_Finalize(); return 0; } eztrace-1.1-2/test/openmp/000077500000000000000000000000001265506773700154465ustar00rootroot00000000000000eztrace-1.1-2/test/openmp/Makefile.am000066400000000000000000000005041265506773700175010ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. AM_CFLAGS = -fopenmp -lm if OPENMP_FOUND check_PROGRAMS = openmp_simple test_nest_lock test_lock openmp_simple_SOURCES=openmp_simple.c test_nest_lock_SOURCES=test_nest_lock.c test_lock_SOURCES=test_lock.c endif eztrace-1.1-2/test/openmp/Makefile.in000066400000000000000000000510431265506773700175160ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @OPENMP_FOUND_TRUE@check_PROGRAMS = openmp_simple$(EXEEXT) \ @OPENMP_FOUND_TRUE@ test_nest_lock$(EXEEXT) test_lock$(EXEEXT) subdir = test/openmp ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__openmp_simple_SOURCES_DIST = openmp_simple.c @OPENMP_FOUND_TRUE@am_openmp_simple_OBJECTS = openmp_simple.$(OBJEXT) openmp_simple_OBJECTS = $(am_openmp_simple_OBJECTS) openmp_simple_LDADD = $(LDADD) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = am__test_lock_SOURCES_DIST = test_lock.c @OPENMP_FOUND_TRUE@am_test_lock_OBJECTS = test_lock.$(OBJEXT) test_lock_OBJECTS = $(am_test_lock_OBJECTS) test_lock_LDADD = $(LDADD) am__test_nest_lock_SOURCES_DIST = test_nest_lock.c @OPENMP_FOUND_TRUE@am_test_nest_lock_OBJECTS = \ @OPENMP_FOUND_TRUE@ test_nest_lock.$(OBJEXT) test_nest_lock_OBJECTS = $(am_test_nest_lock_OBJECTS) test_nest_lock_LDADD = $(LDADD) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(openmp_simple_SOURCES) $(test_lock_SOURCES) \ $(test_nest_lock_SOURCES) DIST_SOURCES = $(am__openmp_simple_SOURCES_DIST) \ $(am__test_lock_SOURCES_DIST) \ $(am__test_nest_lock_SOURCES_DIST) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AM_CFLAGS = -fopenmp -lm @OPENMP_FOUND_TRUE@openmp_simple_SOURCES = openmp_simple.c @OPENMP_FOUND_TRUE@test_nest_lock_SOURCES = test_nest_lock.c @OPENMP_FOUND_TRUE@test_lock_SOURCES = test_lock.c all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu test/openmp/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu test/openmp/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): clean-checkPROGRAMS: @list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list openmp_simple$(EXEEXT): $(openmp_simple_OBJECTS) $(openmp_simple_DEPENDENCIES) $(EXTRA_openmp_simple_DEPENDENCIES) @rm -f openmp_simple$(EXEEXT) $(AM_V_CCLD)$(LINK) $(openmp_simple_OBJECTS) $(openmp_simple_LDADD) $(LIBS) test_lock$(EXEEXT): $(test_lock_OBJECTS) $(test_lock_DEPENDENCIES) $(EXTRA_test_lock_DEPENDENCIES) @rm -f test_lock$(EXEEXT) $(AM_V_CCLD)$(LINK) $(test_lock_OBJECTS) $(test_lock_LDADD) $(LIBS) test_nest_lock$(EXEEXT): $(test_nest_lock_OBJECTS) $(test_nest_lock_DEPENDENCIES) $(EXTRA_test_nest_lock_DEPENDENCIES) @rm -f test_nest_lock$(EXEEXT) $(AM_V_CCLD)$(LINK) $(test_nest_lock_OBJECTS) $(test_nest_lock_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/openmp_simple.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test_lock.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test_nest_lock.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am $(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS) check: check-am all-am: Makefile installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-checkPROGRAMS clean-generic clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: .MAKE: check-am install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ clean-checkPROGRAMS clean-generic clean-libtool cscopelist-am \ ctags ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/test/openmp/openmp_nowait.f000066400000000000000000000023071265506773700204760ustar00rootroot00000000000000! Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis ! See COPYING in top-level directory. program squelette_RECOM implicit none integer n, i, j, m parameter (n=8, m=100) real*8 a(0:n),b(0:n),c(0:n),r do i=0,n a(i)=sqrt(REAL(i)) b(i)=0 enddo !$OMP PARALLEL !$OMP DO private(i) do i=0,n A(i) = A(i) +1 enddo !$omp end do nowait !$OMP DO private(i) do i=0,n do j=0,((i/10000)+1)*m b(i) = b(i) + sqrt(a(i))/3 enddo enddo !$omp end do nowait !$OMP DO private(i) do i=0,n do j=0,((i/10000)+1)*m c(i) = c(i) + sqrt(a(i))/3 enddo enddo !$omp end do !$OMP DO private(i) do i=0,n-1 do j=0,((i/10000)+1)*m b(i+1) = b(i+1) + sqrt(a(i)) enddo enddo !$omp end do nowait !$omp do private(i) do i=0,n-1 c(i+1) = c(i+1) + sqrt(a(i)) enddo !$omp end do !$omp do private(i) do i=0,n-1 b(i+1) = b(i+1) + sqrt(a(i)) + c(i) enddo !$omp end do !$omp master do i=0,n r=r+b(i) enddo print *, r !$omp end master !$OMP END PARALLEL end eztrace-1.1-2/test/openmp/openmp_nowait_c.c000066400000000000000000000030101265506773700207650ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 0) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stdout, fmt, va); va_end(va); } } // end of debugging part #define N 100000 #define M 10 int main() { int i, j; double a[N], b[N], c[N]; double r = 0; for (i = 0; i < N; i++) { a[i] = sqrt(i); b[i] = 0; c[i] = 0; } #pragma omp parallel { #pragma omp for private(i, j) nowait for (i = 0; i < N; i++) { for (j = 0; j < ((i / 10000) + 1) * M; j++) { b[i] = b[i] + sqrt(a[i]) / 3; } } #pragma omp for private(i, j) for (i = 0; i < N; i++) { for (j = 0; j < ((i / 10000) + 1) * M; j++) { c[i] = c[i] + sqrt(a[i]); } } #pragma omp for private(i, j) for (i = 0; i < N; i++) { for (j = 0; j < ((i / 10000) + 1) * M; j++) { b[i] = b[i] + sqrt(a[i]) / 3 + c[i]; } } #pragma omp barrier #pragma omp master { for (i = 0; i < N; i++) { r = r + b[i]; } debug("r = %lf\n", r); } } return 0; } eztrace-1.1-2/test/openmp/openmp_simple.c000066400000000000000000000037051265506773700204660ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ # include # include # include # include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 0) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stdout, fmt, va); va_end(va); } } // end of debugging part void fake_compute() { struct timeval t1, t2; gettimeofday(&t1, NULL); do { gettimeofday(&t2, NULL); } while(((t2.tv_sec-t1.tv_sec)*1e6)+(t2.tv_usec-t1.tv_usec) < 100000); } #define SIZE (1024*1024*8) int main(void) { int i; int *A = malloc(sizeof(int) * SIZE); int *B = malloc(sizeof(int) * SIZE); int *C = malloc(sizeof(int) * SIZE); for (i = 0; i < SIZE; i++) { A[i] = i * 17 % 7; B[i] = i * 19 % 7; C[i] = 0; } //compute for real! int j; for (j = 0; j < 3; j++) { debug("loop %d\n", j); debug("\trunning parallel for schedule(static)\n"); #pragma omp parallel for schedule(static) for (i = 0; i < SIZE; i++) { C[i] = A[i] + B[i]; } fake_compute(); debug("\trunning parallel for schedule(runtime)\n"); #pragma omp parallel for schedule(runtime) for (i = 0; i < SIZE; i++) { C[i] = A[i] + B[i]; } fake_compute(); debug("\trunning parallel for schedule(dynamic)\n"); #pragma omp parallel for schedule(dynamic) for (i = 0; i < SIZE; i++) { C[i] = A[i] + B[i]; } fake_compute(); debug("\trunning parallel for schedule(guided)\n"); #pragma omp parallel for schedule(guided) for (i = 0; i < SIZE; i++) { C[i] = A[i] + B[i]; } fake_compute(); } return 0; } eztrace-1.1-2/test/openmp/test_lock.c000066400000000000000000000026141265506773700176040ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ # include # include # include # include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 0) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stdout, fmt, va); va_end(va); } } // end of debugging part #define SIZE (1024*1024*8) int main(void) { int i; int *A = malloc(sizeof(int) * SIZE); int *B = malloc(sizeof(int) * SIZE); int *C = malloc(sizeof(int) * SIZE); for (i = 0; i < SIZE; i++) { A[i] = i * 17 % 7; B[i] = i * 19 % 7; C[i] = 0; } omp_lock_t lock; omp_init_lock(&lock); int somme = 0; //compute for real! int j; for (j = 0; j < 1; j++) { debug("loop %d\n", j); debug("\trunning parallel for schedule(static)\n"); #pragma omp parallel for for (i = 0; i < SIZE; i++) { C[i] = A[i] + B[i]; if (i % 1000 == 0) { omp_set_lock(&lock); somme += C[i]; omp_unset_lock(&lock); } } } printf("somme = %d\n", somme); return 0; } eztrace-1.1-2/test/openmp/test_nest_lock.c000066400000000000000000000034641265506773700206410ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ # include # include # include # include # include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 0) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stdout, fmt, va); va_end(va); } } // end of debugging part #define SIZE (1024*1024*8) void compute(unsigned usec) { #define TIME_DIFF(t1, t2) ((t2.tv_sec - t1.tv_sec)*1e6) + (t2.tv_usec - t1.tv_usec) struct timeval t1, t2; gettimeofday(&t1, NULL); do { gettimeofday(&t2, NULL); } while (TIME_DIFF(t1, t2) < usec); } int main(void) { int i; int *A = malloc(sizeof(int) * SIZE); int *B = malloc(sizeof(int) * SIZE); int *C = malloc(sizeof(int) * SIZE); for (i = 0; i < SIZE; i++) { A[i] = i * 17 % 7; B[i] = i * 19 % 7; C[i] = 0; } omp_nest_lock_t lock; omp_init_nest_lock(&lock); int somme = 0; //compute for real! int j; for (j = 0; j < 1; j++) { debug("loop %d\n", j); debug("\trunning parallel for schedule(static)\n"); #pragma omp parallel for for (i = 0; i < SIZE; i++) { C[i] = A[i] + B[i]; if (i % 1000 == 0) { omp_set_nest_lock(&lock); compute(10); { omp_set_nest_lock(&lock); compute(10); omp_unset_nest_lock(&lock); } somme += C[i]; omp_unset_nest_lock(&lock); } } } debug("somme = %d\n", somme); return 0; } eztrace-1.1-2/test/openmp/test_task.c000066400000000000000000000024261265506773700176170ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ # include # include # include # include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 0) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stdout, fmt, va); va_end(va); } } // end of debugging part #define SIZE (1024*8) int res = 0; omp_lock_t lock; void task_function(int n) { // printf("task_function(%d) : res = %d\n", n, res); if (n % 2) { omp_set_lock(&lock); res += 1; omp_unset_lock(&lock); } } int main(void) { int i; omp_init_lock(&lock); int j; #pragma omp parallel for (j = 0; j < 10; j++) { debug("loop %d\n", j); for (i = 0; i < SIZE; i++) { if (j % 2) { #pragma omp task untied task_function(i); } else { #pragma omp task task_function(i); } } #pragma omp taskwait } debug("result = %d\n", res); return 0; } eztrace-1.1-2/test/pptrace/000077500000000000000000000000001265506773700156065ustar00rootroot00000000000000eztrace-1.1-2/test/pptrace/automatic/000077500000000000000000000000001265506773700175745ustar00rootroot00000000000000eztrace-1.1-2/test/pptrace/automatic/Makefile.in000066400000000000000000000041451265506773700216450ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. BITS=@TARGET_BITS@ CORE_DIRECTORY=@abs_top_builddir@/src/core CORE_SRC_DIRECTORY=@abs_top_srcdir@/src/core PPTRACE_DIRECTORY=@abs_top_srcdir@/src/pptrace TEST_DIRECTORY=@abs_top_srcdir@/test/pptrace/automatic TESTS=errors binary tracing opcodes wait_open hijack DEBUG_LEVEL=0 ifeq "@PPTRACE_BINARY_TYPE@" "1" LIBBIN=-lbfd -lopcodes else LIBBIN=-lelf endif PPTRACE_DEPS=errors.c\ binary.c ADDITIONAL_DEPS=$(CORE_SRC_DIRECTORY)/ezt_demangle.c errors_FLAGS=$(LIBBIN) errors_DEPS=$(PPTRACE_DEPS) binary_FLAGS=$(LIBBIN) binary_DEPS=$(PPTRACE_DEPS) wait_open_FLAGS=$(LIBBIN) wait_open_DEPS=$(PPTRACE_DEPS)\ tracing.c tracing_FLAGS=$(LIBBIN) tracing_DEPS=$(PPTRACE_DEPS)\ tracing.c opcodes_FLAGS=$(LIBBIN) opcodes_DEPS=$(PPTRACE_DEPS)\ opcodes.c hijack_FLAGS=$(LIBBIN) hijack_DEPS= $(PPTRACE_DEPS)\ opcodes.c\ tracing.c\ hijack.c\ memory.c\ isize.c TESTCASES_=$(patsubst %.c,%,$(wildcard $(TEST_DIRECTORY)/testcase/*.c)) TESTCASES=$(foreach testcase,$(TESTCASES_),$(foreach b,$(BITS),$(testcase).$(b) $(testcase).$(b).so)) TESTS_CHECK=$(foreach test,$(TESTS),$(test).check) CFLAGS = -O0 -g -I$(PPTRACE_DIRECTORY) -I$(CORE_DIRECTORY) -I$(CORE_SRC_DIRECTORY) -D__PPTRACE_DEBUG_LEVEL=$(DEBUG_LEVEL) .PHONY: check testcase all: distdir: check: testcase $(TESTS) testcase: @make -C $(TEST_DIRECTORY)/testcase BITS='$(BITS)' %.check: % @echo -n " *** RUNNING TEST $<... " @./$<.test || (echo "FAILED!"; false) @echo "OK" %:: $(TEST_DIRECTORY)/%.c @echo CC $@ @$(CC) $(CFLAGS) $^ $(foreach d,$($@_DEPS),$(PPTRACE_DIRECTORY)/$d) $(ADDITIONAL_DEPS) -o $@ $($@_FLAGS) @echo "#!/bin/sh" >$@.test @echo "cd $$PWD" >>$@.test @echo './$@ ${TESTCASES} $$*' >>$@.test @echo 'RES=$$?' >>$@.test @echo 'cd - >/dev/null' >>$@.test @echo 'exit $$RES'>>$@.test @chmod +x $@.test install: installcheck: uninstall: distclean: clean clean: @rm -f $(TESTS) $(foreach d,$(TESTS),$d.test) @if [ -d $(TEST_DIRECTORY)/testcase ] ; then make -C $(TEST_DIRECTORY)/testcase BITS='$(BITS)' clean ; fi eztrace-1.1-2/test/pptrace/automatic/binary.c000066400000000000000000000127411265506773700212310ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * binary.h -- tests of binary reading functions (binary.h) * * Created on: 4 Aug. 2011 * Author: Damien Martin-Guillerez */ #include #include #include #include #include #include #include #include char *readline(int fd) { char buf; size_t size = 1024; int index = 0; char *buffer = (char*) malloc(size); buffer[index] = 0; int r; while (0 <= (r = read(fd, &buf, 1))) { if (buf == '\n') { return buffer; } //printf("%d ", buf); buffer[index++] = buf; if (index >= size) { size += 1024; buffer = (char*) realloc(buffer, size); } buffer[index] = 0; } if (r < 0) { free(buffer); return NULL; } return buffer; } int compare_name(char *line, char *symbol) { if (strlen(symbol) + 1 >= strlen(line)) return 0; int i = strlen(line) - strlen(symbol) - 1; if (!isblank(line[i])) return 0; return strcmp(line + i + 1, symbol) == 0 ? 1 : 0; } char *get_nm_symbol(char *path, char *symbol) { int p[2]; if (pipe(p) == -1) return NULL; pid_t child = fork(); if (child == -1) { close(p[1]); close(p[0]); return NULL; } if (child == 0) { close(p[0]); close(STDOUT_FILENO); dup2(p[1], STDOUT_FILENO); close(p[1]); execlp("nm", "nm", path, NULL); exit(-1); } else { close(p[1]); char* buffer = readline(p[0]); while (buffer != NULL) { if (compare_name(buffer, symbol)) { close(p[0]); return buffer; } free(buffer); buffer = readline(p[0]); } close(p[0]); } return NULL; } int compare_result(char *path, zzt_symbol *sym, char *symbol) { if (strcmp(sym->symbol_name, symbol)) return -__LINE__; char *nm = get_nm_symbol(path, symbol); if (!nm) return -__LINE__; zzt_word addr = strtoul(nm, NULL, 16); free(nm); if (!addr) return -__LINE__; if (addr != sym->section_addr + sym->symbol_offset) return -__LINE__; return EXIT_SUCCESS; } int test_read_zstring_array(void *bin, char *symbol, char **model) { char **frombin = read_zstring_array(bin, symbol); if (frombin == NULL && model != NULL) return -__LINE__; if (model == NULL && frombin != NULL) return -__LINE__; int i = 0; while (frombin[i] || model[i]) { if (strcmp(frombin[i], model[i]) != 0) return -__LINE__; i++; } if (frombin[i]) return -__LINE__; if (model[i]) return -__LINE__; free_zstring_array(frombin); return 0; } int test_dump_symbol(void *bin, int bits, zzt_symbol *sym, char **model) { char buf[1024]; char buf2[1024]; uint32_t* val32 = (uint32_t*) buf; word_uint* val64 = (word_uint*) buf; int i = 0; ssize_t size = read_symbol(bin, sym, buf, 1024); bits >>= 3; size /= bits; //printf("Size of symbol %s: %d\n", sym->symbol_name, (int)size); for (i = 0; model[i] && i < size; i++) { zzt_word w = (bits == 4) ? val32[i] : val64[i]; size_t s = read_zstring(bin, sym, w, buf2, 1024); // printf("\t[%d] %p %s\n", i, (void*)w, buf2); if (strcmp(model[i], buf2) != 0) return -__LINE__; } if (i < size) { zzt_word w = (bits == 4) ? val32[i] : val64[i]; if (w != 0) return -__LINE__; } else if (model[i]) { return -__LINE__; } return EXIT_SUCCESS; } char *sym_model[] = {"absolutely", "dummy", "heho", NULL}; int testcase(char *path, int bits, char *symbol, char *arraysym, char *nonsym) { void *bin = open_binary(path); if (bin == NULL) return -__LINE__; if (get_binary_bits(bin) != bits) return -__LINE__; if (get_symbol(bin, nonsym) != NULL) return -__LINE__; zzt_symbol *sym = get_symbol(bin, symbol); if (sym == NULL) return -__LINE__; int r = compare_result(path, sym, symbol); free_symbol(sym); if (r < 0) { close_binary(bin); return r; } sym = get_symbol(bin, arraysym); if (sym == NULL) return -__LINE__; r = test_dump_symbol(bin, bits, sym, sym_model); free_symbol(sym); if (r < 0) { close_binary(bin); return r; } r = test_read_zstring_array(bin, arraysym, sym_model); close_binary(bin); return r; } int nulltest() { return open_binary("/path/to/unknown") == NULL ? EXIT_SUCCESS : -__LINE__; } int getbits(char *path) { int i = strlen(path); if (i > 3 && strncmp(path + strlen(path) - 3, ".so", 3) == 0) { i -= 3; } for (i--; i >= 0 && path[i] != '.'; i--) ; return atoi(path + i + 1); } char* getname(char *path) { char *name = strdup(path); char *bnam = basename(name); int i = strlen(bnam); if (i > 3 && strncmp(bnam + strlen(bnam) - 3, ".so", 3) == 0) { i -= 3; } for (i--; i >= 0 && bnam[i] != '.'; i--) ; if (i > 0) { bnam[i] = 0; char *result = strdup(bnam); free(name); return result; } free(name); return NULL; } int main(int argc, char **argv) { int i, r; if ((r = nulltest())) { fprintf(stderr, "Failed nulltest() at line %d\n", -r); exit(r); } for (i = 1; i < argc; i++) { char *name = getname(argv[i]); if (name != NULL) { r = testcase(argv[i], getbits(argv[i]), name, "dummy_symbol", "_stup_dummy42__45642"); if (r) { fprintf(stderr, "Failed for testcase %s at line %d\n", argv[i], -r); exit(r); } } } exit(EXIT_SUCCESS); return 0; } eztrace-1.1-2/test/pptrace/automatic/common.h000066400000000000000000000041041265506773700212340ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * common.h - common basis for several tests * * Created on: 3 sep. 2012 * Author: Damien Martin-Guillerez */ #include #include int debug; // Common parts #define DEBUG(x) if(debug > 1) fprintf(stderr, "\tDEBUG %s: " x "\n", __method__) #define DEBUG1(x, p1) if(debug > 1) fprintf(stderr, "\tDEBUG %s: " x "\n", __method__, p1) #define DEBUG2(x, p1, p2) if(debug > 1) fprintf(stderr, "\tDEBUG %s: " x "\n", __method__, p1, p2) #define BEGIN_TEST(method) \ int do_run_test_##method; \ int test_##method() { static const char *__method__ = #method; if(debug > 0) fprintf(stderr, "%s\n", __method__); #define END_TEST(method) return 0; } #define RUN_TEST(x) do { \ if(runall || do_run_test_##x) { \ r = test_##x(); \ if(r < 0) { \ return r; \ } \ } \ } while(0) #define PARSE_TEST(x) do { \ if(strcmp(av[i], #x) == 0) { \ do_run_test_##x = 1; \ runall = 0; \ } \ } while(0) #define TEST0(test, testname, msg) do { \ if(!(test)) { \ fprintf(stderr, "FAIL %s for test `" #testname "` with message: " msg "\n", __method__); \ return -__LINE__; \ } \ DEBUG(#testname " succeeded"); \ } while(0) #define TEST1(test, testname, msg, p1) do { \ if(!(test)) { \ fprintf(stderr, "FAIL %s for test `" #testname "` with message: " msg "\n", __method__, p1); \ return -__LINE__; \ } \ DEBUG(#testname " succeeded"); \ } while(0) #define TEST2(test, testname, msg, p1, p2) do { \ if(!(test)) { \ fprintf(stderr, "FAIL %s for test `" #testname "` with message: " msg "\n", __method__, p1, p2); \ return -__LINE__; \ } \ DEBUG(#testname " succeeded"); \ } while(0) #define TEST3(test, testname, msg, p1, p2, p3) do { \ if(!(test)) { \ fprintf(stderr, "FAIL %s for test `" #testname "` with message: " msg "\n", __method__, p1, p2, p3); \ return -__LINE__; \ } \ DEBUG(#testname " succeeded"); \ } while(0) // End of common parts eztrace-1.1-2/test/pptrace/automatic/errors.c000066400000000000000000000021161265506773700212540ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * errors.c -- test of errors function (errors.h) * * Created on: 4 Aug. 2011 * Author: Damien Martin-Guillerez */ #include #include #include #include #include int test_pptrace_error_reporting() { pptrace_clear_error(); const char *err = pptrace_get_error(); if (err != NULL) return -__LINE__; pptrace_report_error("ERROR"); err = pptrace_get_error(); if (err == NULL || strcmp(err, "ERROR")) return -__LINE__; pptrace_report_error("ERROR %d", 1); err = pptrace_get_error(); if (err == NULL || strcmp(err, "ERROR 1")) return -__LINE__; pptrace_clear_error(); malloc(-1); // Force error err = pptrace_get_error(); if (errno) { return err != NULL && (strcmp(strerror(errno), err) == 0) ? 0 : -__LINE__; } return err == NULL ? 0 : -__LINE__; } int main() { return test_pptrace_error_reporting(); } eztrace-1.1-2/test/pptrace/automatic/hijack.c000066400000000000000000000115251265506773700211750ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * hijack.c - test for symbol hijacking * * Created on: 4 Sep. 2012 * Author: Damien Martin-Guillerez */ #include #include #include #include #include #include #include #include #include #include #include #include "common.h" int testfork; int waitattach; // Common parts pid_t child; int fds[2]; void *bin; char *prog; static inline int run_ipc() { if (testfork) return 0; pipe(fds); child = trace_run(NULL, NULL, NULL, 1); if (child > 0) { close(fds[1]); bin = open_binary(prog); return 1; } return 0; } static inline void close_ipc() { close_binary(bin); close(fds[0]); } #define FINISH_IPC() do { \ trace_detach(child); \ trace_wait(child); \ DEBUG("process finished"); \ } while(0) #define IPC_END() do { \ DEBUG("traced process is exiting"); \ exit(0); \ } while(0) #define READ_WORD(w) TEST1(-1 != read(fds[0], &w, sizeof(w)), read, "read failed with error %s!", strerror(errno)) #define WRITE_WORD(w) write(fds[1], &w, sizeof(w)) void buffer_function() { asm("nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop; nop"); } void bad_function() { char *__method__ = "bad_function"; int r = 3; DEBUG("in"); WRITE_WORD(r); } void (*original_pointer)() = bad_function; void original_function() { char *__method__ = "original_function"; int r = 1; DEBUG("in"); WRITE_WORD(r); } void good_function() { char *__method__ = "good_function"; int r = 2; DEBUG2("in (original_pointer = %p, r = %d)", original_pointer, r); WRITE_WORD(r); original_pointer(); WRITE_WORD(r); DEBUG("out"); } #define BEGIN_TEST_HIJACK(name) \ BEGIN_TEST(name) \ if(run_ipc()) { #define END_TEST_HIJACK(name) \ FINISH_IPC(); \ int r; \ READ_WORD(r); TEST1(r == 2, prolog, "Not in good_function() (r = %d)!", r); \ READ_WORD(r); TEST1(r == 1, original, "Not in original_function() (r = %d)!", r); \ READ_WORD(r); TEST1(r == 2, epilog, "Not in good_function() (r = %d)!", r); \ close_ipc(); \ } else { \ if(waitattach) { fprintf(stderr, "child pid = %d\n", getpid()); sleep(10); } \ original_function(); \ IPC_END(); \ } \ END_TEST(name) // End of common parts BEGIN_TEST_HIJACK(hijack_code) ssize_t res = hijack_code( bin, child, (word_uint) (word_uint) original_function, (word_uint) (word_uint) good_function - (word_uint) (word_uint) original_function, (word_uint) (word_uint) buffer_function, (word_uint) (word_uint) &original_pointer, (word_uint) (word_uint) good_function); TEST1(res > 0, result, "hijack_code returned negative value ("WORD_DEC_FORMAT")!", res); END_TEST_HIJACK(hijack_code) BEGIN_TEST_HIJACK(hijack) INIT_ZZT_SYMBOL(toHijack, (word_uint )original_function, (word_uint )good_function - (word_uint )original_function); INIT_ZZT_SYMBOL(orig, (word_uint )&original_pointer, sizeof(original_pointer)); INIT_ZZT_SYMBOL(repl, (word_uint )good_function, 0); ssize_t res = hijack(bin, child, &toHijack, &orig, &repl); TEST1(res > 0, result, "hijack returned negative value ("WORD_DEC_FORMAT")!", res); END_TEST_HIJACK(hijack) void usage(char **av, char option) { if (option != 0) { fprintf(stderr, "Unknown option '%c'", option); } fprintf( stderr, "Usage: %s [-v[v]dg] [test1 test2 test3 ...]\n" "\t-v output verbose debugging information (the more d option, the more verbose the output)\n" "\t-d don't actually run the tests, simply execute the child (used in conjunction with test specifiers to debug)\n" "\t-g print the pid of the child and sleep 10 seconds after detachment to enable GDB attachment.\n" "\ttest specifies the tests to runs (default is all tests). Available tests: hijack_code, hijack.\n", av[0]); exit(-1); } int main(int ac, char **av) { int r, i, j; debug = 0; testfork = 0; waitattach = 0; int runall = 1; prog = av[0]; for (i = 1; i < ac; i++) { if (av[i][0] == '-') { for (j = 1; av[i][j] != 0; j++) { switch (av[i][j]) { case 'v': debug++; break; case 'g': waitattach++; break; case 'd': testfork++; break; default: usage(av, av[i][j]); } } } else { PARSE_TEST(hijack_code); PARSE_TEST(hijack); } } RUN_TEST(hijack_code); RUN_TEST(hijack); return 0; } eztrace-1.1-2/test/pptrace/automatic/opcodes.c000066400000000000000000000156551265506773700214100ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * opcodes.c - tests for opcode generation * * Created on: 3 Sep. 2012 * Author: Damien Martin-Guillerez */ #include #include #include #include #include #include #include #include #include #include "common.h" #define MIN(a,b) (((a) > (b)) ? (b) : (a)) BEGIN_TEST(insert_opcodes) // Try to insert opcodes in a a buffer size_t size = 10; uint8_t buf[15]; int i; for (i = 0; i < 15; i++) buf[i] = 0; ssize_t offset = 0; ssize_t prev = 0; #define INSERT_OP_TEST(str, expected) do { \ DEBUG2("inserting %s at offset "WORD_DEC_FORMAT, str, offset); \ offset = insert_opcodes((uint8_t*)str, strlen(str), buf, size, offset); \ buf[14] = 0; \ TEST2(offset == MIN(prev + strlen(str), size), return, "returned "WORD_DEC_FORMAT" while awaiting "WORD_DEC_FORMAT"!", offset, MIN(prev + strlen(str), size)); \ TEST2(strcmp(buf, expected) == 0, result, "buffer is `%s` while awaiting `%s`!", buf, expected); \ prev = offset; \ } while(0) INSERT_OP_TEST("ABC", "ABC"); INSERT_OP_TEST("ABCDE", "ABCABCDE"); INSERT_OP_TEST("ABCDE", "ABCABCDEAB"); END_TEST(insert_opcodes) int test_function() { return 1; } BEGIN_TEST(generate_trampoline) void *maped_area; void *maped_area2; ssize_t offset; int (*f)(void); #define GENTRAMP_TEST(options, off) do { \ offset = 0; \ maped_area = mmap(NULL, 1024, PROT_READ|PROT_WRITE|PROT_EXEC, options, -1, 0); \ TEST0(maped_area != MAP_FAILED, set-up_##off, "mmap failed!"); \ maped_area2 = (void*)((uint8_t*)maped_area + off); \ offset = generate_trampoline(maped_area, off, (word_uint)(word_uint)maped_area, (word_uint)(word_uint)test_function); \ TEST1(offset > 0, result_##off, "returned value from generate_trampoline is null or negative ("WORD_DEC_FORMAT")!", offset); \ offset = generate_trampoline(maped_area2, 1024-off, (word_uint)(word_uint)maped_area2, (word_uint)(word_uint)maped_area); \ TEST1(offset > 0, result_##off, "returned value from generate_trampoline is null or negative ("WORD_DEC_FORMAT")!", offset); \ f = (int (*)(void))maped_area2; \ int r = f(); \ TEST1(f() == 1, jump_##off, "jump returned %d while awaiting 1!", r); \ munmap(maped_area, 1024); \ } while(0) GENTRAMP_TEST(MAP_ANONYMOUS | MAP_PRIVATE, 512); GENTRAMP_TEST(MAP_ANONYMOUS | MAP_PRIVATE, 128); GENTRAMP_TEST(MAP_ANONYMOUS | MAP_PRIVATE, 127); GENTRAMP_TEST(MAP_ANONYMOUS | MAP_PRIVATE, 126); GENTRAMP_TEST(MAP_ANONYMOUS | MAP_PRIVATE, 125); #if __WORDSIZE == 64 // Trying 32-bits mapping in 64 bits environment GENTRAMP_TEST(MAP_ANONYMOUS | MAP_PRIVATE | MAP_32BIT, 512); GENTRAMP_TEST(MAP_ANONYMOUS | MAP_PRIVATE | MAP_32BIT, 128); GENTRAMP_TEST(MAP_ANONYMOUS | MAP_PRIVATE | MAP_32BIT, 127); GENTRAMP_TEST(MAP_ANONYMOUS | MAP_PRIVATE | MAP_32BIT, 126); GENTRAMP_TEST(MAP_ANONYMOUS | MAP_PRIVATE | MAP_32BIT, 125); #endif END_TEST(generate_trampoline) BEGIN_TEST(read_jump) uint8_t buffer[] = { // from testcase/test.cc main function 0x55,// push %rbp 0x48, 0x89, 0xe5, // mov %rsp,%rbp 0x48, 0x83, 0xec, 0x10, // sub $0x10,%rsp 0xc7, 0x45, 0xf8, 0x00, 0x00, 0x00, 0x00, // movl $0x0,-0x8(%rbp) 0xeb, 0x34, // jmp , 0x400539 0xc7, 0x45, 0xfc, 0x00, 0x00, 0x00, 0x00, // movl $0x0,-0x4(%rbp) 0xeb, 0x1c, // jmp , 0x40052a 0x8b, 0x45, 0xf8, // mov -0x8(%rbp),%eax 0x0f, 0xaf, 0x45, 0xfc, // imul -0x4(%rbp),%eax 0x89, 0xc6, // mov %eax,%esi 0xbf, 0x3c, 0x06, 0x40, 0x00, // mov $0x40063c,%edi 0xb8, 0x00, 0x00, 0x00, 0x00, // mov $0x0,%eax 0xe8, 0xca, 0xfe, 0xff, 0xff, // callq , 0x4003f0 0x83, 0x45, 0xfc, 0x01, // addl $0x1,-0x4(%rbp) 0x83, 0x7d, 0xfc, 0x13, // cmpl $0x13,-0x4(%rbp) 0x0f, 0x9e, 0xc0, // setle %al 0x84, 0xc0, // test %al,%al 0x75, 0xd9, // jne , 0x40050e 0x83, 0x45, 0xf8, 0x01, // addl $0x1,-0x8(%rbp) 0x83, 0x7d, 0xf8, 0x09, // cmpl $0x9,-0x8(%rbp) 0x0f, 0x9e, 0xc0, // setle %al 0x84, 0xc0, // test %al,%al 0x75, 0xc1, // jne 400505 0xb8, 0x00, 0x00, 0x00, 0x00, // mov $0x0,%eax 0xc9, // leaveq 0xc3, // retq }; int sizes[] = {1, 3, 4, 7, 2, 7, 2, 3, 4, 2, 5, 5, 5, 4, 4, 3, 2, 2, 4, 4, 3, 2, 2, 5, 1, 1, 0}; int jumps[] = {0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1}; int i; size_t offset = 0; // the actual test for (i = 0; sizes[i] != 0; i++) { /* - read_jump(buf, size, offset, prefix): read a jump part that was prefixed * by *prefix* and that is contained at offset *offset* of *buf* (*size* is * the size of *buf*). The returned value is the size of the instruction * if a jump is read, 0 if a valid prefix for a jump was encountered, and < 0 * if the instruction is not a jump. */ ssize_t r = read_jump(buffer, 87, offset, 0); if (r == 0) { r = read_jump(buffer, 87, offset + 1, buffer[offset]); if (r > 0) r++; } if (r < 0) { TEST1(jumps[i] == 0, notjump, "instruction %d was a jump but wasn't detected!", i); } else { TEST2( jumps[i] == 1, jump, "instruction %d wasn't a jump but was detected as one with size "WORD_DEC_FORMAT"!", i, r); TEST3(sizes[i] == r, size, "instruction %d has size %d but got "WORD_DEC_FORMAT"!", i, sizes[i], r); } offset += sizes[i]; } END_TEST(read_jump) void usage(char **av, char option) { if (option != 0) { fprintf(stderr, "Unknown option '%c'", option); } fprintf( stderr, "Usage: %s [-v[v]] [test1 test2 test3 ...]\n" "\t-v output verbose debugging information (the more d option, the more verbose the output)\n" "\ttest specifies the tests to runs (default is all tests). Available tests: insert_opcodes, generate_trampoline, read_jump.\n", av[0]); exit(-1); } int main(int ac, char **av) { int r, i, j; debug = 0; int runall = 1; for (i = 1; i < ac; i++) { if (av[i][0] == '-') { for (j = 1; av[i][j] != 0; j++) { switch (av[i][j]) { case 'v': debug++; break; default: usage(av, av[i][j]); } } } else { PARSE_TEST(insert_opcodes); PARSE_TEST(generate_trampoline); PARSE_TEST(read_jump); } } RUN_TEST(insert_opcodes); RUN_TEST(generate_trampoline); RUN_TEST(read_jump); return 0; } eztrace-1.1-2/test/pptrace/automatic/testcase/000077500000000000000000000000001265506773700214075ustar00rootroot00000000000000eztrace-1.1-2/test/pptrace/automatic/testcase/Makefile000066400000000000000000000011631265506773700230500ustar00rootroot00000000000000# Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis # See COPYING in top-level directory. TESTCASES_=$(patsubst %.c,%,$(wildcard *.c)) ifeq "32" "$(shell getconf LONG_BIT)" BITS=32 else BITS=32 64 endif TESTCASES=$(foreach testcase,$(TESTCASES_),$(foreach b,$(BITS),$(testcase).$(b) $(testcase).$(b).so)) all: $(TESTCASES) echo: echo '$(BITS) + $(TESTCASES_) = $(TESTCASES)' %.32: %.c @$(CC) -m32 -o $@ $^ %.64: %.c @$(CC) -m64 -o $@ $^ %.32.so: %.c @$(CC) -m32 -shared -fPIC -Wl,-Bsymbolic -o $@ $^ %.64.so: %.c @$(CC) -m64 -shared -fPIC -Wl,-Bsymbolic -o $@ $^ clean: @rm -f $(TESTCASES) eztrace-1.1-2/test/pptrace/automatic/testcase/titi.c000066400000000000000000000027401265506773700225270ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * titi.c -- test case for automated tests * * Created on: 2 March. 2011 * Author: Damien Martin-Guillerez */ #include #include #include char *dummy_symbol[] = {"absolutely", "dummy", "heho", NULL}; int silent = 0; void postface() { if (!silent) printf("In postface()\n"); if (!silent) printf("Out postface()\n"); } void preface() { if (!silent) printf("In preface()\n"); if (!silent) printf("Out preface()\n"); } void tata(char *test) { if (!silent) printf("In tata()\n"); if (!silent) printf("%s\n", test); if (!silent) printf("Out tata()\n"); } void titi() { if (!silent) printf("In titi()\n"); tata("Hello, World!"); if (!silent) printf("Out titi()\n"); } int main(int argc, char **argv) { int i; int pause = 0; for (i = 0; i < argc; i++) { if (strcmp(argv[i], "-p") == 0) { pause = 1; } if (strcmp(argv[i], "-s") == 0) { silent = 1; } } if (!silent) { printf("Entering program with usage : "); for (i = 0; i < argc; i++) { printf("%s ", argv[i]); } printf("\n"); } if (pause) { printf("Enter a key to continue: "); getchar(); printf("\n"); } titi(); if (!silent) { printf("Exiting program\n"); } return 0; } eztrace-1.1-2/test/pptrace/automatic/tracing.c000066400000000000000000000171121265506773700213710ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * tracing.c - test for tracing functions * * Created on: 26 Aug. 2012 * Author: Damien Martin-Guillerez */ #include #include #include #include #include #include #include #include #include "common.h" int testfork; // Common parts #if __x86_64__ // x86_64 #define instr_call_parent() asm("int3") #elif __arm__ // ARMv7 #define instr_call_parent() asm("bkpt #0") #endif #define call_parent() \ do { \ DEBUG("traced process is before call_parent"); \ instr_call_parent(); \ DEBUG("traced process is after call_parent"); \ } while(0) #define call_parent_lbl(lbl) \ do { \ DEBUG("traced process is before call_parent"); \ instr_call_parent(); \ do_lbl(lbl); \ } while(0) #define lbl_name(lbl) test_##lbl #define lbl_addr(lbl) &&lbl_name(lbl) #define do_lbl(lbl) do { \ lbl_name(lbl): \ DEBUG("traced process is after label " #lbl); \ } while(0) pid_t child; int fds[2]; static inline int run_ipc() { if (testfork) return 0; pipe(fds); child = trace_run(NULL, NULL, NULL, 1); return child > 0 ? 1 : 0; } static inline void close_ipc() { close(fds[0]); close(fds[1]); } #define FINISH_IPC() do { \ trace_detach(child); \ trace_wait(child); \ DEBUG("process finished"); \ } while(0) #define IPC_END() do { \ DEBUG("traced process is exiting"); \ exit(0); \ } while(0) #define READ_WORD(w) read(fds[0], &w, sizeof(w)) #define WRITE_WORD(w) write(fds[1], &w, sizeof(w)) // End of common parts BEGIN_TEST(getset_ip) void* r; word_uint rr; // print the ip of the int 3 instruction and propose a function ip if (run_ipc()) { // The tracing process trace_continue(child); r = (void*) get_ip(child); TEST2(lbl_addr(getset_ip_lbl1) == r, get_ip, "returned %p while awaiting %p!", r, lbl_addr(getset_ip_lbl1)); set_ip(child, (word_uint)lbl_addr(getset_ip_lbl2)); FINISH_IPC() ; READ_WORD(rr); TEST1(rr == 1, set_ip, "returned "WORD_DEC_FORMAT" while awaiting 1!", rr); close_ipc(); } else { // The traced process rr = 1; call_parent_lbl(getset_ip_lbl1); rr = 0; do_lbl(getset_ip_lbl2); WRITE_WORD(rr); IPC_END(); } END_TEST(getset_ip) BEGIN_TEST(trace_readwrite) static word_uint result; // try write then read result and compares if (run_ipc()) { word_uint rr; trace_continue(child); READ_WORD(result); trace_read(child, (word_uint) &result, (uint8_t*) &rr, sizeof(rr)); TEST2(rr == result, trace_read, "returned "WORD_HEX_FORMAT" while awaiting "WORD_HEX_FORMAT"!", rr, result); rr = 42; trace_write(child, (word_uint) &result, (uint8_t*) &rr, sizeof(rr)); FINISH_IPC() ; READ_WORD(result); TEST2( rr == result, trace_write, "trace_write(): value of result is "WORD_HEX_FORMAT" while awaiting "WORD_HEX_FORMAT"!", rr, result); close_ipc(); } else { result = 4242; WRITE_WORD(result); call_parent(); WRITE_WORD(result); IPC_END(); } END_TEST(trace_readwrite) BEGIN_TEST(trace_replace) // give one address and the original value and a value to replace static uint8_t value; if (run_ipc()) { trace_continue(child); READ_WORD(value); uint8_t rr = trace_replace(child, (word_uint) &value, 42); TEST2(value == rr, trace_replace, "returned %x while awaiting %x", rr, value); FINISH_IPC() ; READ_WORD(value); TEST1(value == 42, trace_replace, "written %x while awaiting 42", value); close_ipc(); } else { value = 24; WRITE_WORD(value); call_parent(); WRITE_WORD(value); IPC_END(); } END_TEST(trace_replace) BEGIN_TEST(trace_copy) // give two addresses and a string then print the resulting string static char buffer[10]; static const char *tocopy = "BBBBBBBBB\0ABC"; word_uint val = -1; if (run_ipc()) { trace_copy(child, (word_uint) tocopy, (word_uint) buffer, strlen(tocopy) + 1); FINISH_IPC() ; READ_WORD(val); TEST0(val == 1, trace_copy, "the buffer comparison failed"); close_ipc(); } else { val = strcmp(buffer, tocopy) == 0 ? 1 : 0; if (!val) { DEBUG2("%s != %s!", buffer, tocopy); } WRITE_WORD(val); IPC_END(); } END_TEST(trace_copy) BEGIN_TEST(trace_singlestep) void *r; if (run_ipc()) { trace_continue(child); r = (void*) get_ip(child); TEST2(lbl_addr(singlestep_lbl1) == r, set-up, "eip is %p while awaiting %p!", r, lbl_addr(singlestep_lbl1)); trace_singlestep(child); r = (void*) get_ip(child); TEST2(lbl_addr(singlestep_lbl2) == r, singlestep, "eip is %p while awaiting %p!", r, lbl_addr(singlestep_lbl2)); FINISH_IPC() ; close_ipc(); } else { instr_call_parent(); lbl_name(singlestep_lbl1): #if __x86_64__ // x86_64 #if __WORDSIZE == 64 asm("inc %rax"); #else asm("inc %eax"); #endif #elif __arm__ // ARMv7 asm("add r0, r0, #1"); #endif lbl_name(singlestep_lbl2): IPC_END(); } END_TEST(trace_singlestep) BEGIN_TEST(trace_mmap) static char *buf1 = "ABCDEF"; static char *buf2; if (run_ipc()) { word_uint mmap = trace_mmap(child, 0, 1024, PROT_READ | PROT_WRITE); TEST0(mmap != 0, mmap_nonnull, "mmap returned null!"); int errcode = (int) (-(word_uint) mmap); TEST2(errcode < 0 || errcode > 127, mmap_failed, "mmap returned the error code %d (strerror = %s)!", errcode, strerror(errcode)); DEBUG1("trace_mmap returned %p", (void* )mmap); trace_write(child, (word_uint) &buf2, (uint8_t*) &mmap, sizeof(mmap)); DEBUG("written the address of mmap to buf2"); trace_copy(child, (word_uint) buf1, mmap, strlen(buf1) + 1); DEBUG("copied content of buf1 to mmap'd content"); FINISH_IPC() ; READ_WORD(mmap); TEST0(mmap == 1, mmap_copy, "data comparison failed!"); close_ipc(); } else { DEBUG1("buf2 = %p", buf2); word_uint val = strcmp(buf1, buf2) == 0 ? 1 : 0; if (!val) { DEBUG2("%s != %s!", buf1, buf2); } WRITE_WORD(val); IPC_END(); } END_TEST(trace_mmap) void usage(char **av, char option) { if (option != 0) { fprintf(stderr, "Unknown option '%c'", option); } fprintf( stderr, "Usage: %s [-v[v]] [test1 test2 test3 ...]\n" "\t-v output verbose debugging information (the more d option, the more verbose the output)\n" "\t-d don't actually run the tests, simply execute the child (used in conjunction with test specifiers to debug)\n" "\ttest specifies the tests to runs (default is all tests). Available tests: getset_ip, readwrite, replace, copy, singlestep, mmap.\n", av[0]); exit(-1); } int main(int ac, char **av) { int r, i, j; debug = 0; testfork = 0; int runall = 1; for (i = 1; i < ac; i++) { if (av[i][0] == '-') { for (j = 1; av[i][j] != 0; j++) { switch (av[i][j]) { case 'v': debug++; break; case 'd': testfork++; break; default: usage(av, av[i][j]); } } } else { PARSE_TEST(getset_ip); PARSE_TEST(trace_readwrite); PARSE_TEST(trace_replace); PARSE_TEST(trace_copy); PARSE_TEST(trace_singlestep); PARSE_TEST(trace_mmap); } } RUN_TEST(getset_ip); RUN_TEST(trace_readwrite); RUN_TEST(trace_replace); RUN_TEST(trace_copy); RUN_TEST(trace_singlestep); RUN_TEST(trace_mmap); return 0; } eztrace-1.1-2/test/pptrace/automatic/wait_open.c000066400000000000000000000074141265506773700217330ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. * * * wait_open.c - test waiting for open and mmap in both 32 and 64 bits * * Created on: 5 Aug. 2011 * Author: Damien Martin-Guillerez */ #include #include #include #include #include #include #include #include #include char **new_envp(char **envp, char *ldpreload) { int i; for (i = 0; envp[i]; i++) ; char **env = (char**) malloc(sizeof(char*) * (i + 1)); env[0] = (char*) malloc(15 + strlen(ldpreload)); snprintf(env[0], 15 + strlen(ldpreload), "LD_PRELOAD=%s", ldpreload); for (i = 0; envp[i]; i++) env[i + 1] = envp[i]; env[i + 1] = NULL; return env; } int test(int debug, char *prog, char *lib, char **envp) { char *argv[] = {NULL, "-s", NULL}; argv[0] = prog; char **env = new_envp(envp, lib); void *bin = open_binary(prog); if (bin == NULL) { fprintf(stderr, "Failed to open binary %s!\n", prog); return -__LINE__; } trace_set_bits(get_binary_bits(bin)); close_binary(bin); pid_t child = trace_run(prog, argv, env, 1); //memory leak here to avoid double free on hydra //free(env[0]); //free(env); if (child <= 0) { fprintf(stderr, "Failed to trace process %s!\n", prog); return -__LINE__; } //open("/etc/ld.so.cache", *) word_uint fd; if (trace_wait_syscall(child, &fd, TRACE_SYSCALL(open), SYSCALL_ARGTYPE_ZSTRING, lib, SYSCALL_ARGTYPE_IGNORE, SYSCALL_ARGTYPE_END) < 0) { fprintf(stderr, "Failed to wait for open(\"%s\", *) for process %s (pid = %d)!\n", lib, prog, child); trace_detach(child); return -__LINE__; } if (debug) printf("open(\"%s\", *) = "WORD_DEC_FORMAT"\n", lib, fd); if ((int) fd < 3) { fprintf( stderr, "open(\"%s\", *) returned a negative value or a reserved file descriptor ("WORD_DEC_FORMAT" - "WORD_HEX_FORMAT") for process %s (pid = %d)!\n", lib, fd, fd, prog, child); return -__LINE__; } //mmap(NULL, 22967, PROT_READ, MAP_PRIVATE, 3, 0) = 0x7f4b50756000 //mmap(NULL, *, *, *, fd, 0) word_uint addr; if (trace_wait_syscall(child, &addr, MMAP_SYSCALLS, SYSCALL_ARGTYPE_IGNORE, SYSCALL_ARGTYPE_IGNORE, SYSCALL_ARGTYPE_INT, (word_uint) (PROT_READ | PROT_EXEC), SYSCALL_ARGTYPE_IGNORE, SYSCALL_ARGTYPE_INT, (word_uint) fd, SYSCALL_ARGTYPE_IGNORE, SYSCALL_ARGTYPE_END) < 0) { fprintf( stderr, "Failed to wait for mmap(*, *, PROT_READ|PROT_EXEC, *, "WORD_DEC_FORMAT", *) for process %s (pid = %d)!\n", fd, prog, child); trace_detach(child); return -__LINE__; } if (debug) printf( "mmap(*, *, PROT_READ|PROT_EXEC, *, "WORD_DEC_FORMAT", *) = "WORD_HEX_FORMAT"\n", fd, addr); if ((void*) addr == MAP_FAILED) { fprintf( stderr, "mmap(*, *, PROT_READ|PROT_EXEC, *, "WORD_DEC_FORMAT", *) returned MAP_FAILED for process %s (pid = %d)!\n", fd, prog, child); return -__LINE__; } trace_detach(child); trace_wait(child); return EXIT_SUCCESS; } int main(int argc, char **argv, char **envp) { int debug = 0; int i; for (i = 1; argv[i] != NULL; i++) { if (strcasecmp(argv[i], "-d") == 0) { debug = 1; } else if (strstr(argv[i], ".so") == NULL) { char lib[1024]; strcpy(lib, argv[i]); strcat(lib, ".so"); int r = test(debug, argv[i], lib, envp); if (r) { return r; } } } return EXIT_SUCCESS; } eztrace-1.1-2/test/pthread/000077500000000000000000000000001265506773700155775ustar00rootroot00000000000000eztrace-1.1-2/test/pthread/Makefile.am000066400000000000000000000005121265506773700176310ustar00rootroot00000000000000# Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 # See COPYING in top-level directory. check_PROGRAMS = cond dummy_thread test_pthread cond_SOURCES = cond.c cond_LDFLAGS = -lpthread dummy_thread_SOURCES = dummy_thread.c dummy_thread_LDFLAGS = -lpthread test_pthread_SOURCES = test_pthread.c test_pthread_LDFLAGS = -lpthread eztrace-1.1-2/test/pthread/Makefile.in000066400000000000000000000512101265506773700176430ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ check_PROGRAMS = cond$(EXEEXT) dummy_thread$(EXEEXT) \ test_pthread$(EXEEXT) subdir = test/pthread ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am_cond_OBJECTS = cond.$(OBJEXT) cond_OBJECTS = $(am_cond_OBJECTS) cond_LDADD = $(LDADD) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = cond_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(cond_LDFLAGS) $(LDFLAGS) -o $@ am_dummy_thread_OBJECTS = dummy_thread.$(OBJEXT) dummy_thread_OBJECTS = $(am_dummy_thread_OBJECTS) dummy_thread_LDADD = $(LDADD) dummy_thread_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(dummy_thread_LDFLAGS) $(LDFLAGS) -o $@ am_test_pthread_OBJECTS = test_pthread.$(OBJEXT) test_pthread_OBJECTS = $(am_test_pthread_OBJECTS) test_pthread_LDADD = $(LDADD) test_pthread_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(test_pthread_LDFLAGS) $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(cond_SOURCES) $(dummy_thread_SOURCES) \ $(test_pthread_SOURCES) DIST_SOURCES = $(cond_SOURCES) $(dummy_thread_SOURCES) \ $(test_pthread_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ cond_SOURCES = cond.c cond_LDFLAGS = -lpthread dummy_thread_SOURCES = dummy_thread.c dummy_thread_LDFLAGS = -lpthread test_pthread_SOURCES = test_pthread.c test_pthread_LDFLAGS = -lpthread all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu test/pthread/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu test/pthread/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): clean-checkPROGRAMS: @list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list cond$(EXEEXT): $(cond_OBJECTS) $(cond_DEPENDENCIES) $(EXTRA_cond_DEPENDENCIES) @rm -f cond$(EXEEXT) $(AM_V_CCLD)$(cond_LINK) $(cond_OBJECTS) $(cond_LDADD) $(LIBS) dummy_thread$(EXEEXT): $(dummy_thread_OBJECTS) $(dummy_thread_DEPENDENCIES) $(EXTRA_dummy_thread_DEPENDENCIES) @rm -f dummy_thread$(EXEEXT) $(AM_V_CCLD)$(dummy_thread_LINK) $(dummy_thread_OBJECTS) $(dummy_thread_LDADD) $(LIBS) test_pthread$(EXEEXT): $(test_pthread_OBJECTS) $(test_pthread_DEPENDENCIES) $(EXTRA_test_pthread_DEPENDENCIES) @rm -f test_pthread$(EXEEXT) $(AM_V_CCLD)$(test_pthread_LINK) $(test_pthread_OBJECTS) $(test_pthread_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cond.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/dummy_thread.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test_pthread.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am $(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS) check: check-am all-am: Makefile installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-checkPROGRAMS clean-generic clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: .MAKE: check-am install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ clean-checkPROGRAMS clean-generic clean-libtool cscopelist-am \ ctags ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/test/pthread/cond.c000066400000000000000000000020121265506773700166610ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 0) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stdout, fmt, va); va_end(va); } } // end of debugging part int main() { pthread_cond_t cond; pthread_mutex_t mutex; debug("Testing pthread_cond_*\n"); pthread_cond_init(&cond, NULL); pthread_mutex_init(&mutex, NULL); pthread_mutex_lock(&mutex); pthread_cond_signal(&cond); pthread_cond_broadcast(&cond); pthread_mutex_unlock(&mutex); pthread_cond_destroy(&cond); debug("OK ! \n"); return 0; } eztrace-1.1-2/test/pthread/dummy_thread.c000066400000000000000000000050501265506773700204250ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include #include #include #include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 0) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stdout, fmt, va); va_end(va); } } // end of debugging part /* Number of iterations */ #define ITER 10 /* Number of threads */ #define NTH 2 typedef union { unsigned long long tick; struct { unsigned low; unsigned high; }; } tick_t; #define TICK_DIFF(t1, t2) \ ((t2).tick - (t1).tick) #define TIME_DIFF(t1, t2) \ ((t2.tv_sec - t1.tv_sec) * 1000000 + (t2.tv_usec - t1.tv_usec)) /* Only used during thread creating to make sure that the thread * got the correct args. */ sem_t thread_ready; /* Block/unblock a thread */ sem_t sem[NTH]; pthread_mutex_t mutex; /* Fake computation of usec microseconds */ void compute(int usec) { struct timeval tv1, tv2; gettimeofday(&tv1, NULL); do { gettimeofday(&tv2, NULL); } while (TIME_DIFF(tv1, tv2) < usec); } void* f_thread(void* arg) { uint8_t my_id = *(uint8_t*) arg; /* Notify the main thread that we got the args */ sem_post(&thread_ready); debug("Running thread #%d\n", my_id); int i; for (i = 0; i < ITER; i++) { /* Wait until the previous thread has finished his job */ sem_wait(&sem[my_id]); debug("[thread #%d] loop %d\n", my_id, i); /* compute for 1ms */ pthread_mutex_lock(&mutex); compute(50000); pthread_mutex_unlock(&mutex); compute(50000); /* Wake up the next thread */ sem_post(&sem[(my_id + 1) % NTH]); } debug("End of thread #%d\n", my_id); return NULL; } int main(int argc, char**argv) { pthread_t tid[NTH]; int i; pthread_mutex_init(&mutex, NULL); sem_init(&thread_ready, 0, 0); for (i = 0; i < NTH; i++) sem_init(&sem[i], 0, 0); for (i = 0; i < NTH; i++) { pthread_create(&tid[i], NULL, f_thread, &i); sem_wait(&thread_ready); } /* Unblock the first thread so that it can start working */ sem_post(&sem[0]); for (i = 0; i < NTH; i++) { pthread_join(tid[i], NULL); } return 0; } eztrace-1.1-2/test/pthread/race_cond.c000066400000000000000000000036111265506773700176610ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include #include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 0) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stdout, fmt, va); va_end(va); } } // end of debugging part // Number of threads #define NBTHREAD 2 // Number of iterations #define NBITER 10000 /* * Only used during thread creating to make sure that the thread * got the correct args. */ sem_t thread_ready; pthread_barrier_t barrier; volatile int sum = 0; void compute() __attribute__((optimize("-O0"))); void compute() { int i; for (i = 0; i < NBITER; i++) { void *ptr = malloc(1); free(ptr); sum += 1; } } void* do_work(void* arg) { uint8_t my_id = *(uint8_t*) arg; // Notify the main thread that we got the args sem_post(&thread_ready); debug("Running thread #%d\n", my_id); pthread_barrier_wait(&barrier); compute(); pthread_barrier_wait(&barrier); debug("End of thread #%d\n", my_id); return NULL; } int main() { pthread_t tid[NBTHREAD]; int i; pthread_barrier_init(&barrier, NULL, NBTHREAD); sem_init(&thread_ready, 0, 0); for (i = 0; i < NBTHREAD; i++) { pthread_create(&tid[i], NULL, do_work, &i); sem_wait(&thread_ready); } for (i = 0; i < NBTHREAD; i++) pthread_join(tid[i], NULL); printf("Thread sum: %d\n", sum); sum = NBTHREAD * NBITER; printf("Check sum: %d\n", sum); pthread_barrier_destroy(&barrier); return 0; } eztrace-1.1-2/test/pthread/test_pthread.c000066400000000000000000000070231265506773700204330ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include #include #include #include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 0) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stdout, fmt, va); va_end(va); } } // end of debugging part /* Number of iterations */ #define ITER 10 /* Number of threads */ #define NTH 2 typedef union { unsigned long long tick; struct { unsigned low; unsigned high; }; } tick_t; #define TICK_DIFF(t1, t2) \ ((t2).tick - (t1).tick) #define TIME_DIFF(t1, t2) \ ((t2.tv_sec - t1.tv_sec) * 1000000 + (t2.tv_usec - t1.tv_usec)) /* Only used during thread creating to make sure that the thread * got the correct args. */ sem_t thread_ready; /* Block/unblock a thread */ sem_t sem[NTH]; pthread_mutex_t mutex; pthread_spinlock_t spinlock; pthread_barrier_t barrier; pthread_cond_t cond; pthread_rwlock_t rwlock; /* Fake computation of usec microseconds */ void compute(int usec) { struct timeval tv1, tv2; gettimeofday(&tv1, NULL); do { gettimeofday(&tv2, NULL); } while (TIME_DIFF(tv1, tv2) < usec); } void* f_thread(void* arg) { uint8_t my_id = *(uint8_t*) arg; /* Notify the main thread that we got the args */ sem_post(&thread_ready); debug("Running thread #%d\n", my_id); pthread_barrier_wait(&barrier); int i; for (i = 0; i < ITER; i++) { /* Wait until the previous thread has finished his job */ sem_wait(&sem[my_id]); debug("[thread #%d] loop %d\n", my_id, i); /* test mutex */ pthread_mutex_lock(&mutex); compute(5000); pthread_mutex_unlock(&mutex); compute(5000); /* test spinlock */ pthread_spin_lock(&spinlock); compute(5000); pthread_spin_unlock(&spinlock); compute(5000); /* test spinlock */ pthread_spin_lock(&spinlock); compute(5000); pthread_spin_unlock(&spinlock); compute(5000); /* test rwlock */ pthread_rwlock_rdlock(&rwlock); compute(5000); pthread_rwlock_unlock(&rwlock); compute(5000); pthread_rwlock_wrlock(&rwlock); compute(5000); pthread_rwlock_unlock(&rwlock); compute(5000); /* Wake up the next thread */ sem_post(&sem[(my_id + 1) % NTH]); } pthread_barrier_wait(&barrier); debug("End of thread #%d\n", my_id); return NULL; } int main(int argc, char**argv) { pthread_t tid[NTH]; int i; pthread_mutex_init(&mutex, NULL); pthread_spin_init(&spinlock, 0); pthread_barrier_init(&barrier, NULL, NTH); pthread_cond_init(&cond, NULL); pthread_rwlock_init(&rwlock, NULL); sem_init(&thread_ready, 0, 0); for (i = 0; i < NTH; i++) sem_init(&sem[i], 0, 0); for (i = 0; i < NTH; i++) { pthread_create(&tid[i], NULL, f_thread, &i); sem_wait(&thread_ready); } /* Unblock the first thread so that it can start working */ sem_post(&sem[0]); for (i = 0; i < NTH; i++) { pthread_join(tid[i], NULL); } pthread_mutex_destroy(&mutex); pthread_spin_destroy(&spinlock); pthread_barrier_destroy(&barrier); pthread_cond_destroy(&cond); pthread_rwlock_destroy(&rwlock); return 0; } eztrace-1.1-2/test/pthread/test_sigsegv.c000066400000000000000000000044161265506773700204560ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include #include #include #include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 0) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stdout, fmt, va); va_end(va); } } // end of debugging part /* This program calls functions (more or less) randomly and recursively. * At some point, it raises a SIGSEGV. */ typedef union { unsigned long long tick; struct { unsigned low; unsigned high; }; } tick_t; #define TICK_DIFF(t1, t2) \ ((t2).tick - (t1).tick) #define TIME_DIFF(t1, t2) \ ((t2.tv_sec - t1.tv_sec) * 1000000 + (t2.tv_usec - t1.tv_usec)) void func1(int a); void func2(int a); void func3(int a); /* Fake computation of usec microseconds */ void compute(int usec) { struct timeval tv1, tv2; gettimeofday(&tv1, NULL); do { gettimeofday(&tv2, NULL); } while (TIME_DIFF(tv1, tv2) < usec); } void func1(int a) { debug("func1(%d)\n", a); compute(100 * a); int alea = rand() % 7; if (!alea) *(int*) 0 = 0; switch (a % 3) { case 0: func1(a - 1); break; case 1: func2(a - 1); break; case 2: func3(a - 1); break; } } void func2(int a) { debug("func2(%d)\n", a); compute(100 * a); int alea = rand() % 6; if (!alea) *(int*) 0 = 0; switch (a % 3) { case 0: func1(a - 1); break; case 1: func2(a - 1); break; case 2: func3(a - 1); break; } } void func3(int a) { debug("func3(%d)\n", a); compute(100 * a); int alea = rand() % 5; if (!alea) *(int*) 0 = 0; switch (a % 3) { case 0: func1(a - 1); break; case 1: func2(a - 1); break; case 2: func3(a - 1); break; } } int main(int argc, char**argv) { srand(time(NULL)); while (1) func1(rand() % 101); return 0; } eztrace-1.1-2/test/static/000077500000000000000000000000001265506773700154375ustar00rootroot00000000000000eztrace-1.1-2/test/static/Makefile.am000066400000000000000000000042351265506773700174770ustar00rootroot00000000000000# Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 # See COPYING in top-level directory. if AMEXTERNLITL TLCFLAGS=$(TL_CPPFLAGS) TLLDFLAGS=$(TL_LDFLAGS) TLLIBADD=$(TL_LIB) else # AMEXTERNLITL TLCFLAGS = -I$(top_srcdir)/extlib/litl/src -I$(top_builddir)/extlib/litl/src TLLDFLAGS = $(top_builddir)/extlib/litl/src/liblitl.la TLLIBADD=$(TL_LIB) endif # AMINTERNLITL if AMEXTERNGTG GTGCFLAGS=$(GTG_CPPFLAGS) GTGLDFLAGS=$(GTG_LDFLAGS) GTGDEPENDENCIES = GTGLIBADD=$(GTG_LIB) else GTGCFLAGS = -I$(top_srcdir)/extlib/gtg/inc -I$(top_builddir)/extlib/gtg GTGLDFLAGS = $(top_builddir)/extlib/gtg/src/libgtg.la GTGDEPENDENCIES = $(GTGLDFLAGS) GTGLIBADD= endif EZT_DEPS = $(top_builddir)/src/core/eztrace_config.h if GTG_OUT_OF_ORDER GTGCFLAGS+=-DGTG_OUT_OF_ORDER endif check_PROGRAMS = static check_LTLIBRARIES = libeztrace-convert-staticlib.la\ libeztrace-staticlib.la\ libeztrace-autostart-staticlib.la static_SOURCES = static.c AM_CFLAGS = -W -Wall -Wextra -I$(top_builddir)/src/core/ -I$(top_srcdir)/src/core -I$(top_srcdir)/src/pptrace libeztrace_convert_staticlib_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) libeztrace_convert_staticlib_la_LIBADD = $(TLLIBADD) $(GTG_LIB) libeztrace_convert_staticlib_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) -module -avoid-version -rpath /dev/null libeztrace_convert_staticlib_la_DEPENDENCIES = $(GTGDEPENDENCIES) $(EZT_DEPS) libeztrace_convert_staticlib_la_SOURCES = eztrace_convert_staticlib.c libeztrace_staticlib_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_staticlib_la_LIBADD = $(TLLIBADD) libeztrace_staticlib_la_LDFLAGS = --no-undefined $(TLLDFLAGS) -Wl,-Bsymbolic -module -avoid-version -rpath /dev/null libeztrace_staticlib_la_SOURCES = staticlib.c libeztrace_autostart_staticlib_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_autostart_staticlib_la_LIBADD = $(TLLIBADD) libeztrace_autostart_staticlib_la_LDFLAGS = --no-undefined $(TLLDFLAGS) -Wl,-Bsymbolic -module -avoid-version -rpath /dev/null libeztrace_autostart_staticlib_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra -DEZTRACE_AUTOSTART libeztrace_autostart_staticlib_la_SOURCES = staticlib.c noinst_HEADERS = staticlib_ev_codes.h eztrace-1.1-2/test/static/Makefile.in000066400000000000000000000711621265506773700175130ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @GTG_OUT_OF_ORDER_TRUE@am__append_1 = -DGTG_OUT_OF_ORDER check_PROGRAMS = static$(EXEEXT) subdir = test/static ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(noinst_HEADERS) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__DEPENDENCIES_1 = @AMEXTERNLITL_FALSE@am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) @AMEXTERNLITL_TRUE@am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) libeztrace_autostart_staticlib_la_DEPENDENCIES = \ $(am__DEPENDENCIES_2) am_libeztrace_autostart_staticlib_la_OBJECTS = \ libeztrace_autostart_staticlib_la-staticlib.lo libeztrace_autostart_staticlib_la_OBJECTS = \ $(am_libeztrace_autostart_staticlib_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libeztrace_autostart_staticlib_la_LINK = $(LIBTOOL) $(AM_V_lt) \ --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link \ $(CCLD) $(libeztrace_autostart_staticlib_la_CFLAGS) $(CFLAGS) \ $(libeztrace_autostart_staticlib_la_LDFLAGS) $(LDFLAGS) -o $@ am_libeztrace_convert_staticlib_la_OBJECTS = \ libeztrace_convert_staticlib_la-eztrace_convert_staticlib.lo libeztrace_convert_staticlib_la_OBJECTS = \ $(am_libeztrace_convert_staticlib_la_OBJECTS) libeztrace_convert_staticlib_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) \ $(libeztrace_convert_staticlib_la_LDFLAGS) $(LDFLAGS) -o $@ libeztrace_staticlib_la_DEPENDENCIES = $(am__DEPENDENCIES_2) am_libeztrace_staticlib_la_OBJECTS = \ libeztrace_staticlib_la-staticlib.lo libeztrace_staticlib_la_OBJECTS = \ $(am_libeztrace_staticlib_la_OBJECTS) libeztrace_staticlib_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libeztrace_staticlib_la_LDFLAGS) \ $(LDFLAGS) -o $@ am_static_OBJECTS = static.$(OBJEXT) static_OBJECTS = $(am_static_OBJECTS) static_LDADD = $(LDADD) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libeztrace_autostart_staticlib_la_SOURCES) \ $(libeztrace_convert_staticlib_la_SOURCES) \ $(libeztrace_staticlib_la_SOURCES) $(static_SOURCES) DIST_SOURCES = $(libeztrace_autostart_staticlib_la_SOURCES) \ $(libeztrace_convert_staticlib_la_SOURCES) \ $(libeztrace_staticlib_la_SOURCES) $(static_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac HEADERS = $(noinst_HEADERS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ @AMEXTERNLITL_FALSE@TLCFLAGS = -I$(top_srcdir)/extlib/litl/src -I$(top_builddir)/extlib/litl/src @AMEXTERNLITL_TRUE@TLCFLAGS = $(TL_CPPFLAGS) @AMEXTERNLITL_FALSE@TLLDFLAGS = $(top_builddir)/extlib/litl/src/liblitl.la @AMEXTERNLITL_TRUE@TLLDFLAGS = $(TL_LDFLAGS) @AMEXTERNLITL_FALSE@TLLIBADD = $(TL_LIB) @AMEXTERNLITL_TRUE@TLLIBADD = $(TL_LIB) @AMEXTERNGTG_FALSE@GTGCFLAGS = -I$(top_srcdir)/extlib/gtg/inc \ @AMEXTERNGTG_FALSE@ -I$(top_builddir)/extlib/gtg \ @AMEXTERNGTG_FALSE@ $(am__append_1) @AMEXTERNGTG_TRUE@GTGCFLAGS = $(GTG_CPPFLAGS) $(am__append_1) @AMEXTERNGTG_FALSE@GTGLDFLAGS = $(top_builddir)/extlib/gtg/src/libgtg.la @AMEXTERNGTG_TRUE@GTGLDFLAGS = $(GTG_LDFLAGS) @AMEXTERNGTG_FALSE@GTGDEPENDENCIES = $(GTGLDFLAGS) @AMEXTERNGTG_TRUE@GTGDEPENDENCIES = @AMEXTERNGTG_FALSE@GTGLIBADD = @AMEXTERNGTG_TRUE@GTGLIBADD = $(GTG_LIB) EZT_DEPS = $(top_builddir)/src/core/eztrace_config.h check_LTLIBRARIES = libeztrace-convert-staticlib.la\ libeztrace-staticlib.la\ libeztrace-autostart-staticlib.la static_SOURCES = static.c AM_CFLAGS = -W -Wall -Wextra -I$(top_builddir)/src/core/ -I$(top_srcdir)/src/core -I$(top_srcdir)/src/pptrace libeztrace_convert_staticlib_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) $(GTGCFLAGS) libeztrace_convert_staticlib_la_LIBADD = $(TLLIBADD) $(GTG_LIB) libeztrace_convert_staticlib_la_LDFLAGS = $(GTGLDFLAGS) $(TLLDFLAGS) -module -avoid-version -rpath /dev/null libeztrace_convert_staticlib_la_DEPENDENCIES = $(GTGDEPENDENCIES) $(EZT_DEPS) libeztrace_convert_staticlib_la_SOURCES = eztrace_convert_staticlib.c libeztrace_staticlib_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_staticlib_la_LIBADD = $(TLLIBADD) libeztrace_staticlib_la_LDFLAGS = --no-undefined $(TLLDFLAGS) -Wl,-Bsymbolic -module -avoid-version -rpath /dev/null libeztrace_staticlib_la_SOURCES = staticlib.c libeztrace_autostart_staticlib_la_CPPFLAGS = $(AM_CPPFLAGS) $(TLCFLAGS) libeztrace_autostart_staticlib_la_LIBADD = $(TLLIBADD) libeztrace_autostart_staticlib_la_LDFLAGS = --no-undefined $(TLLDFLAGS) -Wl,-Bsymbolic -module -avoid-version -rpath /dev/null libeztrace_autostart_staticlib_la_CFLAGS = $(AM_CFLAGS) -W -Wall -Wextra -DEZTRACE_AUTOSTART libeztrace_autostart_staticlib_la_SOURCES = staticlib.c noinst_HEADERS = staticlib_ev_codes.h all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu test/static/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu test/static/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): clean-checkLTLIBRARIES: -test -z "$(check_LTLIBRARIES)" || rm -f $(check_LTLIBRARIES) @list='$(check_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libeztrace-autostart-staticlib.la: $(libeztrace_autostart_staticlib_la_OBJECTS) $(libeztrace_autostart_staticlib_la_DEPENDENCIES) $(EXTRA_libeztrace_autostart_staticlib_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_autostart_staticlib_la_LINK) $(libeztrace_autostart_staticlib_la_OBJECTS) $(libeztrace_autostart_staticlib_la_LIBADD) $(LIBS) libeztrace-convert-staticlib.la: $(libeztrace_convert_staticlib_la_OBJECTS) $(libeztrace_convert_staticlib_la_DEPENDENCIES) $(EXTRA_libeztrace_convert_staticlib_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_convert_staticlib_la_LINK) $(libeztrace_convert_staticlib_la_OBJECTS) $(libeztrace_convert_staticlib_la_LIBADD) $(LIBS) libeztrace-staticlib.la: $(libeztrace_staticlib_la_OBJECTS) $(libeztrace_staticlib_la_DEPENDENCIES) $(EXTRA_libeztrace_staticlib_la_DEPENDENCIES) $(AM_V_CCLD)$(libeztrace_staticlib_la_LINK) $(libeztrace_staticlib_la_OBJECTS) $(libeztrace_staticlib_la_LIBADD) $(LIBS) clean-checkPROGRAMS: @list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list static$(EXEEXT): $(static_OBJECTS) $(static_DEPENDENCIES) $(EXTRA_static_DEPENDENCIES) @rm -f static$(EXEEXT) $(AM_V_CCLD)$(LINK) $(static_OBJECTS) $(static_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_autostart_staticlib_la-staticlib.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_convert_staticlib_la-eztrace_convert_staticlib.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libeztrace_staticlib_la-staticlib.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/static.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< libeztrace_autostart_staticlib_la-staticlib.lo: staticlib.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_staticlib_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_staticlib_la_CFLAGS) $(CFLAGS) -MT libeztrace_autostart_staticlib_la-staticlib.lo -MD -MP -MF $(DEPDIR)/libeztrace_autostart_staticlib_la-staticlib.Tpo -c -o libeztrace_autostart_staticlib_la-staticlib.lo `test -f 'staticlib.c' || echo '$(srcdir)/'`staticlib.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_autostart_staticlib_la-staticlib.Tpo $(DEPDIR)/libeztrace_autostart_staticlib_la-staticlib.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='staticlib.c' object='libeztrace_autostart_staticlib_la-staticlib.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_autostart_staticlib_la_CPPFLAGS) $(CPPFLAGS) $(libeztrace_autostart_staticlib_la_CFLAGS) $(CFLAGS) -c -o libeztrace_autostart_staticlib_la-staticlib.lo `test -f 'staticlib.c' || echo '$(srcdir)/'`staticlib.c libeztrace_convert_staticlib_la-eztrace_convert_staticlib.lo: eztrace_convert_staticlib.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_staticlib_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_convert_staticlib_la-eztrace_convert_staticlib.lo -MD -MP -MF $(DEPDIR)/libeztrace_convert_staticlib_la-eztrace_convert_staticlib.Tpo -c -o libeztrace_convert_staticlib_la-eztrace_convert_staticlib.lo `test -f 'eztrace_convert_staticlib.c' || echo '$(srcdir)/'`eztrace_convert_staticlib.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_convert_staticlib_la-eztrace_convert_staticlib.Tpo $(DEPDIR)/libeztrace_convert_staticlib_la-eztrace_convert_staticlib.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='eztrace_convert_staticlib.c' object='libeztrace_convert_staticlib_la-eztrace_convert_staticlib.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_convert_staticlib_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_convert_staticlib_la-eztrace_convert_staticlib.lo `test -f 'eztrace_convert_staticlib.c' || echo '$(srcdir)/'`eztrace_convert_staticlib.c libeztrace_staticlib_la-staticlib.lo: staticlib.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_staticlib_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libeztrace_staticlib_la-staticlib.lo -MD -MP -MF $(DEPDIR)/libeztrace_staticlib_la-staticlib.Tpo -c -o libeztrace_staticlib_la-staticlib.lo `test -f 'staticlib.c' || echo '$(srcdir)/'`staticlib.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libeztrace_staticlib_la-staticlib.Tpo $(DEPDIR)/libeztrace_staticlib_la-staticlib.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='staticlib.c' object='libeztrace_staticlib_la-staticlib.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libeztrace_staticlib_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libeztrace_staticlib_la-staticlib.lo `test -f 'staticlib.c' || echo '$(srcdir)/'`staticlib.c mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am $(MAKE) $(AM_MAKEFLAGS) $(check_LTLIBRARIES) $(check_PROGRAMS) check: check-am all-am: Makefile $(HEADERS) installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-checkLTLIBRARIES clean-checkPROGRAMS clean-generic \ clean-libtool mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: .MAKE: check-am install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ clean-checkLTLIBRARIES clean-checkPROGRAMS clean-generic \ clean-libtool cscopelist-am ctags ctags-am distclean \ distclean-compile distclean-generic distclean-libtool \ distclean-tags distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-info install-info-am install-man \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ pdf pdf-am ps ps-am tags tags-am uninstall uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/test/static/eztrace_convert_staticlib.c000066400000000000000000000053671265506773700230510ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include "eztrace_convert.h" #include "staticlib_ev_codes.h" int eztrace_convert_staticlib_init(); int handle_staticlib_events(eztrace_event_t *ev); void handleEZTRACE_staticlib_mafunc_1(); void handleEZTRACE_staticlib_mafunc_2(); /* Constructor of the plugin. * This function registers the current module to eztrace_convert */ struct eztrace_convert_module staticlib_module; void libinit(void) __attribute__ ((constructor)); void libinit(void) { staticlib_module.api_version = EZTRACE_API_VERSION; /* Specify the initialization function. * This function will be called once all the plugins are loaded * and the trace is started. * This function usually declared StateTypes, LinkTypes, etc. */ staticlib_module.init = eztrace_convert_staticlib_init; /* Specify the function to call for handling an event */ staticlib_module.handle = handle_staticlib_events; /* Specify the module prefix */ staticlib_module.module_prefix = staticlib_EVENTS_ID; asprintf(&staticlib_module.name, "staticlib"); asprintf(&staticlib_module.description, "module for the example library"); staticlib_module.token.data = &staticlib_module; /* Register the module to eztrace_convert */ eztrace_convert_register_module(&staticlib_module); //printf("module staticlib loaded\n"); } void libfinalize(void) __attribute__ ((destructor)); void libfinalize(void) { //printf("unloading module staticlib\n"); } /* * This function will be called once all the plugins are loaded * and the trace is started. * This function usually declared StateTypes, LinkTypes, etc. */ int eztrace_convert_staticlib_init() { addEntityValue("staticlib_STATE_0", "ST_Thread", "Doing function mafunc", GTG_PINK); } /* This function is called by eztrace_convert for each event to * handle. * It shall return 1 if the event was handled successfully or * 0 otherwise. */ int handle_staticlib_events(eztrace_event_t *ev) { switch (LITL_READ_GET_CODE(ev)) { case EZTRACE_staticlib_mafunc_1: handleEZTRACE_staticlib_mafunc_1(); break; case EZTRACE_staticlib_mafunc_2: handleEZTRACE_staticlib_mafunc_2(); break; default: /* The event was not handled */ return 0; } return 1; } void handleEZTRACE_staticlib_mafunc_1() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() pushState(CURRENT, "ST_Thread", thread_id, "staticlib_STATE_0"); } void handleEZTRACE_staticlib_mafunc_2() { FUNC_NAME; DECLARE_THREAD_ID_STR(thread_id, CUR_INDEX, CUR_THREAD_ID); CHANGE() popState(CURRENT, "ST_Thread", thread_id); } eztrace-1.1-2/test/static/static.c000066400000000000000000000022011265506773700170650ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } if (_debug >= 0) { // debug verbose mode va_list va; va_start(va, fmt); vfprintf(stdout, fmt, va); va_end(va); } } // end of debugging part #define microsleep(us) do { struct timespec tm; tm.tv_sec = (time_t)us / 1000; tm.tv_nsec = (long)(us % 1000) * 1000; nanosleep(&tm, NULL); } while(0) int mafunc(int n) { debug("i sleep %d microsec\n", n); microsleep(n); return EXIT_SUCCESS; } int main() { int i = 0; debug("hello i m in main an i will wait 4 microsec\n"); microsleep(4); for (i = 0; i < 4; i++) { mafunc(i); debug("main sleep 1 microsec\n"); microsleep(1); } return EXIT_SUCCESS; } eztrace-1.1-2/test/static/staticlib.c000066400000000000000000000015461265506773700175670ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include "eztrace.h" #include "staticlib_ev_codes.h" int (*libmafunc)(int n); int mafunc(int n) { EZTRACE_EVENT1(EZTRACE_staticlib_mafunc_1, n); int ret = libmafunc(n); EZTRACE_EVENT1(EZTRACE_staticlib_mafunc_2, n); return ret; } START_INTERCEPT INTERCEPT2("mafunc", libmafunc) END_INTERCEPT static void __staticlib_init(void) __attribute__ ((constructor)); /* Initialize the current library */ static void __staticlib_init(void) { DYNAMIC_INTERCEPT_ALL(); /* start event recording */ #ifdef EZTRACE_AUTOSTART eztrace_start (); #endif } static void __staticlib_conclude(void) __attribute__ ((destructor)); static void __staticlib_conclude(void) { /* stop event recording */ eztrace_stop(); } eztrace-1.1-2/test/static/staticlib_ev_codes.h000066400000000000000000000016611265506773700214410ustar00rootroot00000000000000/* -*- c-file-style: "GNU" -*- */ /* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #ifndef __staticlib_EV_CODES_H__ #define __staticlib_EV_CODES_H__ /* This file defines the event codes that are used by the example * module. */ #include "ev_codes.h" /* Event codes prefix. This identifies the module and thus should be * unique. * The 0x0? prefix is reserved for eztrace internal use. Thus you can * use any prefix between 0x10 and 0xff. */ #define staticlib_EVENTS_ID USER_MODULE_ID(0x99) #define staticlib_PREFIX (staticlib_EVENTS_ID << NB_BITS_EVENTS) /* Define various event codes used by the example module * The 2 most significant bytes should correspond to the module id, * as below: */ #define EZTRACE_staticlib_mafunc_1 (staticlib_PREFIX | 0x1) #define EZTRACE_staticlib_mafunc_2 (staticlib_PREFIX | 0x2) #endif /* __staticlib_EV_CODES_H__ */ eztrace-1.1-2/test/stdio/000077500000000000000000000000001265506773700152725ustar00rootroot00000000000000eztrace-1.1-2/test/stdio/Makefile.am000066400000000000000000000002431265506773700173250ustar00rootroot00000000000000# Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 # See COPYING in top-level directory. check_PROGRAMS = stdio stdio_SOURCES = stdio.c stdio_LDFLAGS = -lpthread eztrace-1.1-2/test/stdio/Makefile.in000066400000000000000000000462551265506773700173530ustar00rootroot00000000000000# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2014 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ # Copyright © CNRS, INRIA, UniversitĂ© Bordeaux 1 # See COPYING in top-level directory. VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ check_PROGRAMS = stdio$(EXEEXT) subdir = test/stdio ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am_stdio_OBJECTS = stdio.$(OBJEXT) stdio_OBJECTS = $(am_stdio_OBJECTS) stdio_LDADD = $(LDADD) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = stdio_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(stdio_LDFLAGS) $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(stdio_SOURCES) DIST_SOURCES = $(stdio_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CUDA_CFLAGS = @CUDA_CFLAGS@ CUDA_LDFLAGS = @CUDA_LDFLAGS@ CUDA_LIBS = @CUDA_LIBS@ CUDA_ROOT = @CUDA_ROOT@ CUPTI_CFLAGS = @CUPTI_CFLAGS@ CUPTI_LDFLAGS = @CUPTI_LDFLAGS@ CUPTI_LIBS = @CUPTI_LIBS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ DYNLIB_EXT = @DYNLIB_EXT@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FC = @FC@ FCFLAGS = @FCFLAGS@ FGREP = @FGREP@ GREP = @GREP@ GTGDIR = @GTGDIR@ GTG_CPPFLAGS = @GTG_CPPFLAGS@ GTG_DEPENDENCIES = @GTG_DEPENDENCIES@ GTG_EXT_CPPFLAGS = @GTG_EXT_CPPFLAGS@ GTG_EXT_LDFLAGS = @GTG_EXT_LDFLAGS@ GTG_EXT_LIB = @GTG_EXT_LIB@ GTG_LDFLAGS = @GTG_LDFLAGS@ GTG_LIB = @GTG_LIB@ GTG_OUT_OF_ORDER = @GTG_OUT_OF_ORDER@ HAVE_ENV = @HAVE_ENV@ HAVE_LIBOPCODE = @HAVE_LIBOPCODE@ HAVE_PRCTL_H = @HAVE_PRCTL_H@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LATEXMK = @LATEXMK@ LD = @LD@ LDFLAGS = @LDFLAGS@ LD_LIBRARY_PATH_NAME = @LD_LIBRARY_PATH_NAME@ LD_PRELOAD_NAME = @LD_PRELOAD_NAME@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LITL_PRINT = @LITL_PRINT@ LITL_ROOT = @LITL_ROOT@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MPICC = @MPICC@ MPI_EVENT_ID = @MPI_EVENT_ID@ MPI_INC = @MPI_INC@ MPI_LDFLAGS = @MPI_LDFLAGS@ MPI_MODULE_NAME = @MPI_MODULE_NAME@ MPI_ROOT = @MPI_ROOT@ NM = @NM@ NMEDIT = @NMEDIT@ NVCC = @NVCC@ NVCCFLAGS = @NVCCFLAGS@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAPIDIR = @PAPIDIR@ PAPI_CPPFLAGS = @PAPI_CPPFLAGS@ PAPI_ENABLED = @PAPI_ENABLED@ PAPI_LDFLAGS = @PAPI_LDFLAGS@ PAPI_LIBDIR = @PAPI_LIBDIR@ PATH_SEPARATOR = @PATH_SEPARATOR@ PDFLATEX = @PDFLATEX@ PERL = @PERL@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ PPTRACE_BINARY_TYPE = @PPTRACE_BINARY_TYPE@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STARPU_CFLAGS = @STARPU_CFLAGS@ STARPU_CPPFLAGS = @STARPU_CPPFLAGS@ STARPU_LDFLAGS = @STARPU_LDFLAGS@ STARPU_LIBS = @STARPU_LIBS@ STARPU_ROOT = @STARPU_ROOT@ STRIP = @STRIP@ TARGET_BITS = @TARGET_BITS@ TL_CPPFLAGS = @TL_CPPFLAGS@ TL_EXT_CPPFLAGS = @TL_EXT_CPPFLAGS@ TL_EXT_LDFLAGS = @TL_EXT_LDFLAGS@ TL_EXT_LIB = @TL_EXT_LIB@ TL_LDFLAGS = @TL_LDFLAGS@ TL_LIB = @TL_LIB@ USE_CUDADIR_FROM_USER = @USE_CUDADIR_FROM_USER@ USE_MPIDIR_FROM_USER = @USE_MPIDIR_FROM_USER@ USE_PAPIDIR_FROM_USER = @USE_PAPIDIR_FROM_USER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ ac_ct_FC = @ac_ct_FC@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ stdio_SOURCES = stdio.c stdio_LDFLAGS = -lpthread all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu test/stdio/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu test/stdio/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): clean-checkPROGRAMS: @list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list stdio$(EXEEXT): $(stdio_OBJECTS) $(stdio_DEPENDENCIES) $(EXTRA_stdio_DEPENDENCIES) @rm -f stdio$(EXEEXT) $(AM_V_CCLD)$(stdio_LINK) $(stdio_OBJECTS) $(stdio_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/stdio.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ @am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ @am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am $(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS) check: check-am all-am: Makefile installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-checkPROGRAMS clean-generic clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: .MAKE: check-am install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ clean-checkPROGRAMS clean-generic clean-libtool cscopelist-am \ ctags ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: eztrace-1.1-2/test/stdio/stdio.c000066400000000000000000000055511265506773700165660ustar00rootroot00000000000000/* * Copyright (C) CNRS, INRIA, UniversitĂ© Bordeaux 1, TĂ©lĂ©com SudParis * See COPYING in top-level directory. */ #include #include #include #include #include #include #include #include #include #include #include // Debugging part, print out only if debugging level of the system is verbose or more int _debug = -77; void debug(char *fmt, ...) { if (_debug == -77) { char *buf = getenv("EZTRACE_DEBUG"); if (buf == NULL) _debug = 0; else _debug = atoi(buf); } va_list va; va_start(va, fmt); if (_debug >= 0) { // debug verbose mode vfprintf(stderr, fmt, va); } else { // Don't print out => redirect to /dev/null FILE *f = fopen("/dev/null", "a"); vfprintf(f, fmt, va); fclose(f); } va_end(va); } // end of debugging part #define __STDIO_TEST_STATIC #ifdef __STDIO_TEST_STATIC /*ssize_t read(int fd, void *buf, size_t size) { if(size > 30) size = 30; memcpy(buf, "012345678901234567890123456789", size); sleep(0.1); return (ssize_t)size; } */ #endif // __STDIO_TEST_STATIC /* Number of iterations */ #define ITER 10 /* Number of threads */ #define NTH 2 typedef union { unsigned long long tick; struct { unsigned low; unsigned high; }; } tick_t; int fd[2][2]; sem_t* thread_ready; #define TICK_DIFF(t1, t2) \ ((t2).tick - (t1).tick) #define TIME_DIFF(t1, t2) \ ((t2.tv_sec - t1.tv_sec) * 1000000 + (t2.tv_usec - t1.tv_usec)) /* Fake computation of usec microseconds */ void compute(int usec) { struct timeval tv1, tv2; gettimeofday(&tv1, NULL); do { gettimeofday(&tv2, NULL); } while (TIME_DIFF(tv1, tv2) < usec); } void* f_thread(void* arg) { int my_id = *(int*) arg; /* Notify the main thread that we got the args */ sem_post(thread_ready); debug("Running thread #%d\n", my_id); int buf = -1; int i; for (i = 0; i < ITER; i++) { /* Wait until the previous thread has finished his job */ read(fd[my_id][0], &buf, sizeof(int)); debug("[thread #%d] read %d\n", my_id, buf); /* compute for 1ms */ compute(50000); buf++; /* Wake up the next thread */ write(fd[(my_id + 1) % 2][1], &buf, sizeof(int)); buf = 0; } debug("End of thread #%d\n", my_id); return NULL; } int main(int argc, char**argv) { pthread_t tid[NTH]; int i; if (pipe(fd[0]) || pipe(fd[1])) { fprintf(stderr, "error while calling pipe\n"); return 1; } sem_unlink("ready"); thread_ready = sem_open("ready", O_CREAT, 0666, 0); for (i = 0; i < NTH; i++) { pthread_create(&tid[i], NULL, f_thread, &i); sem_wait(thread_ready); } sem_unlink("ready"); i = 0; debug("Main thread writes %d\n", i); write(fd[0][1], &i, sizeof(int)); for (i = 0; i < NTH; i++) { pthread_join(tid[i], NULL); } return 0; }