Projects
Mega:23.09
libunwind
Sign Up
Log In
Username
Password
Sorry, you are not authorized to perform this action.
×
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
Expand all
Collapse all
Changes of Revision 3
View file
_service:tar_scm:libunwind.spec
Changed
@@ -1,20 +1,18 @@ Name: libunwind Epoch: 2 -Version: 1.6.2 -Release: 7 +Version: 1.7.2 +Release: 1 Summary: Libunwind provides a C ABI to determine the call-chain of a program License: BSD URL: http://savannah.nongnu.org/projects/libunwind Source: http://download-mirror.savannah.gnu.org/releases/libunwind/libunwind-%{version}.tar.gz -Patch0001: 0001-fix-byte_order_is_valid-function-logic.patch -Patch2: backport-check-namespace.sh-adjust-aarch64-symbols.patch -Patch3: backport-tests-run-coredump-unwind-Skip-test-if-no-coredump-h.patch -Patch4: backport-aarch64-unw_step-validates-address-before-calling-dwarf_get.patch -Patch5: backport-avoid-calling-printf-because-OE-glibc-2.34-used-mno-.patch -Patch6: backport-fix-run-ptrace-mapper-test-case-failed.patch +Patch1: 0001-fix-byte_order_is_valid-function-logic.patch +Patch2: backport-aarch64-unw_step-validates-address-before-calling-dwarf_get.patch +Patch3: backport-avoid-calling-printf-because-OE-glibc-2.34-used-mno-.patch +Patch4: backport-fix-run-ptrace-mapper-test-case-failed.patch -ExclusiveArch: aarch64 %{ix86} x86_64 riscv64 +ExclusiveArch: aarch64 %{ix86} x86_64 riscv64 ppc64le BuildRequires: automake libtool autoconf texlive-latex2man gcc-c++ @@ -90,6 +88,18 @@ %{_mandir}/*/* %changelog +* Mon Jan 29 2024 zhuofeng <zhuofeng2@huawei.com> - 2:1.7.2-1 +- Type:bugfix +- ID:NA +- SUG:NA +- DESC:update version to 1.7.2 + +* Mon Nov 27 2023 jiahua.yu <jiahua.yu@shingroup.cn> - 2:1.6.2-8 +- Type:update +- ID:NA +- SUG:NA +- DESC:init support for ppc64le + * Tue Jul 11 2023 chenziyang <chenziyang4@huawei.com> - 2:1.6.2-7 - Type:bugfix - ID:NA
View file
_service:tar_scm:backport-check-namespace.sh-adjust-aarch64-symbols.patch
Deleted
@@ -1,140 +0,0 @@ -From e8fa8d0ca5349d01cf5505eb0d952ef26c62cc94 Mon Sep 17 00:00:00 2001 -From: Stephen Webb <swebb@blackberry.com> -Date: Fri, 21 Oct 2022 15:52:22 -0400 -Subject: PATCH check-namespace.sh: adjust aarch64 symbols - -Some symbols for aarch64 were missing, and some were marked as -extraneous in this ABI checker. - -Fixes #389. ---- - tests/check-namespace.sh.in | 46 ++++++++++++++++--------------------- - 1 file changed, 20 insertions(+), 26 deletions(-) - -diff --git a/tests/check-namespace.sh.in b/tests/check-namespace.sh.in -index f99fb59..f9201a2 100644 ---- a/tests/check-namespace.sh.in -+++ b/tests/check-namespace.sh.in -@@ -117,7 +117,8 @@ check_local_unw_abi () { - - match _U${plat}_flush_cache - match _U${plat}_get_accessors -- match _U${plat}_getcontext -+ match _U${plat}_get_elf_image -+ match _U${plat}_get_exe_image_path - match _U${plat}_regname - match _U${plat}_strerror - -@@ -130,68 +131,59 @@ check_local_unw_abi () { - - case ${plat} in - arm) -- match _U${plat}_get_elf_image -- match _U${plat}_get_exe_image_path -+ match _U${plat}_getcontext - match _U${plat}_is_fpreg - match _UL${plat}_search_unwind_table - match _UL${plat}_dwarf_search_unwind_table - match _UL${plat}_dwarf_find_unwind_table - ;; - hppa) -+ match _U${plat}_getcontext - match _UL${plat}_dwarf_search_unwind_table - match _UL${plat}_dwarf_find_unwind_table -- match _U${plat}_get_elf_image -- match _U${plat}_get_exe_image_path - match _U${plat}_setcontext - ;; - ia64) -+ match _U${plat}_getcontext - match _UL${plat}_search_unwind_table -- match _U${plat}_get_elf_image -- match _U${plat}_get_exe_image_path - ;; - x86) -- match _U${plat}_get_elf_image -- match _U${plat}_get_exe_image_path -+ match _U${plat}_getcontext - match _U${plat}_is_fpreg - match _UL${plat}_dwarf_search_unwind_table - match _UL${plat}_dwarf_find_unwind_table - ;; - x86_64) -- match _U${plat}_get_elf_image -- match _U${plat}_get_exe_image_path -+ match _U${plat}_getcontext - match _U${plat}_is_fpreg - match _UL${plat}_dwarf_search_unwind_table - match _UL${plat}_dwarf_find_unwind_table - match _U${plat}_setcontext - ;; - ppc*) -+ match _U${plat}_getcontext - match _U${plat}_get_func_addr -- match _U${plat}_get_elf_image -- match _U${plat}_get_exe_image_path - match _U${plat}_is_fpreg - match _UL${plat}_dwarf_search_unwind_table - match _UL${plat}_dwarf_find_unwind_table - ;; - tilegx) -+ match _U${plat}_getcontext - match _U${plat}_is_fpreg - match _UL${plat}_dwarf_search_unwind_table - match _UL${plat}_dwarf_find_unwind_table - match _UL${plat}_local_addr_space_init -- match _U${plat}_get_elf_image -- match _U${plat}_get_exe_image_path - match ${plat}_lock - ;; - s390x) -- match _U${plat}_get_elf_image -- match _U${plat}_get_exe_image_path -+ match _U${plat}_getcontext - match _U${plat}_is_fpreg - match _UL${plat}_dwarf_search_unwind_table - match _UL${plat}_dwarf_find_unwind_table - match _U${plat}_setcontext - ;; - riscv) -- match _U${plat}_get_elf_image -- match _U${plat}_get_exe_image_path -+ match _U${plat}_getcontext - match _U${plat}_is_fpreg - match _UL${plat}_dwarf_search_unwind_table - match _UL${plat}_dwarf_find_unwind_table -@@ -288,15 +280,15 @@ check_generic_unw_abi () { - match _U${plat}_dwarf_search_unwind_table - match _U${plat}_dwarf_find_unwind_table - ;; -- tilegx) -- match _U${plat}_dwarf_search_unwind_table -+ tilegx) -+ match _U${plat}_dwarf_search_unwind_table - match _U${plat}_dwarf_find_unwind_table -- match _U${plat}_get_elf_image -+ match _U${plat}_get_elf_image - match _U${plat}_get_exe_image_path -- match _U${plat}_is_fpreg -- match _U${plat}_local_addr_space_init -- match ${plat}_lock -- ;; -+ match _U${plat}_is_fpreg -+ match _U${plat}_local_addr_space_init -+ match ${plat}_lock -+ ;; - s390x) - match _U${plat}_is_fpreg - match _U${plat}_get_elf_image -@@ -315,6 +307,8 @@ check_generic_unw_abi () { - match _U${plat}_is_fpreg - match _U${plat}_dwarf_search_unwind_table - match _U${plat}_dwarf_find_unwind_table -+ match _U${plat}_get_elf_image -+ match _U${plat}_get_exe_image_path - ;; - esac - --- -2.27.0 -
View file
_service:tar_scm:backport-tests-run-coredump-unwind-Skip-test-if-no-coredump-h.patch
Deleted
@@ -1,31 +0,0 @@ -From fedff5ac77c945fc0c5df534074163a784bfa5b3 Mon Sep 17 00:00:00 2001 -From: Florian Weimer <fweimer@redhat.com> -Date: Wed, 7 Sep 2022 14:01:36 +0200 -Subject: PATCH tests/run-coredump-unwind: Skip test if no coredump has been - created - -In some build environments, coredumps are not created even if the -corresponding ulimit is positive. This change skips the test if -the coredump is missing. ---- - tests/run-coredump-unwind | 4 ++++ - 1 file changed, 4 insertions(+) - -diff --git a/tests/run-coredump-unwind b/tests/run-coredump-unwind -index 8d07742..0c2b28c 100755 ---- a/tests/run-coredump-unwind -+++ b/tests/run-coredump-unwind -@@ -48,6 +48,10 @@ fi - ./crasher backing_files - ) 2>/dev/null - COREFILE=$TEMPDIR/core* -+if ! test -f "$COREFILE"; then -+ echo "crasher process did not produce coredump, test skipped" -+ exit 77 -+fi - - # magic option -testcase enables checking for the specific contents of the stack - ./test-coredump-unwind $COREFILE -testcase `cat $TEMPDIR/backing_files` --- -2.33.0 -
View file
_service
Changed
@@ -2,7 +2,7 @@ <service name="tar_scm"> <param name="url">git@gitee.com:src-openeuler/libunwind.git</param> <param name="scm">git</param> - <param name="revision">openEuler-23.09</param> + <param name="revision">master</param> <param name="exclude">*</param> <param name="extract">*</param> </service>
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/acinclude.m4
Deleted
@@ -1,1 +0,0 @@ -
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/INSTALL -> _service:tar_scm:libunwind-1.7.2.tar.gz/INSTALL
Changed
@@ -1,8 +1,8 @@ Installation Instructions ************************* - Copyright (C) 1994-1996, 1999-2002, 2004-2017, 2020-2021 Free -Software Foundation, Inc. +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 @@ -12,96 +12,97 @@ Basic Installation ================== - Briefly, the shell command './configure && make && make install' + 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 +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 +`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 + 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 +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'). +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. + 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 +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 +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 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. + 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 + 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. + 2. Type `make' to compile the package. - 3. Optionally, type 'make check' to run any self-tests that come with + 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 + 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 + user, and only the `make install' phase executed with root privileges. - 5. Optionally, type 'make installcheck' to repeat any self-tests, but + 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 + 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 + 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 + 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 + 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. + 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' +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: + 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 @@ -112,21 +113,21 @@ 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 +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. +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 + 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 +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 +"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" \ @@ -135,104 +136,105 @@ 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. +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 + 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 +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 +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 +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 +`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 +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 +`${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. +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 +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 + 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. +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 +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 +overridden with `make V=1'; while running `./configure --disable-silent-rules' sets the default to verbose, which can be -overridden with 'make V=0'. +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 + 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 timestamps as their -prerequisites, which makes it generally unusable when shipped generated -files such as 'configure' are involved. Use GNU 'make' instead. + 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 '<wchar.h>' header file. The option '-nodtk' can be used as a -workaround. If GNU CC is not installed, it is therefore recommended to -try +parse its `<wchar.h>' 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" @@ -240,26 +242,26 @@ ./configure CC="cc -nodtk" - On Solaris, don't put '/usr/ucb' early in your 'PATH'. This + 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'. +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: + 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 + 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 +_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: +`--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 @@ -268,101 +270,101 @@ 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 + 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 +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'. +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. + 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 +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: +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 +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: +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' Invocation ====================== - 'configure' recognizes the following options to control how it + `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' +`-h' + Print a summary of all of the options to `configure', and exit. -'--help=short' -'--help=recursive' +`--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. + `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' +`--version' +`-V' + Print the version of Autoconf used to generate the `configure' script, and exit. -'--cache-file=FILE' +`--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 + traditionally `config.cache'. FILE defaults to `/dev/null' to disable caching. -'--config-cache' -'-C' - Alias for '--cache-file=config.cache'. +`--config-cache' +`-C' + Alias for `--cache-file=config.cache'. -'--quiet' -'--silent' -'-q' +`--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 + suppress all normal output, redirect it to `/dev/null' (any error messages will still be shown). -'--srcdir=DIR' +`--srcdir=DIR' Look for the package's source code in directory DIR. Usually - 'configure' can determine that directory automatically. + `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. +`--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' +`--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. +`configure' also accepts some other, not widely useful, options. Run +`configure --help' for more details.
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/Makefile.am -> _service:tar_scm:libunwind-1.7.2.tar.gz/Makefile.am
Changed
@@ -1,3 +1,4 @@ +ACLOCAL_AMFLAGS = -I m4 include_HEADERS = include/libunwind-dynamic.h if BUILD_PTRACE @@ -47,6 +48,9 @@ if ARCH_RISCV include_HEADERS += include/libunwind-riscv.h endif +if ARCH_LOONGARCH64 +include_HEADERS += include/libunwind-loongarch64.h +endif if !REMOTE_ONLY include_HEADERS += include/libunwind.h @@ -97,6 +101,9 @@ include/tdep-s390x/jmpbuf.h include/tdep-s390x/libunwind_i.h \ include/tdep-riscv/dwarf-config.h \ include/tdep-riscv/jmpbuf.h include/tdep-riscv/libunwind_i.h \ + include/tdep-loongarch64/dwarf-config.h \ + include/tdep-loongarch64/jmpbuf.h \ + include/tdep-loongarch64/libunwind_i.h \ include/tdep/libunwind_i.h \ include/tdep/jmpbuf.h include/tdep/dwarf-config.h
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/Makefile.in -> _service:tar_scm:libunwind-1.7.2.tar.gz/Makefile.in
Changed
@@ -1,7 +1,7 @@ -# Makefile.in generated by automake 1.16.4 from Makefile.am. +# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ -# Copyright (C) 1994-2021 Free Software Foundation, Inc. +# 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, @@ -104,13 +104,16 @@ @ARCH_SH_TRUE@am__append_13 = include/libunwind-sh.h @ARCH_S390X_TRUE@am__append_14 = include/libunwind-s390x.h @ARCH_RISCV_TRUE@am__append_15 = include/libunwind-riscv.h -@REMOTE_ONLY_FALSE@am__append_16 = include/libunwind.h -@BUILD_UNWIND_HEADER_TRUE@@REMOTE_ONLY_FALSE@am__append_17 = include/unwind.h -@CONFIG_TESTS_TRUE@am__append_18 = tests -@CONFIG_DOCS_TRUE@am__append_19 = doc +@ARCH_LOONGARCH64_TRUE@am__append_16 = include/libunwind-loongarch64.h +@REMOTE_ONLY_FALSE@am__append_17 = include/libunwind.h +@BUILD_UNWIND_HEADER_TRUE@@REMOTE_ONLY_FALSE@am__append_18 = include/unwind.h +@CONFIG_TESTS_TRUE@am__append_19 = tests +@CONFIG_DOCS_TRUE@am__append_20 = doc subdir = . ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/acinclude.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)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) @@ -161,7 +164,8 @@ include/libunwind-x86.h include/libunwind-x86_64.h \ include/libunwind-ppc32.h include/libunwind-ppc64.h \ include/libunwind-sh.h include/libunwind-s390x.h \ - include/libunwind-riscv.h include/libunwind.h include/unwind.h + include/libunwind-riscv.h include/libunwind-loongarch64.h \ + include/libunwind.h include/unwind.h am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ @@ -199,7 +203,7 @@ $(RECURSIVE_CLEAN_TARGETS) \ $(am__extra_recursive_targets) AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ - cscope distdir distdir-am dist dist-all distcheck + 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 @@ -217,6 +221,9 @@ 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 = src tests doc am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/config/ar-lib \ $(top_srcdir)/config/compile $(top_srcdir)/config/config.guess \ @@ -232,8 +239,7 @@ $(top_srcdir)/src/unwind/libunwind.pc.in AUTHORS COPYING \ ChangeLog INSTALL NEWS README TODO config/ar-lib \ config/compile config/config.guess config/config.sub \ - config/depcomp config/install-sh config/ltmain.sh \ - config/missing + config/install-sh config/ltmain.sh config/missing DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) distdir = $(PACKAGE)-$(VERSION) top_distdir = $(distdir) @@ -272,8 +278,6 @@ DIST_ARCHIVES = $(distdir).tar.gz GZIP_ENV = --best DIST_TARGETS = dist-gzip -# Exists only to be overridden by the user if desired. -AM_DISTCHECK_DVI_TARGET = dvi distuninstallcheck_listfiles = find . -type f -print am__distuninstallcheck_listfiles = $(distuninstallcheck_listfiles) \ | sed 's|^\./|$(prefix)/|' | grep -v '$(infodir)/dir$$' @@ -296,8 +300,6 @@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ -CSCOPE = @CSCOPE@ -CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ @@ -313,7 +315,6 @@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ -ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ @@ -364,6 +365,7 @@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ +UNW_TESTDRIVER = @UNW_TESTDRIVER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ @@ -427,15 +429,16 @@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ +ACLOCAL_AMFLAGS = -I m4 include_HEADERS = include/libunwind-dynamic.h $(am__append_1) \ $(am__append_2) $(am__append_3) $(am__append_4) \ $(am__append_5) $(am__append_6) $(am__append_7) \ $(am__append_8) $(am__append_9) $(am__append_10) \ $(am__append_11) $(am__append_12) $(am__append_13) \ $(am__append_14) $(am__append_15) $(am__append_16) \ - $(am__append_17) + $(am__append_17) $(am__append_18) nodist_include_HEADERS = include/libunwind-common.h -SUBDIRS = src $(am__append_18) $(am__append_19) +SUBDIRS = src $(am__append_19) $(am__append_20) noinst_HEADERS = include/dwarf.h include/dwarf_i.h include/dwarf-eh.h \ include/compiler.h include/libunwind_i.h include/mempool.h \ include/remote.h \ @@ -466,6 +469,9 @@ include/tdep-s390x/jmpbuf.h include/tdep-s390x/libunwind_i.h \ include/tdep-riscv/dwarf-config.h \ include/tdep-riscv/jmpbuf.h include/tdep-riscv/libunwind_i.h \ + include/tdep-loongarch64/dwarf-config.h \ + include/tdep-loongarch64/jmpbuf.h \ + include/tdep-loongarch64/libunwind_i.h \ include/tdep/libunwind_i.h \ include/tdep/jmpbuf.h include/tdep/dwarf-config.h @@ -509,8 +515,8 @@ echo ' $(SHELL) ./config.status'; \ $(SHELL) ./config.status;; \ *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles);; \ + 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) @@ -707,10 +713,8 @@ distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags -rm -f cscope.out cscope.in.out cscope.po.out cscope.files -distdir: $(BUILT_SOURCES) - $(MAKE) $(AM_MAKEFLAGS) distdir-am -distdir-am: $(DISTFILES) +distdir: $(DISTFILES) $(am__remove_distdir) test -d "$(distdir)" || mkdir "$(distdir)" @srcdirstrip=`echo "$(srcdir)" | sed 's/.^$$\\*/\\\\&/g'`; \ @@ -775,7 +779,7 @@ ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \ || chmod -R a+r "$(distdir)" dist-gzip: distdir - tardir=$(distdir) && $(am__tar) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).tar.gz + tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz $(am__post_remove_distdir) dist-bzip2: distdir @@ -790,10 +794,6 @@ tardir=$(distdir) && $(am__tar) | XZ_OPT=$${XZ_OPT--e} xz -c >$(distdir).tar.xz $(am__post_remove_distdir) -dist-zstd: distdir - tardir=$(distdir) && $(am__tar) | zstd -c $${ZSTD_CLEVEL-$${ZSTD_OPT--19}} >$(distdir).tar.zst - $(am__post_remove_distdir) - dist-tarZ: distdir @echo WARNING: "Support for distribution archives compressed with" \ "legacy program 'compress' is deprecated." >&2 @@ -805,7 +805,7 @@ @echo WARNING: "Support for shar distribution archives is" \ "deprecated." >&2 @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 - shar $(distdir) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).shar.gz + shar $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).shar.gz $(am__post_remove_distdir) dist-zip: distdir @@ -823,7 +823,7 @@ distcheck: dist case '$(DIST_ARCHIVES)' in \ *.tar.gz*) \ - eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).tar.gz | $(am__untar) ;;\ + GZIP=$(GZIP_ENV) gzip -dc $(distdir).tar.gz | $(am__untar) ;;\ *.tar.bz2*) \ bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\ *.tar.lz*) \ @@ -833,11 +833,9 @@ *.tar.Z*) \ uncompress -c $(distdir).tar.Z | $(am__untar) ;;\ *.shar.gz*) \ - eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).shar.gz | unshar ;;\ + GZIP=$(GZIP_ENV) gzip -dc $(distdir).shar.gz | unshar ;;\ *.zip*) \ unzip $(distdir).zip ;;\ - *.tar.zst*) \ - zstd -dc $(distdir).tar.zst | $(am__untar) ;;\ esac chmod -R a-w $(distdir) chmod u+w $(distdir) @@ -853,7 +851,7 @@ $(DISTCHECK_CONFIGURE_FLAGS) \ --srcdir=../.. --prefix="$$dc_install_base" \ && $(MAKE) $(AM_MAKEFLAGS) \ - && $(MAKE) $(AM_MAKEFLAGS) $(AM_DISTCHECK_DVI_TARGET) \ + && $(MAKE) $(AM_MAKEFLAGS) dvi \ && $(MAKE) $(AM_MAKEFLAGS) check \ && $(MAKE) $(AM_MAKEFLAGS) install \ && $(MAKE) $(AM_MAKEFLAGS) installcheck \ @@ -1019,19 +1017,19 @@ 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 dist-zstd distcheck distclean \ - distclean-generic distclean-hdr 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-nodist_includeHEADERS 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-generic mostlyclean-libtool pdf pdf-am ps ps-am \ - tags tags-am uninstall uninstall-am uninstall-includeHEADERS \ + dist-xz dist-zip distcheck distclean distclean-generic \ + distclean-hdr 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-nodist_includeHEADERS 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-generic \ + mostlyclean-libtool pdf pdf-am ps ps-am tags tags-am uninstall \ + uninstall-am uninstall-includeHEADERS \ uninstall-nodist_includeHEADERS .PRECIOUS: Makefile
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/NEWS -> _service:tar_scm:libunwind-1.7.2.tar.gz/NEWS
Changed
@@ -28,11 +28,11 @@ * News for v1.0: -** Fast unwind (rbp, rsp, rip only) on x86_64 with a fallback to +** Fast unwind (rbp, rsp, rip only) on x86_64 with a fallback to slow code path (Lassi Tuura) ** Improved local and remote unwinding on ARM (Ken Werner) ** Testing, stability and many fixes on x86 (Paul Pluzhnikov) -** FreeBSD port and clean separation of OS specific bits +** FreeBSD port and clean separation of OS specific bits (Konstantin Belousov) ** Thanks for all the bug reports, contributions and testing! @@ -108,7 +108,7 @@ * News for v0.98: ** Update libunwind to be compliant with the updated/expanded - ia64 unwind specificiation by HJ Lu 1. This is needed for + ia64 unwind specification by HJ Lu 1. This is needed for GCC 3.4 compatibility. 1 http://www.kernel.org/pub/linux/devel/gcc/unwind/ @@ -116,7 +116,7 @@ ** Initial support for x86-64 has been added courtesy of Max Asbock. Along with this came a bunch of DWARF2 unwinder fixes. -** A new rountine unw_strerror() has been added courtesy of +** A new routine unw_strerror() has been added courtesy of Thomas Hallgren. ** Including <libunwind.h> now defines 4 macros that can be used @@ -188,40 +188,40 @@ at IBM and it is expected that this support will be merged into the official tree soon. - + * News for v0.96: ** _Unwind_*() routines defined by the C++ ABI are now included in libunwind. - + * News for v0.95: ** Bigger, better, faster, or so the theory goes. - + * News for v0.93: ** More bug-fixes & improved HP-UX support. - + * News for v0.92: ** Bug-fix release. IA-64 unwinder can now be built with Intel compiler (ECC). - + * News for v0.91: ** Lots of documentation updates ** Some portability fixes. - + * News for v0.9: ** The libunwind API is mostly feature-complete at this point (hence the version jump from v0.2 to v0.9). - + * News for v0.2: ** Automated configuration/build with autoconf and automake. @@ -236,12 +236,12 @@ e.g., useful for building a debugger that can support multiple targets such as x86, ia64, etc.) - + * News for v0.1: ** Added support for exception handling. - + * News for v0.0: ** It's a brand new package.
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/README -> _service:tar_scm:libunwind-1.7.2.tar.gz/README
Changed
@@ -1,6 +1,7 @@ # libunwind -!Build Status(https://travis-ci.org/libunwind/libunwind.svg?branch=master)(https://travis-ci.org/libunwind/libunwind) +!CI - Unix(https://github.com/libunwind/libunwind/actions/workflows/CI-unix.yml/badge.svg)(https://github.com/libunwind/libunwind/actions/workflows/CI-unix.yml) +!CI - Windows(https://github.com/libunwind/libunwind/actions/workflows/CI-win.yml/badge.svg)(https://github.com/libunwind/libunwind/actions/workflows/CI-win.yml) This library supports several architecture/operating-system combinations: @@ -16,12 +17,15 @@ | Linux | IA-64 | ✓ | | Linux | PARISC | Works well, but C library missing unwind-info | | Linux | Tilegx | 64-bit mode only | -| Linux | MIPS | Newly added | +| Linux | MIPS | ✓ | | Linux | RISC-V | 64-bit only | +| Linux | LoongArch | 64-bit only | | HP-UX | IA-64 | Mostly works, but known to have serious limitations | | FreeBSD | x86-64 | ✓ | | FreeBSD | x86 | ✓ | | FreeBSD | AArch64 | ✓ | +| FreeBSD | PPC32 | ✓ | +| FreeBSD | PPC64 | ✓ | | Solaris | x86-64 | ✓ | ## Libc Requirements @@ -41,6 +45,7 @@ | arm | p | | | hppa | p | p | | ia64 | p | r | +| loongarch | p | | | mips | p | | | ppc32 | r | | | ppc64 | r | r | @@ -57,9 +62,9 @@ commands: $ autoreconf -i # Needed only for building from git. Depends on libtool. - $ ./configure + $ ./configure --prefix=PREFIX $ make - $ make install prefix=PREFIX + $ make install where `PREFIX` is the installation prefix. By default, a prefix of `/usr/local` is used, such that `libunwind.a` is installed in @@ -89,18 +94,6 @@ Caveat: Unwinding of 32-bit (ILP32) binaries is not supported at the moment. -### Workaround for older versions of GCC - -GCC v3.0 and GCC v3.2 ship with a bad version of `sys/types.h`. The -workaround is to issue the following commands before running -`configure`: - - $ mkdir $top_dir/include/sys - $ cp /usr/include/sys/types.h $top_dir/include/sys - -GCC v3.3.2 or later have been fixed and do not require this -workaround. - ### Building for PowerPC64 / Linux For building for power64 you should use: @@ -136,27 +129,6 @@ $ make check -### Expected results on IA-64 Linux - -Unless you have a very recent C library and compiler installed, it is -currently expected to have the following tests fail on IA-64 Linux: - -* `Gtest-init` (should pass starting with glibc-2.3.x/gcc-3.4) -* `Ltest-init` (should pass starting with glibc-2.3.x/gcc-3.4) -* `test-ptrace` (should pass starting with glibc-2.3.x/gcc-3.4) -* `run-ia64-test-dyn1` (should pass starting with glibc-2.3.x) - -This does not mean that libunwind cannot be used with older compilers -or C libraries, it just means that for certain corner cases, unwinding -will fail. Since they're corner cases, it is not likely for -applications to trigger them. - -Note: If you get lots of errors in `Gia64-test-nat` and `Lia64-test-nat`, it's -almost certainly a sign of an old assembler. The GNU assembler used -to encode previous-stack-pointer-relative offsets incorrectly. -This bug was fixed on 21-Sep-2004 so any later assembler will be -fine. - ### Expected results on x86 Linux The following tests are expected to fail on x86 Linux: @@ -172,10 +144,6 @@ ### Expected results on PARISC Linux -Caveat: GCC v3.4 or newer is needed on PA-RISC Linux. Earlier -versions of the compiler failed to generate the exception-handling -program header (`GNU_EH_FRAME`) needed for unwinding. - The following tests are expected to fail on x86-64 Linux: * `Gtest-bt` (backtrace truncated at `kill()` due to lack of unwind-info)
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/aclocal.m4 -> _service:tar_scm:libunwind-1.7.2.tar.gz/aclocal.m4
Changed
@@ -1,6 +1,6 @@ -# generated automatically by aclocal 1.16.4 -*- Autoconf -*- +# generated automatically by aclocal 1.15 -*- Autoconf -*- -# Copyright (C) 1996-2021 Free Software Foundation, Inc. +# 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, @@ -20,9061 +20,7 @@ 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'.)) -# libtool.m4 - Configure libtool for the host system. -*-Autoconf-*- -# -# Copyright (C) 1996-2001, 2003-2015 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) 2014 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 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 this program. If not, see <http://www.gnu.org/licenses/>. -) - -# serial 58 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.62)dnl We use AC_PATH_PROGS_FEATURE_CHECK -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_PREPARE_CC_BASENAME -# ----------------------- -m4_defun(_LT_PREPARE_CC_BASENAME, -# Calculate cc_basename. Skip known compiler wrappers and cross-prefix. -func_cc_basename () -{ - for cc_temp in @S|@*""; do - case $cc_temp in - compile | *\\/compile | ccache | *\\/ccache ) ;; - distcc | *\\/distcc | purify | *\\/purify ) ;; - \-*) ;; - *) break;; - esac - done - func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` -} -)# _LT_PREPARE_CC_BASENAME - - -# _LT_CC_BASENAME(CC) -# ------------------- -# It would be clearer to call AC_REQUIREs from _LT_PREPARE_CC_BASENAME, -# but that macro is also expanded into generated libtool script, which -# arranges for $SED and $ECHO to be set by different means. -m4_defun(_LT_CC_BASENAME, -m4_require(_LT_PREPARE_CC_BASENAME)dnl -AC_REQUIRE(_LT_DECL_SED)dnl -AC_REQUIRE(_LT_PROG_ECHO_BACKSLASH)dnl -func_cc_basename $1 -cc_basename=$func_cc_basename_result -) - - -# _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 -m4_require(_LT_CMD_TRUNCATE)dnl - -_LT_CONFIG_LIBTOOL_INIT( -# See if we are running on zsh, and set the options that 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 set != "${COLLECT_NAMES+set}"; 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 - - - -# 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, !?.$, , .) -)) - - - - - -# _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: -# -# <var>='`$ECHO "$<var>" | $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\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes - ;; - *) - 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\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes - ;; - *) - 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 0 = "$lt_write_fail" && chmod +x $1dnl -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 <bug-libtool@gnu.org>." - -lt_cl_version="\ -m4_ifset(AC_PACKAGE_NAME, AC_PACKAGE_NAME )config.ltdnl -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 yes = "$silent" && - 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 that 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 -# Generated automatically by $as_me ($PACKAGE) $VERSION -# NOTE: Changes made to this file will be lost: look at ltmain.sh. - -# Provide generalized library-building support services. -# Written by Gordon Matzigkeit, 1996 - -_LT_COPYING -_LT_LIBTOOL_TAGS - -# Configured defaults for sys_lib_dlsearch_path munging. -: \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"} - -# ### BEGIN LIBTOOL CONFIG -_LT_LIBTOOL_CONFIG_VARS -_LT_LIBTOOL_TAG_VARS -# ### END LIBTOOL CONFIG - -_LT_EOF - - cat <<'_LT_EOF' >> "$cfgfile" - -# ### BEGIN FUNCTIONS SHARED WITH CONFIGURE - -_LT_PREPARE_MUNGE_PATH_LIST -_LT_PREPARE_CC_BASENAME - -# ### END FUNCTIONS SHARED WITH CONFIGURE - -_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 set != "${COLLECT_NAMES+set}"; 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) - - 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' - 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 AM_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(AM_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(AM_PROG_GCJ, - m4_define(AM_PROG_GCJ, defn(AM_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 0 = "$_lt_result"; 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 cr libconftest.a conftest.o" >&AS_MESSAGE_LOG_FD - $AR cr 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 0 = "$_lt_result" && $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,*-darwin912*) - _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; - 10.012,.*) - _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; - 10.*|11.*) - _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; - esac - ;; - esac - if test yes = "$lt_cv_apple_cc_single_mod"; then - _lt_dar_single_mod='$single_module' - fi - if test yes = "$lt_cv_ld_exported_symbols_list"; 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 no = "$lt_cv_ld_force_load"; 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 yes = "$lt_cv_ld_force_load"; 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*|nagfor*) _lt_dar_can_shared=yes ;; - *) _lt_dar_can_shared=$GCC ;; - esac - if test yes = "$_lt_dar_can_shared"; 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 yes != "$lt_cv_apple_cc_single_mod"; 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 set = "${lt_cv_aix_libpath+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 that will find a shell with a builtin -# printf (that 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, -AS_HELP_STRING(--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 yes = "$GCC"; 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 where 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 no = "$enable_libtool_lock" || 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 what ABI is being produced by ac_compile, and set mode - # options accordingly. - 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 what ABI is being produced by ac_compile, and set linker - # options accordingly. - echo '#line '$LINENO' "configure"' > conftest.$ac_ext - if AC_TRY_EVAL(ac_compile); then - if test yes = "$lt_cv_prog_gnu_ld"; 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* - ;; - -mips64*-*linux*) - # Find out what ABI is being produced by ac_compile, and set linker - # options accordingly. - echo '#line '$LINENO' "configure"' > conftest.$ac_ext - if AC_TRY_EVAL(ac_compile); then - emul=elf - case `/usr/bin/file conftest.$ac_objext` in - *32-bit*) - emul="${emul}32" - ;; - *64-bit*) - emul="${emul}64" - ;; - esac - case `/usr/bin/file conftest.$ac_objext` in - *MSB*) - emul="${emul}btsmip" - ;; - *LSB*) - emul="${emul}ltsmip" - ;; - esac - case `/usr/bin/file conftest.$ac_objext` in - *N32*) - emul="${emul}n32" - ;; - esac - LD="${LD-ld} -m $emul" - fi - rm -rf conftest* - ;; - -x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ -s390*-*linux*|s390*-*tpf*|sparc*-*linux*) - # Find out what ABI is being produced by ac_compile, and set linker - # options accordingly. Note that the listed cases only cover the - # situations where additional linker options are needed (such as when - # doing 32-bit compilation for a host where ld defaults to 64-bit, or - # vice versa); the common cases where no linker options are needed do - # not appear in the list. - 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-*linux*) - LD="${LD-ld} -m elf32lppclinux" - ;; - powerpc64-*linux*) - 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-*linux*) - LD="${LD-ld} -m elf64lppc" - ;; - powerpc-*linux*) - 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 yes != "$lt_cv_cc_needs_belf"; then - # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf - CFLAGS=$SAVE_CFLAGS - fi - ;; -*-*solaris*) - # Find out what ABI is being produced by ac_compile, and set linker - # options accordingly. - 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*|x86_64-*-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=cr} -_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 0 -eq "$ac_status"; then - # Ensure the archiver fails upon bogus file names. - rm -f conftest.$ac_objext libconftest.a - AC_TRY_EVAL(lt_ar_try) - if test 0 -ne "$ac_status"; then - lt_cv_ar_at_file=@ - fi - fi - rm -f conftest.* libconftest.a - ) - ) - -if test no = "$lt_cv_ar_at_file"; 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 - bitrig* | 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" ## exclude from sc_useless_quotes_in_assignment - # 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 yes = "$$2"; 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 yes = "$$2"; 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; - ;; - - bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*) - # 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 17 != "$i" # 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 yes = "$cross_compiling"; 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 <dlfcn.h> -#endif - -#include <stdio.h> - -#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 -fvisibility=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 yes != "$enable_dlopen"; 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 - ) - ;; - - tpf*) - # Don't try to run any link tests for TPF. We know it's impossible - # because TPF is a cross-compiler, and we know how we open DSOs. - lt_cv_dlopen=dlopen - lt_cv_dlopen_libs= - lt_cv_dlopen_self=no - ;; - - *) - 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 no = "$lt_cv_dlopen"; then - enable_dlopen=no - else - enable_dlopen=yes - fi - - case $lt_cv_dlopen in - dlopen) - save_CPPFLAGS=$CPPFLAGS - test yes = "$ac_cv_header_dlfcn_h" && 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 yes = "$lt_cv_dlopen_self"; 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 no = "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" && test no != "$need_locks"; 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 no = "$hard_links"; 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 where 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 yes = "$_LT_TAGVAR(hardcode_automatic, $1)"; then - - # We can hardcode non-existent directories. - if test no != "$_LT_TAGVAR(hardcode_direct, $1)" && - # 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 no != "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" && - test no != "$_LT_TAGVAR(hardcode_minus_L, $1)"; 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 relink = "$_LT_TAGVAR(hardcode_action, $1)" || - test yes = "$_LT_TAGVAR(inherit_rpath, $1)"; then - # Fast installation is not supported - enable_fast_install=no -elif test yes = "$shlibpath_overrides_runpath" || - test no = "$enable_shared"; 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_PREPARE_MUNGE_PATH_LIST -# --------------------------- -# Make sure func_munge_path_list() is defined correctly. -m4_defun(_LT_PREPARE_MUNGE_PATH_LIST, -# func_munge_path_list VARIABLE PATH -# ----------------------------------- -# VARIABLE is name of variable containing _space_ separated list of -# directories to be munged by the contents of PATH, which is string -# having a format: -# "DIR:DIR:" -# string "DIR DIR" will be prepended to VARIABLE -# ":DIR:DIR" -# string "DIR DIR" will be appended to VARIABLE -# "DIRP:DIRP::DIRA:DIRA" -# string "DIRP DIRP" will be prepended to VARIABLE and string -# "DIRA DIRA" will be appended to VARIABLE -# "DIR:DIR" -# VARIABLE will be replaced by "DIR DIR" -func_munge_path_list () -{ - case x@S|@2 in - x) - ;; - *:) - eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'` \@S|@@S|@1\" - ;; - x:*) - eval @S|@1=\"\@S|@@S|@1 `$ECHO @S|@2 | $SED 's/:/ /g'`\" - ;; - *::*) - eval @S|@1=\"\@S|@@S|@1\ `$ECHO @S|@2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" - eval @S|@1=\"`$ECHO @S|@2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \@S|@@S|@1\" - ;; - *) - eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'`\" - ;; - esac -} -)# _LT_PREPARE_PATH_LIST - - -# _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 -m4_require(_LT_PREPARE_MUNGE_PATH_LIST)dnl -AC_MSG_CHECKING(dynamic linker characteristics) -m4_if($1, - , -if test yes = "$GCC"; 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` - # ...but if some path component already ends with the multilib dir we assume - # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer). - case "$lt_multi_os_dir; $lt_search_path_spec " in - "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*) - lt_multi_os_dir= - ;; - esac - 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" - elif test -n "$lt_multi_os_dir"; then - 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_freqlt_foo++; } - if (lt_freqlt_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 - -AC_ARG_VAR(LT_SYS_LIBRARY_PATH, -User-defined run-time library search path.) - -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' - ;; - -aix4-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 ia64 = "$host_cpu"; 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 - # Using Import Files as archive members, it is possible to support - # filename-based versioning of shared library archives on AIX. While - # this would work for both with and without runtime linking, it will - # prevent static linking of such archives. So we do filename-based - # shared library versioning with .so extension only, which is used - # when both runtime linking and shared linking is enabled. - # Unfortunately, runtime linking may impact performance, so we do - # not want this to be the default eventually. Also, we use the - # versioned .so libs for executables only if there is the -brtl - # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. - # To allow for filename-based versioning support, we need to create - # libNAME.so.V as an archive file, containing: - # *) an Import File, referring to the versioned filename of the - # archive as well as the shared archive member, telling the - # bitwidth (32 or 64) of that shared object, and providing the - # list of exported symbols of that shared object, eventually - # decorated with the 'weak' keyword - # *) the shared object with the F_LOADONLY flag set, to really avoid - # it being seen by the linker. - # At run time we better use the real file rather than another symlink, - # but for link time we create the symlink libNAME.so -> libNAME.so.V - - case $with_aix_soname,$aix_use_runtimelinking in - # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct - # soname into executable. Probably we can add versioning support to - # collect2, so additional links can be useful in future. - aix,yes) # traditional libtool - dynamic_linker='AIX unversionable lib.so' - # If using run time linking (on AIX 4.2 or later) use lib<name>.so - # instead of lib<name>.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' - ;; - aix,no) # traditional AIX only - dynamic_linker='AIX lib.a(lib.so.V)' - # 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' - ;; - svr4,*) # full svr4 only - dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o)" - library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' - # We do not specify a path in Import Files, so LIBPATH fires. - shlibpath_overrides_runpath=yes - ;; - *,yes) # both, prefer svr4 - dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o), lib.a(lib.so.V)" - library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' - # unpreferred sharedlib libNAME.a needs extra handling - postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' - postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' - # We do not specify a path in Import Files, so LIBPATH fires. - shlibpath_overrides_runpath=yes - ;; - *,no) # both, prefer aix - dynamic_linker="AIX lib.a(lib.so.V), lib.so.V($shared_archive_member_spec.o)" - library_names_spec='$libname$release.a $libname.a' - soname_spec='$libname$release$shared_ext$major' - # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling - postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' - postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' - ;; - esac - 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%'\''`; $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 - ;; - -bsdi45*) - 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 - freebsd23.*) 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$major $libname$shared_ext' - soname_spec='$libname$release$shared_ext$major' - 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=no - 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 32 = "$HPUX_IA64_MODE"; then - sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" - sys_lib_dlsearch_path_spec=/usr/lib/hpux32 - else - sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" - sys_lib_dlsearch_path_spec=/usr/lib/hpux64 - fi - ;; - 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 - ;; - -interix3-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 yes = "$lt_cv_prog_gnu_ld"; 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 - ;; - -linux*android*) - version_type=none # Android doesn't support versioned libraries. - need_lib_prefix=no - need_version=no - library_names_spec='$libname$release$shared_ext' - soname_spec='$libname$release$shared_ext' - finish_cmds= - shlibpath_var=LD_LIBRARY_PATH - shlibpath_overrides_runpath=yes - - # 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 - - dynamic_linker='Android linker' - # Don't embed -rpath directories since the linker doesn't support them. - _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' - ;; - -# 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 - - # Ideally, we could use ldconfig to report *all* directores which are - # searched for libraries, however this is still not possible. Aside from not - # being certain /sbin/ldconfig is available, command - # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, - # even though it is searched at run-time. Try to do the best guess by - # appending ld.so.conf contents (and includes) 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* | bitrig*) - version_type=sunos - sys_lib_dlsearch_path_spec=/usr/lib - need_lib_prefix=no - if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then - need_version=no - else - need_version=yes - fi - 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 - shlibpath_overrides_runpath=yes - ;; - -os2*) - libname_spec='$name' - version_type=windows - shrext_cmds=.dll - need_version=no - need_lib_prefix=no - # OS/2 can only load a DLL with a base name of 8 characters or less. - soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; - v=$($ECHO $release$versuffix | tr -d .-); - n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); - $ECHO $n$v`$shared_ext' - library_names_spec='${libname}_dll.$libext' - dynamic_linker='OS/2 ld.exe' - shlibpath_var=BEGINLIBPATH - sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" - sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec - 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' - ;; - -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 yes = "$with_gnu_ld"; 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=sco - 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 yes = "$with_gnu_ld"; 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 no = "$dynamic_linker" && can_build_shared=no - -variables_saved_for_relink="PATH $shlibpath_var $runpath_var" -if test yes = "$GCC"; then - variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" -fi - -if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then - sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec -fi - -if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then - sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec -fi - -# remember unaugmented sys_lib_dlsearch_path content for libtool script decls... -configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec - -# ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code -func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" - -# to be used as default LT_SYS_LIBRARY_PATH value in generated libtool -configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH - -_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, configure_time_dlsearch_path, 2, - Detected run-time system search path for libraries) -_LT_DECL(, configure_time_lt_sys_library_path, 2, - Explicit LT_SYS_LIBRARY_PATH set during ./configure time) -)# _LT_SYS_DYNAMIC_LINKER - - -# _LT_PATH_TOOL_PREFIX(TOOL) -# -------------------------- -# find a file program that 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 that 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 no = "$withval" || with_gnu_ld=yes, - with_gnu_ld=no)dnl - -ac_prog=ld -if test yes = "$GCC"; 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 yes = "$with_gnu_ld"; 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 </dev/null` in - *GNU* | *'with BFD'*) - test no != "$with_gnu_ld" && break - ;; - *) - test yes != "$with_gnu_ld" && break - ;; - esac - fi - done - IFS=$lt_save_ifs -else - lt_cv_path_LD=$LD # Let the user override the test with a path. -fi) -LD=$lt_cv_path_LD -if test -n "$LD"; then - AC_MSG_RESULT($LD) -else - AC_MSG_RESULT(no) -fi -test -z "$LD" && AC_MSG_ERROR(no acceptable ld found in \$PATH) -_LT_PATH_LD_GNU -AC_SUBST(LD) - -_LT_TAGDECL(, LD, 1, The linker used to build libraries) -)# LT_PATH_LD - -# Old names: -AU_ALIAS(AM_PROG_LD, LT_PATH_LD) -AU_ALIAS(AC_PROG_LD, LT_PATH_LD) -dnl aclocal-1.4 backwards compatibility: -dnl AC_DEFUN(AM_PROG_LD, ) -dnl AC_DEFUN(AC_PROG_LD, ) - - -# _LT_PATH_LD_GNU -#- -------------- -m4_defun(_LT_PATH_LD_GNU, -AC_CACHE_CHECK(if the linker ($LD) is GNU ld, lt_cv_prog_gnu_ld, -# I'd rather use --version here, but apparently some GNU lds only accept -v. -case `$LD -v 2>&1 </dev/null` in -*GNU* | *'with BFD'*) - lt_cv_prog_gnu_ld=yes - ;; -*) - lt_cv_prog_gnu_ld=no - ;; -esac) -with_gnu_ld=$lt_cv_prog_gnu_ld -)# _LT_PATH_LD_GNU - - -# _LT_CMD_RELOAD -# -------------- -# find reload flag for linker -# -- PORTME Some linkers may need a different reload flag. -m4_defun(_LT_CMD_RELOAD, -AC_CACHE_CHECK(for $LD option to reload object files, - lt_cv_ld_reload_flag, - lt_cv_ld_reload_flag='-r') -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 yes != "$GCC"; then - reload_cmds=false - fi - ;; - darwin*) - if test yes = "$GCC"; then - reload_cmds='$LTCC $LTCFLAGS -nostdlib $wl-r -o $output$reload_objs' - else - reload_cmds='$LD$reload_flag -o $output$reload_objs' - fi - ;; -esac -_LT_TAGDECL(, reload_flag, 1, How to create reloadable object files)dnl -_LT_TAGDECL(, reload_cmds, 2)dnl -)# _LT_CMD_RELOAD - - -# _LT_PATH_DD -# ----------- -# find a working dd -m4_defun(_LT_PATH_DD, -AC_CACHE_CHECK(for a working dd, ac_cv_path_lt_DD, -printf 0123456789abcdef0123456789abcdef >conftest.i -cat conftest.i conftest.i >conftest2.i -: ${lt_DD:=$DD} -AC_PATH_PROGS_FEATURE_CHECK(lt_DD, dd, -if "$ac_path_lt_DD" bs=32 count=1 <conftest2.i >conftest.out 2>/dev/null; then - cmp -s conftest.i conftest.out \ - && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=: -fi) -rm -f conftest.i conftest2.i conftest.out) -)# _LT_PATH_DD - - -# _LT_CMD_TRUNCATE -# ---------------- -# find command to truncate a binary pipe -m4_defun(_LT_CMD_TRUNCATE, -m4_require(_LT_PATH_DD) -AC_CACHE_CHECK(how to truncate binary pipes, lt_cv_truncate_bin, -printf 0123456789abcdef0123456789abcdef >conftest.i -cat conftest.i conftest.i >conftest2.i -lt_cv_truncate_bin= -if "$ac_cv_path_lt_DD" bs=32 count=1 <conftest2.i >conftest.out 2>/dev/null; then - cmp -s conftest.i conftest.out \ - && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1" -fi -rm -f conftest.i conftest2.i conftest.out -test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q") -_LT_DECL(lt_truncate_bin, lt_cv_truncate_bin, 1, - Command to truncate a binary pipe) -)# _LT_CMD_TRUNCATE - - -# _LT_CHECK_MAGIC_METHOD -# ---------------------- -# how to check for library dependencies -# -- PORTME fill in with the dynamic library characteristics -m4_defun(_LT_CHECK_MAGIC_METHOD, -m4_require(_LT_DECL_EGREP) -m4_require(_LT_DECL_OBJDUMP) -AC_CACHE_CHECK(how to recognize dependent libraries, -lt_cv_deplibs_check_method, -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 -# that 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 -aix4-9*) - lt_cv_deplibs_check_method=pass_all - ;; - -beos*) - lt_cv_deplibs_check_method=pass_all - ;; - -bsdi45*) - lt_cv_deplibs_check_method='file_magic ELF 0-90-9*-bit MLSB (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. - if ( 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)/i3-986 (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 (s0-90-90-9|ELF-0-90-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 (s0-90-90-9|ELF -0-90-9)(-bit)?( LMSB)? 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 (s0-90-90-9|PA-RISC0-9\.0-9) shared library' - lt_cv_file_magic_test_file=/usr/lib/libc.sl - ;; - esac - ;; - -interix3-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-90-9*-bit MLSB (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* | bitrig*) - if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; 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-90-9*-bit MLSB (shared object|dynamic lib) M0-90-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-90-9*-bit LMSB (shared object|dynamic lib )' - ;; - sni) - lt_cv_file_magic_cmd='/bin/file' - lt_cv_deplibs_check_method="file_magic ELF 0-90-9*-bit LMSB 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 - ;; -os2*) - 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 - # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty - case $build_os in - mingw*) lt_bad_file=conftest.nm/nofile ;; - *) lt_bad_file=/dev/null ;; - esac - case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in - *$lt_bad_file* | *'Invalid file or object type'*) - lt_cv_path_NM="$tmp_nm -B" - break 2 - ;; - *) - case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in - */dev/null*) - lt_cv_path_NM="$tmp_nm -p" - break 2 - ;; - *) - 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 no != "$lt_cv_path_NM"; 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 -headers /dev/null 2>&1 | sed '1q'` in - *COFF*) - DUMPBIN="$DUMPBIN -symbols -headers" - ;; - *) - 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 one 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 yes != "$lt_cv_path_mainfest_tool"; then - MANIFEST_TOOL=: -fi -_LT_DECL(, MANIFEST_TOOL, 1, Manifest tool)dnl -)# _LT_PATH_MANIFEST_TOOL - - -# _LT_DLL_DEF_P(FILE) -# --------------------- -# True iff FILE is a Windows DLL '.def' file. -# Keep in sync with func_dll_def_p in the libtool script -AC_DEFUN(_LT_DLL_DEF_P, -dnl - test DEF = "`$SED -n dnl - -e '\''s/^ *//'\'' dnl Strip leading whitespace - -e '\''/^\(;.*\)*$/d'\'' dnl Delete empty lines and comments - -e '\''s/^\(EXPORTS\|LIBRARY\)\( .*\)*$/DEF/p'\'' dnl - -e q dnl Only consider the first "real" line - $1`" dnl -)# _LT_DLL_DEF_P - - -# 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 yes = "$GCC"; 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 ia64 = "$host_cpu"; 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 - -if test "$lt_cv_nm_interface" = "MS dumpbin"; then - # Gets list of data symbols to import. - lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'" - # Adjust the below global symbol transforms to fixup imported variables. - lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'" - lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'" - lt_c_name_lib_hook="\ - -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\ - -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'" -else - # Disable hooks by default. - lt_cv_sys_global_symbol_to_import= - lt_cdecl_hook= - lt_c_name_hook= - lt_c_name_lib_hook= -fi - -# 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"\ -$lt_cdecl_hook\ -" -e 's/^T .* \(.*\)$/extern int \1();/p'"\ -" -e 's/^$symcode$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"\ -$lt_c_name_hook\ -" -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ -" -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'" - -# Transform an extracted symbol line into symbol name with lib prefix and -# symbol address. -lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\ -$lt_c_name_lib_hook\ -" -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ -" -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\ -" -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/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, - # D for any global variable and I for any imported 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 hidei};"\ -" /Section length .*#relocs.*(pick any)/{hidelast_section=1};"\ -" /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn2,2)};"\ -" /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\ -" /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\ -" \$ 0!~/External *\|/{next};"\ -" / 0+ UNDEF /{next}; / UNDEF \(^|\)*()/{next};"\ -" {if(hidesection) next};"\ -" {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\ -" {split(\$ 0,a,/\||\r/); split(a2,s)};"\ -" s1~/^@?/{print f,s1,s1; next};"\ -" s1~prfx {split(s1,t,\"@\"); print f,t1,substr(t1,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 - $ECHO "$as_me:$LINENO: $NM conftest.$ac_objext | $lt_cv_sys_global_symbol_pipe > $nlist" >&AS_MESSAGE_LOG_FD - if eval "$NM" conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist 2>&AS_MESSAGE_LOG_FD && 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 can'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* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$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 yes = "$pipe_works"; 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_import, lt_cv_sys_global_symbol_to_import, 1, - Transform the output of nm into a list of symbols to manually relocate) -_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_interface, lt_cv_nm_interface, 1, - The name lister interface) -_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 yes = "$GXX"; 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 ia64 = "$host_cpu"; then - # AIX 5 now supports IA64 processor - _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' - fi - _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' - ;; - - 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') - case $host_os in - os2*) - _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' - ;; - esac - ;; - 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)= - ;; - interix3-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 - aix4-9*) - # All AIX code is PIC. - if test ia64 = "$host_cpu"; 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 ia64 != "$host_cpu"; 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* | bgxlcC* | mpixlcC*) - # 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 yes = "$GCC"; 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 ia64 = "$host_cpu"; then - # AIX 5 now supports IA64 processor - _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' - fi - _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' - ;; - - 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') - case $host_os in - os2*) - _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' - ;; - esac - ;; - - 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 - ;; - - interix3-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 ia64 = "$host_cpu"; 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 - ;; - - 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' - case $cc_basename in - 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' - ;; - esac - ;; - - 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') - case $host_os in - os2*) - _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' - ;; - esac - ;; - - 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' - ;; - # flang / f18. f95 an alias for gfortran or flang on Debian - flang* | f18* | f95*) - _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' - _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' - _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' - ;; - tcc*) - # Fabrice Bellard et al's Tiny 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)='-static' - ;; - 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 that 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__FID_.*' - case $host_os in - aix4-9*) - # If we're using GNU nm, then we don't want the "-C" option. - # -C means demangle to GNU nm, but means don't demangle to AIX nm. - # Without the "-l" option, or with the "-B" option, AIX nm treats - # weak defined symbols like other global defined symbols, whereas - # GNU nm marks them as "W". - # While the 'weak' keyword is ignored in the Export File, we need - # it in the Import File for the 'aix-soname' feature, so we have - # to replace the "-B" option with "-P" for AIX nm. - 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) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' - else - _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\(^B*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | 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__FID_.*' - # 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 yes != "$GCC"; then - with_gnu_ld=no - fi - ;; - interix*) - # we just hope/assume this is gcc and not c89 (= MSVC++) - with_gnu_ld=yes - ;; - openbsd* | bitrig*) - 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 yes = "$with_gnu_ld"; 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 yes = "$lt_use_gnu_ld_interface"; 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 | $SED -e 's/(^)\+)\s\+//' 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 - aix3-9*) - # On AIX/PPC, the GNU linker is very broken - if test ia64 != "$host_cpu"; 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 <jrb3@best.com> 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, use it as - # is; otherwise, prepend EXPORTS... - _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P($export_symbols); 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 - ;; - - os2*) - _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' - _LT_TAGVAR(hardcode_minus_L, $1)=yes - _LT_TAGVAR(allow_undefined_flag, $1)=unsupported - shrext_cmds=.dll - _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ - $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ - $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ - $ECHO EXPORTS >> $output_objdir/$libname.def~ - emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ - $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ - emximp -o $lib $output_objdir/$libname.def' - _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ - $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ - $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ - $ECHO EXPORTS >> $output_objdir/$libname.def~ - prefix_cmds="$SED"~ - if test EXPORTS = "`$SED 1q $export_symbols`"; then - prefix_cmds="$prefix_cmds -e 1d"; - fi~ - prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ - cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ - $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ - emximp -o $lib $output_objdir/$libname.def' - _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' - _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes - ;; - - interix3-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 linux-dietlibc = "$host_os"; 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 no = "$tmp_diet" - 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' ;; - nagfor*) # NAGFOR 5.3 - tmp_sharedflag='-Wl,-shared' ;; - xlcC* | bgxlcC* | mpixlcC*) # 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 yes = "$supports_anon_versioning"; 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 - tcc*) - _LT_TAGVAR(export_dynamic_flag_spec, $1)='-rdynamic' - ;; - 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 yes = "$supports_anon_versioning"; 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.10-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 cannot -*** 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 no = "$_LT_TAGVAR(ld_shlibs, $1)"; 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 yes = "$GCC" && 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 - ;; - - aix4-9*) - if test ia64 = "$host_cpu"; 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 GNU nm, but means don't demangle to AIX nm. - # Without the "-l" option, or with the "-B" option, AIX nm treats - # weak defined symbols like other global defined symbols, whereas - # GNU nm marks them as "W". - # While the 'weak' keyword is ignored in the Export File, we need - # it in the Import File for the 'aix-soname' feature, so we have - # to replace the "-B" option with "-P" for AIX nm. - 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) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' - else - _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\(^B*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | 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 - # have runtime linking enabled, and use it for executables. - # For shared libraries, we enable/disable runtime linking - # depending on the kind of the shared library created - - # when "with_aix_soname,aix_use_runtimelinking" is: - # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables - # "aix,yes" lib.so shared, rtl:yes, for executables - # lib.a static archive - # "both,no" lib.so.V(shr.o) shared, rtl:yes - # lib.a(lib.so.V) shared, rtl:no, for executables - # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables - # lib.a(lib.so.V) shared, rtl:no - # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables - # lib.a static archive - case $host_os in aix4.23|aix4.23.*|aix5-9*) - for ld_flag in $LDFLAGS; do - if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then - aix_use_runtimelinking=yes - break - fi - done - if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then - # With aix-soname=svr4, we create the lib.so.V shared archives only, - # so we don't have lib.a shared libs to link our executables. - # We have to force runtime linking in this case. - aix_use_runtimelinking=yes - LDFLAGS="$LDFLAGS -Wl,-brtl" - fi - ;; - 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,' - case $with_aix_soname,$aix_use_runtimelinking in - aix,*) ;; # traditional, no import file - svr4,* | *,yes) # use import file - # The Import File defines what to hardcode. - _LT_TAGVAR(hardcode_direct, $1)=no - _LT_TAGVAR(hardcode_direct_absolute, $1)=no - ;; - esac - - if test yes = "$GCC"; 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 yes = "$aix_use_runtimelinking"; then - shared_flag="$shared_flag "'$wl-G' - fi - # Need to ensure runtime linking is disabled for the traditional - # shared library, or the linker may eventually find shared libraries - # /with/ Import File - we do not want to mix them. - shared_flag_aix='-shared' - shared_flag_svr4='-shared $wl-G' - else - # not using gcc - if test ia64 = "$host_cpu"; 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 yes = "$aix_use_runtimelinking"; then - shared_flag='$wl-G' - else - shared_flag='$wl-bM:SRE' - fi - shared_flag_aix='$wl-bM:SRE' - shared_flag_svr4='$wl-G' - 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,yes = "$with_aix_soname,$aix_use_runtimelinking"; 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 -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag - else - if test ia64 = "$host_cpu"; 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 yes = "$with_gnu_ld"; 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 - _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' - # -brtl affects multiple linker settings, -berok does not and is overridden later - compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\(, \\)%-berok\\1%g"`' - if test svr4 != "$with_aix_soname"; then - # This is similar to how AIX traditionally builds its shared libraries. - _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' - fi - if test aix != "$with_aix_soname"; then - _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' - else - # used by -dlpreopen to get the symbols - _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' - fi - _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' - 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 - ;; - - bsdi45*) - _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,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' - _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P($export_symbols); then - cp "$export_symbols" "$output_objdir/$soname.def"; - echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; - else - $SED -e '\''s/^/-link -EXPORT:/'\'' < $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 yes = "$GCC"; 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 "x$output_objdir/$soname" = "x$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 "x$output_objdir/$soname" = "x$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 yes,no = "$GCC,$with_gnu_ld"; 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 no = "$with_gnu_ld"; 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 yes,no = "$GCC,$with_gnu_ld"; 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 no = "$with_gnu_ld"; 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 yes = "$GCC"; 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 yes = "$lt_cv_irix_exported_symbol"; 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 - _LT_TAGVAR(link_all_deplibs, $1)=no - 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 - ;; - - linux*) - case $cc_basename in - tcc*) - # Fabrice Bellard et al's Tiny C Compiler - _LT_TAGVAR(ld_shlibs, $1)=yes - _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' - ;; - esac - ;; - - 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* | bitrig*) - 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__`"; 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 - _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' - 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 - shrext_cmds=.dll - _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ - $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ - $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ - $ECHO EXPORTS >> $output_objdir/$libname.def~ - emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ - $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ - emximp -o $lib $output_objdir/$libname.def' - _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ - $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ - $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ - $ECHO EXPORTS >> $output_objdir/$libname.def~ - prefix_cmds="$SED"~ - if test EXPORTS = "`$SED 1q $export_symbols`"; then - prefix_cmds="$prefix_cmds -e 1d"; - fi~ - prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ - cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ - $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ - emximp -o $lib $output_objdir/$libname.def' - _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' - _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes - ;; - - osf3*) - if test yes = "$GCC"; 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 yes = "$GCC"; 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 yes = "$GCC"; 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 yes = "$GCC"; 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 sequent = "$host_vendor"; 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 yes = "$GCC"; 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 CANNOT 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 yes = "$GCC"; 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 sni = "$host_vendor"; 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 no = "$_LT_TAGVAR(ld_shlibs, $1)" && 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 yes,yes = "$GCC,$enable_shared"; 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 - -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 what 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 no = "$can_build_shared" && 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 yes = "$enable_shared" && enable_static=no - if test -n "$RANLIB"; then - archive_cmds="$archive_cmds~\$RANLIB \$lib" - postinstall_cmds='$RANLIB $lib' - fi - ;; - - aix4-9*) - if test ia64 != "$host_cpu"; then - case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in - yes,aix,yes) ;; # shared object as lib.so file only - yes,svr4,*) ;; # shared object as lib.so archive member only - yes,*) enable_static=no ;; # shared object in lib.a archive as well - esac - 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 yes = "$enable_shared" || 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 no != "$CXX" && - ( (test g++ = "$CXX" && `g++ -v >/dev/null 2>&1` ) || - (test g++ != "$CXX"))); 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 yes != "$_lt_caught_CXX_error"; 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 yes = "$GXX"; 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 yes = "$GXX"; 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 yes = "$with_gnu_ld"; 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 - ;; - aix4-9*) - if test ia64 = "$host_cpu"; 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 - # have runtime linking enabled, and use it for executables. - # For shared libraries, we enable/disable runtime linking - # depending on the kind of the shared library created - - # when "with_aix_soname,aix_use_runtimelinking" is: - # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables - # "aix,yes" lib.so shared, rtl:yes, for executables - # lib.a static archive - # "both,no" lib.so.V(shr.o) shared, rtl:yes - # lib.a(lib.so.V) shared, rtl:no, for executables - # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables - # lib.a(lib.so.V) shared, rtl:no - # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables - # lib.a static archive - case $host_os in aix4.23|aix4.23.*|aix5-9*) - for ld_flag in $LDFLAGS; do - case $ld_flag in - *-brtl*) - aix_use_runtimelinking=yes - break - ;; - esac - done - if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then - # With aix-soname=svr4, we create the lib.so.V shared archives only, - # so we don't have lib.a shared libs to link our executables. - # We have to force runtime linking in this case. - aix_use_runtimelinking=yes - LDFLAGS="$LDFLAGS -Wl,-brtl" - fi - ;; - 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,' - case $with_aix_soname,$aix_use_runtimelinking in - aix,*) ;; # no import file - svr4,* | *,yes) # use import file - # The Import File defines what to hardcode. - _LT_TAGVAR(hardcode_direct, $1)=no - _LT_TAGVAR(hardcode_direct_absolute, $1)=no - ;; - esac - - if test yes = "$GXX"; 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 yes = "$aix_use_runtimelinking"; then - shared_flag=$shared_flag' $wl-G' - fi - # Need to ensure runtime linking is disabled for the traditional - # shared library, or the linker may eventually find shared libraries - # /with/ Import File - we do not want to mix them. - shared_flag_aix='-shared' - shared_flag_svr4='-shared $wl-G' - else - # not using gcc - if test ia64 = "$host_cpu"; 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 yes = "$aix_use_runtimelinking"; then - shared_flag='$wl-G' - else - shared_flag='$wl-bM:SRE' - fi - shared_flag_aix='$wl-bM:SRE' - shared_flag_svr4='$wl-G' - 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,yes = "$with_aix_soname,$aix_use_runtimelinking"; then - # Warning - without using the other runtime loading flags (-brtl), - # -berok will link without error, but may produce a broken library. - # The "-G" linker flag allows undefined symbols. - _LT_TAGVAR(no_undefined_flag, $1)='-bernotok' - # 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 -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag - else - if test ia64 = "$host_cpu"; 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 yes = "$with_gnu_ld"; 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 - _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' - # -brtl affects multiple linker settings, -berok does not and is overridden later - compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\(, \\)%-berok\\1%g"`' - if test svr4 != "$with_aix_soname"; then - # This is similar to how AIX traditionally builds its shared - # libraries. Need -bnortl late, we may have -brtl in LDFLAGS. - _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' - fi - if test aix != "$with_aix_soname"; then - _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' - else - # used by -dlpreopen to get the symbols - _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' - fi - _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' - fi - fi - ;; - - beos*) - if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then - _LT_TAGVAR(allow_undefined_flag, $1)=unsupported - # Joseph Beckenbach <jrb3@best.com> 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,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' - _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P($export_symbols); then - cp "$export_symbols" "$output_objdir/$soname.def"; - echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; - else - $SED -e '\''s/^/-link -EXPORT:/'\'' < $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, use it as - # is; otherwise, prepend EXPORTS... - _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P($export_symbols); 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) - ;; - - os2*) - _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' - _LT_TAGVAR(hardcode_minus_L, $1)=yes - _LT_TAGVAR(allow_undefined_flag, $1)=unsupported - shrext_cmds=.dll - _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ - $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ - $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ - $ECHO EXPORTS >> $output_objdir/$libname.def~ - emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ - $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ - emximp -o $lib $output_objdir/$libname.def' - _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ - $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ - $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ - $ECHO EXPORTS >> $output_objdir/$libname.def~ - prefix_cmds="$SED"~ - if test EXPORTS = "`$SED 1q $export_symbols`"; then - prefix_cmds="$prefix_cmds -e 1d"; - fi~ - prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ - cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ - $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ - emximp -o $lib $output_objdir/$libname.def' - _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' - _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes - ;; - - 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 "x$output_objdir/$soname" = "x$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 yes = "$GXX"; 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 "x$output_objdir/$soname" = "x$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 no = "$with_gnu_ld"; 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 yes = "$GXX"; then - if test no = "$with_gnu_ld"; 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 - ;; - - interix3-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 yes = "$GXX"; then - if test no = "$with_gnu_ld"; 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 yes = "$supports_anon_versioning"; 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 - ;; - - openbsd* | bitrig*) - 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__`"; 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 yes,no = "$GXX,$with_gnu_ld"; 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 yes,no = "$GXX,$with_gnu_ld"; 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 $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 $wl-h $wl$soname -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 $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 $wl-h $wl$soname -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 CANNOT 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 no = "$_LT_TAGVAR(ld_shlibs, $1)" && 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 yes != "$_lt_caught_CXX_error" - -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 @S|@2 in - .*) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%\\\\@S|@2\$%%"`;; - *) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%@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 x-L = "$p" || - test x-R = "$p"; 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 no = "$pre_test_object_deps_done"; 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 no = "$pre_test_object_deps_done"; 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 -interix3-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)= - ;; -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 no = "$F77"; 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 yes != "$_lt_disable_F77"; 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 no = "$can_build_shared" && 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 yes = "$enable_shared" && enable_static=no - if test -n "$RANLIB"; then - archive_cmds="$archive_cmds~\$RANLIB \$lib" - postinstall_cmds='$RANLIB $lib' - fi - ;; - aix4-9*) - if test ia64 != "$host_cpu"; then - case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in - yes,aix,yes) ;; # shared object as lib.so file only - yes,svr4,*) ;; # shared object as lib.so archive member only - yes,*) enable_static=no ;; # shared object in lib.a archive as well - esac - 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 yes = "$enable_shared" || 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 yes != "$_lt_disable_F77" - -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 no = "$FC"; 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 yes != "$_lt_disable_FC"; 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 no = "$can_build_shared" && 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 yes = "$enable_shared" && enable_static=no - if test -n "$RANLIB"; then - archive_cmds="$archive_cmds~\$RANLIB \$lib" - postinstall_cmds='$RANLIB $lib' - fi - ;; - aix4-9*) - if test ia64 != "$host_cpu"; then - case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in - yes,aix,yes) ;; # shared object as lib.so file only - yes,svr4,*) ;; # shared object as lib.so archive member only - yes,*) enable_static=no ;; # shared object in lib.a archive as well - esac - 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 yes = "$enable_shared" || 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 yes != "$_lt_disable_FC" - -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 - -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 - -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(AM_PROG_GCJ, AM_PROG_GCJ, - AC_CHECK_TOOL(GCJ, gcj,) - test set = "${GCJFLAGS+set}" || 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 10 -lt "$lt_ac_count" && 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, -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_PATH_CONVERSION_FUNCTIONS -# ----------------------------- -# Determine what 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 - -# Helper functions for option handling. -*- Autoconf -*- -# -# Copyright (C) 2004-2005, 2007-2009, 2011-2015 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 8 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_UNLESS_OPTIONS(LT_INIT, aix-soname=aix aix-soname=both aix-soname=svr4, - _LT_WITH_AIX_SONAME(aix)) - ) -)# _LT_SET_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_AIX_SONAME(DEFAULT) -# ---------------------------------- -# implement the --with-aix-soname flag, and support the `aix-soname=aix' -# and `aix-soname=both' and `aix-soname=svr4' LT_INIT options. DEFAULT -# is either `aix', `both' or `svr4'. If omitted, it defaults to `aix'. -m4_define(_LT_WITH_AIX_SONAME, -m4_define(_LT_WITH_AIX_SONAME_DEFAULT, m4_if($1, svr4, svr4, m4_if($1, both, both, aix)))dnl -shared_archive_member_spec= -case $host,$enable_shared in -power*-*-aix5-9*,yes) - AC_MSG_CHECKING(which variant of shared library versioning to provide) - AC_ARG_WITH(aix-soname, - AS_HELP_STRING(--with-aix-soname=aix|svr4|both, - shared library versioning (aka "SONAME") variant to provide on AIX, @<:@default=_LT_WITH_AIX_SONAME_DEFAULT@:>@.), - case $withval in - aix|svr4|both) - ;; - *) - AC_MSG_ERROR(Unknown argument to --with-aix-soname) - ;; - esac - lt_cv_with_aix_soname=$with_aix_soname, - AC_CACHE_VAL(lt_cv_with_aix_soname, - lt_cv_with_aix_soname=_LT_WITH_AIX_SONAME_DEFAULT) - with_aix_soname=$lt_cv_with_aix_soname) - AC_MSG_RESULT($with_aix_soname) - if test aix != "$with_aix_soname"; then - # For the AIX way of multilib, we name the shared archive member - # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o', - # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File. - # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag, - # the AIX toolchain works better with OBJECT_MODE set (default 32). - if test 64 = "${OBJECT_MODE-32}"; then - shared_archive_member_spec=shr_64 - else - shared_archive_member_spec=shr - fi - fi - ;; -*) - with_aix_soname=aix - ;; -esac - -_LT_DECL(, shared_archive_member_spec, 0, - Shared archive member basename, for filename based shared library versioning on AIX)dnl -)# _LT_WITH_AIX_SONAME - -LT_OPTION_DEFINE(LT_INIT, aix-soname=aix, _LT_WITH_AIX_SONAME(aix)) -LT_OPTION_DEFINE(LT_INIT, aix-soname=both, _LT_WITH_AIX_SONAME(both)) -LT_OPTION_DEFINE(LT_INIT, aix-soname=svr4, _LT_WITH_AIX_SONAME(svr4)) - - -# _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=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, ) - - -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)) - -# ltsugar.m4 -- libtool m4 base layer. -*-Autoconf-*- -# -# Copyright (C) 2004-2005, 2007-2008, 2011-2015 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)$3m4_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($3m4_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 -) - -# ltversion.m4 -- version numbers -*- Autoconf -*- -# -# Copyright (C) 2004, 2011-2015 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 4179 ltversion.m4 -# This file is part of GNU Libtool - -m4_define(LT_PACKAGE_VERSION, 2.4.6) -m4_define(LT_PACKAGE_REVISION, 2.4.6) - -AC_DEFUN(LTVERSION_VERSION, -macro_version='2.4.6' -macro_revision='2.4.6' -_LT_DECL(, macro_version, 0, Which release of libtool.m4 was used?) -_LT_DECL(, macro_revision, 0) -) - -# lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*- -# -# Copyright (C) 2004-2005, 2007, 2009, 2011-2015 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)) - -# Copyright (C) 2002-2021 Free Software Foundation, Inc. +# 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, @@ -9086,10 +32,10 @@ # 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.16' +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.16.4, , +m4_if($1, 1.15, , AC_FATAL(Do not call $0, use AM_INIT_AUTOMAKE($1).))dnl ) @@ -9105,12 +51,12 @@ # 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.16.4)dnl +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))) -# Copyright (C) 2011-2021 Free Software Foundation, Inc. +# Copyright (C) 2011-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -9172,7 +118,7 @@ # Figure out how to run the assembler. -*- Autoconf -*- -# Copyright (C) 2001-2021 Free Software Foundation, Inc. +# 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, @@ -9192,7 +138,7 @@ # AM_AUX_DIR_EXPAND -*- Autoconf -*- -# Copyright (C) 2001-2021 Free Software Foundation, Inc. +# 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, @@ -9244,7 +190,7 @@ # AM_COND_IF -*- Autoconf -*- -# Copyright (C) 2008-2021 Free Software Foundation, Inc. +# Copyright (C) 2008-2014 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -9281,7 +227,7 @@ # AM_CONDITIONAL -*- Autoconf -*- -# Copyright (C) 1997-2021 Free Software Foundation, Inc. +# 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, @@ -9312,7 +258,7 @@ Usually this means the macro was only invoked conditionally.) fi)) -# Copyright (C) 1999-2021 Free Software Foundation, Inc. +# 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, @@ -9503,12 +449,13 @@ # Generate code to set up dependency tracking. -*- Autoconf -*- -# Copyright (C) 1999-2021 Free Software Foundation, Inc. +# 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, @@ -9516,43 +463,49 @@ # 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. - # TODO: see whether this extra hack can be removed once we start - # requiring Autoconf 2.70 or later. - AS_CASE($CONFIG_FILES, - *\'*, eval set x "$CONFIG_FILES", - *, set x $CONFIG_FILES) + case $CONFIG_FILES in + *\'*) eval set x "$CONFIG_FILES" ;; + *) set x $CONFIG_FILES ;; + esac shift - # Used to flag and report bootstrapping failures. - am_rc=0 - for am_mf + for mf do # Strip MF so we end up with the name of the file. - am_mf=`AS_ECHO("$am_mf") | sed -e 's/:.*$//'` - # Check whether this is an Automake generated Makefile which includes - # dependency-tracking related rules and includes. - # Grep'ing the whole file directly is not great: AIX grep has a line + 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. - sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \ - || continue - am_dirpart=`AS_DIRNAME("$am_mf")` - am_filepart=`AS_BASENAME("$am_mf")` - AM_RUN_LOG(cd "$am_dirpart" \ - && sed -e '/# am--include-marker/d' "$am_filepart" \ - | $MAKE -f - am--depfiles) || am_rc=$? + 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 - if test $am_rc -ne 0; then - AC_MSG_FAILURE(Something went wrong bootstrapping makefile fragments - for automatic dependency tracking. If GNU make was not used, consider - re-running the configure script with MAKE="gmake" (or whatever is - necessary). You can also try re-running configure with the - '--disable-dependency-tracking' option to at least be able to build - the package (albeit without support for automatic dependency tracking).) - fi - AS_UNSET(am_dirpart) - AS_UNSET(am_filepart) - AS_UNSET(am_mf) - AS_UNSET(am_rc) - rm -f conftest-deps.mk } )# _AM_OUTPUT_DEPENDENCY_COMMANDS @@ -9561,17 +514,18 @@ # ----------------------------- # This macro should only be invoked once -- use via AC_REQUIRE. # -# This code is only required when automatic dependency tracking is enabled. -# This creates each '.Po' and '.Plo' makefile fragment that we'll need in -# order to bootstrap the dependency handling code. +# 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" MAKE="${MAKE-make}")) + AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir") +) # Do all the work for Automake. -*- Autoconf -*- -# Copyright (C) 1996-2021 Free Software Foundation, Inc. +# 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, @@ -9635,7 +589,7 @@ _AM_SET_OPTIONS($1)dnl dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT. m4_if( - m4_ifset(AC_PACKAGE_NAME, ok):m4_ifset(AC_PACKAGE_VERSION, ok), + 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 @@ -9658,8 +612,8 @@ 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: -# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html> -# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html> +# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html> +# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html> 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. @@ -9687,20 +641,6 @@ m4_define(AC_PROG_OBJCXX, m4_defn(AC_PROG_OBJCXX)_AM_DEPENDENCIES(OBJCXX)))dnl ) -# Variables for tags utilities; see am/tags.am -if test -z "$CTAGS"; then - CTAGS=ctags -fi -AC_SUBST(CTAGS) -if test -z "$ETAGS"; then - ETAGS=etags -fi -AC_SUBST(ETAGS) -if test -z "$CSCOPE"; then - CSCOPE=cscope -fi -AC_SUBST(CSCOPE) - 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 @@ -9740,7 +680,7 @@ 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: <https://www.gnu.org/software/coreutils/>. +that behaves properly: <http://www.gnu.org/software/coreutils/>. If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM @@ -9782,7 +722,7 @@ done echo "timestamp for $_am_arg" >`AS_DIRNAME("$_am_arg")`/stamp-h$_am_stamp_count) -# Copyright (C) 2001-2021 Free Software Foundation, Inc. +# 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, @@ -9803,7 +743,7 @@ fi AC_SUBST(install_sh)) -# Copyright (C) 2003-2021 Free Software Foundation, Inc. +# 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, @@ -9825,7 +765,7 @@ # Add --enable-maintainer-mode option to configure. -*- Autoconf -*- # From Jim Meyering -# Copyright (C) 1996-2021 Free Software Foundation, Inc. +# 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, @@ -9860,7 +800,7 @@ # Check to see how 'make' treats includes. -*- Autoconf -*- -# Copyright (C) 2001-2021 Free Software Foundation, Inc. +# 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, @@ -9868,42 +808,49 @@ # AM_MAKE_INCLUDE() # ----------------- -# Check whether make has an 'include' directive that can support all -# the idioms we need for our automatic dependency tracking code. +# Check to see how make treats includes. AC_DEFUN(AM_MAKE_INCLUDE, -AC_MSG_CHECKING(whether ${MAKE-make} supports the include directive) -cat > confinc.mk << 'END' +am_make=${MAKE-make} +cat > confinc << 'END' am__doit: - @echo this is the am__doit target >confinc.out + @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= -# BSD make does it like this. -echo '.include "confinc.mk" # ignored' > confmf.BSD -# Other make implementations (GNU, Solaris 10, AIX) do it like this. -echo 'include confinc.mk # ignored' > confmf.GNU -_am_result=no -for s in GNU BSD; do - AM_RUN_LOG(${MAKE-make} -f confmf.$s && cat confinc.out) - AS_CASE($?:`cat confinc.out 2>/dev/null`, - '0:this is the am__doit target', - AS_CASE($s, - BSD, am__include='.include' am__quote='"', - am__include='include' am__quote='')) - if test "$am__include" != "#"; then - _am_result="yes ($s style)" - break - fi -done -rm -f confinc.* confmf.* -AC_MSG_RESULT(${_am_result}) -AC_SUBST(am__include)) -AC_SUBST(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-2021 Free Software Foundation, Inc. +# 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, @@ -9924,7 +871,12 @@ AC_REQUIRE(AM_AUX_DIR_EXPAND)dnl AC_REQUIRE_AUX_FILE(missing)dnl if test x"${MISSING+set}" != xset; then - MISSING="\${SHELL} '$am_aux_dir/missing'" + 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 @@ -9937,7 +889,7 @@ # Helper functions for option handling. -*- Autoconf -*- -# Copyright (C) 2001-2021 Free Software Foundation, Inc. +# 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, @@ -9966,7 +918,7 @@ AC_DEFUN(_AM_IF_OPTION, m4_ifset(_AM_MANGLE_OPTION($1), $2, $3)) -# Copyright (C) 1999-2021 Free Software Foundation, Inc. +# 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, @@ -10013,7 +965,7 @@ # For backward compatibility. AC_DEFUN_ONCE(AM_PROG_CC_C_O, AC_REQUIRE(AC_PROG_CC)) -# Copyright (C) 2001-2021 Free Software Foundation, Inc. +# 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, @@ -10032,7 +984,7 @@ # Check to make sure that the build environment is sane. -*- Autoconf -*- -# Copyright (C) 1996-2021 Free Software Foundation, Inc. +# 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, @@ -10113,7 +1065,7 @@ rm -f conftest.file ) -# Copyright (C) 2009-2021 Free Software Foundation, Inc. +# 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, @@ -10173,7 +1125,7 @@ _AM_SUBST_NOTMAKE(AM_BACKSLASH)dnl ) -# Copyright (C) 2001-2021 Free Software Foundation, Inc. +# 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, @@ -10201,7 +1153,7 @@ INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" AC_SUBST(INSTALL_STRIP_PROGRAM)) -# Copyright (C) 2006-2021 Free Software Foundation, Inc. +# 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, @@ -10220,7 +1172,7 @@ # Check how to create a tarball. -*- Autoconf -*- -# Copyright (C) 2004-2021 Free Software Foundation, Inc. +# 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, @@ -10351,4 +1303,8 @@ AC_SUBST(am__untar) ) # _AM_PROG_TAR -m4_include(acinclude.m4) +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)
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/config/ar-lib -> _service:tar_scm:libunwind-1.7.2.tar.gz/config/ar-lib
Changed
@@ -2,9 +2,9 @@ # Wrapper for Microsoft lib.exe me=ar-lib -scriptversion=2019-07-04.01; # UTC +scriptversion=2012-03-01.08; # UTC -# Copyright (C) 2010-2021 Free Software Foundation, Inc. +# Copyright (C) 2010-2014 Free Software Foundation, Inc. # Written by Peter Rosin <peda@lysator.liu.se>. # # This program is free software; you can redistribute it and/or modify @@ -18,7 +18,7 @@ # 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 <https://www.gnu.org/licenses/>. +# along with this program. If not, see <http://www.gnu.org/licenses/>. # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a @@ -53,7 +53,7 @@ MINGW*) file_conv=mingw ;; - CYGWIN* | MSYS*) + CYGWIN*) file_conv=cygwin ;; *) @@ -65,7 +65,7 @@ mingw) file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'` ;; - cygwin | msys) + cygwin) file=`cygpath -m "$file" || echo "$file"` ;; wine) @@ -224,11 +224,10 @@ esac done else - $AR -NOLOGO -LIST "$archive" | tr -d '\r' | sed -e 's/\\/\\\\/g' \ - | while read member - do - $AR -NOLOGO -EXTRACT:"$member" "$archive" || exit $? - done + $AR -NOLOGO -LIST "$archive" | sed -e 's/\\/\\\\/g' | while read member + do + $AR -NOLOGO -EXTRACT:"$member" "$archive" || exit $? + done fi elif test -n "$quick$replace"; then
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/config/compile -> _service:tar_scm:libunwind-1.7.2.tar.gz/config/compile
Changed
@@ -1,9 +1,9 @@ #! /bin/sh # Wrapper for compilers which do not understand '-c -o'. -scriptversion=2018-03-07.03; # UTC +scriptversion=2012-10-14.11; # UTC -# Copyright (C) 1999-2021 Free Software Foundation, Inc. +# Copyright (C) 1999-2014 Free Software Foundation, Inc. # Written by Tom Tromey <tromey@cygnus.com>. # # This program is free software; you can redistribute it and/or modify @@ -17,7 +17,7 @@ # 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 <https://www.gnu.org/licenses/>. +# along with this program. If not, see <http://www.gnu.org/licenses/>. # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a @@ -53,7 +53,7 @@ MINGW*) file_conv=mingw ;; - CYGWIN* | MSYS*) + CYGWIN*) file_conv=cygwin ;; *) @@ -67,7 +67,7 @@ mingw/*) file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'` ;; - cygwin/* | msys/*) + cygwin/*) file=`cygpath -m "$file" || echo "$file"` ;; wine/*) @@ -255,8 +255,7 @@ echo "compile $scriptversion" exit $? ;; - cl | */\\cl | cl.exe | */\\cl.exe | \ - icl | */\\icl | icl.exe | */\\icl.exe ) + cl | */\\cl | cl.exe | */\\cl.exe ) func_cl_wrapper "$@" # Doesn't return... ;; esac @@ -340,9 +339,9 @@ # Local Variables: # mode: shell-script # sh-indentation: 2 -# eval: (add-hook 'before-save-hook 'time-stamp) +# eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" -# time-stamp-time-zone: "UTC0" +# time-stamp-time-zone: "UTC" # time-stamp-end: "; # UTC" # End:
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/config/config.guess -> _service:tar_scm:libunwind-1.7.2.tar.gz/config/config.guess
Changed
@@ -1,8 +1,8 @@ #! /bin/sh # Attempt to guess a canonical system name. -# Copyright 1992-2018 Free Software Foundation, Inc. +# Copyright 1992-2015 Free Software Foundation, Inc. -timestamp='2018-02-24' +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 @@ -15,7 +15,7 @@ # 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 <https://www.gnu.org/licenses/>. +# along with this program; if not, see <http://www.gnu.org/licenses/>. # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a @@ -27,7 +27,7 @@ # Originally written by Per Bothner; maintained since 2000 by Ben Elliston. # # You can get the latest version of this script from: -# https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess +# http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD # # Please send patches to <config-patches@gnu.org>. @@ -39,7 +39,7 @@ Output the configuration name of the system \`$me' is run on. -Options: +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 @@ -50,7 +50,7 @@ GNU config.guess ($timestamp) Originally written by Per Bothner. -Copyright 1992-2018 Free Software Foundation, Inc. +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." @@ -107,9 +107,9 @@ dummy=$tmp/dummy ; tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ; case $CC_FOR_BUILD,$HOST_CC,$CC in - ,,) echo "int x;" > "$dummy.c" ; + ,,) 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 + if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then CC_FOR_BUILD="$c"; break ; fi ; done ; @@ -132,14 +132,14 @@ UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown -case "$UNAME_SYSTEM" in +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" + eval $set_cc_for_build + cat <<-EOF > $dummy.c #include <features.h> #if defined(__UCLIBC__) LIBC=uclibc @@ -149,20 +149,13 @@ LIBC=gnu #endif EOF - eval "`$CC_FOR_BUILD -E "$dummy.c" 2>/dev/null | grep '^LIBC' | sed 's, ,,g'`" - - # If ldd exists, use it to detect musl libc. - if command -v ldd >/dev/null && \ - ldd --version 2>&1 | grep -q ^musl - then - LIBC=musl - fi + 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 +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*, @@ -176,30 +169,27 @@ # 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 || \ + /sbin/$sysctl 2>/dev/null || \ + /usr/sbin/$sysctl 2>/dev/null || \ echo unknown)` - case "$UNAME_MACHINE_ARCH" in + 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\(armv0-9\).*$,\1,'` - endian=`echo "$UNAME_MACHINE_ARCH" | sed -ne 's,^.*\(eb\)$,\1,p'` - machine="${arch}${endian}"-unknown + arch=`echo ${UNAME_MACHINE_ARCH} | sed -e 's,^e\(armv0-9\).*$,\1,'` + endian=`echo ${UNAME_MACHINE_ARCH} | sed -ne 's,^.*\(eb\)$,\1,p'` + machine=${arch}${endian}-unknown ;; - *) machine="$UNAME_MACHINE_ARCH"-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) and ABI. - case "$UNAME_MACHINE_ARCH" in - earm*) - os=netbsdelf - ;; - arm*|i386|m68k|ns32k|sh3*|sparc|vax) - eval "$set_cc_for_build" + # 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 @@ -215,10 +205,10 @@ ;; esac # Determine ABI tags. - case "$UNAME_MACHINE_ARCH" in + case "${UNAME_MACHINE_ARCH}" in earm*) expr='s/^earmv0-9/-eabi/;s/eb$//' - abi=`echo "$UNAME_MACHINE_ARCH" | sed -e "$expr"` + abi=`echo ${UNAME_MACHINE_ARCH} | sed -e "$expr"` ;; esac # The OS release @@ -226,55 +216,42 @@ # 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 + case "${UNAME_VERSION}" in Debian*) release='-gnu' ;; *) - release=`echo "$UNAME_RELEASE" | sed -e 's/-_.*//' | cut -d. -f1,2` + 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}" + echo "${machine}-${os}${release}${abi}" exit ;; *:Bitrig:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'` - echo "$UNAME_MACHINE_ARCH"-unknown-bitrig"$UNAME_RELEASE" + 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 ;; - *:LibertyBSD:*:*) - UNAME_MACHINE_ARCH=`arch | sed 's/^.*BSD\.//'` - echo "$UNAME_MACHINE_ARCH"-unknown-libertybsd"$UNAME_RELEASE" - exit ;; - *:MidnightBSD:*:*) - echo "$UNAME_MACHINE"-unknown-midnightbsd"$UNAME_RELEASE" + echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE} exit ;; *:ekkoBSD:*:*) - echo "$UNAME_MACHINE"-unknown-ekkobsd"$UNAME_RELEASE" + echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE} exit ;; *:SolidBSD:*:*) - echo "$UNAME_MACHINE"-unknown-solidbsd"$UNAME_RELEASE" + echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE} exit ;; macppc:MirBSD:*:*) - echo powerpc-unknown-mirbsd"$UNAME_RELEASE" + echo powerpc-unknown-mirbsd${UNAME_RELEASE} exit ;; *:MirBSD:*:*) - echo "$UNAME_MACHINE"-unknown-mirbsd"$UNAME_RELEASE" + echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE} exit ;; *:Sortix:*:*) - echo "$UNAME_MACHINE"-unknown-sortix + echo ${UNAME_MACHINE}-unknown-sortix exit ;; - *:Redox:*:*) - echo "$UNAME_MACHINE"-unknown-redox - exit ;; - mips:OSF1:*.*) - echo mips-dec-osf1 - exit ;; alpha:OSF1:*:*) case $UNAME_RELEASE in *4.0) @@ -291,54 +268,63 @@ 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 ;; + UNAME_MACHINE="alpha" ;; "EV4.5 (21064)") - UNAME_MACHINE=alpha ;; + UNAME_MACHINE="alpha" ;; "LCA4 (21066/21068)") - UNAME_MACHINE=alpha ;; + UNAME_MACHINE="alpha" ;; "EV5 (21164)") - UNAME_MACHINE=alphaev5 ;; + UNAME_MACHINE="alphaev5" ;; "EV5.6 (21164A)") - UNAME_MACHINE=alphaev56 ;; + UNAME_MACHINE="alphaev56" ;; "EV5.6 (21164PC)") - UNAME_MACHINE=alphapca56 ;; + UNAME_MACHINE="alphapca56" ;; "EV5.7 (21164PC)") - UNAME_MACHINE=alphapca57 ;; + UNAME_MACHINE="alphapca57" ;; "EV6 (21264)") - UNAME_MACHINE=alphaev6 ;; + UNAME_MACHINE="alphaev6" ;; "EV6.7 (21264A)") - UNAME_MACHINE=alphaev67 ;; + UNAME_MACHINE="alphaev67" ;; "EV6.8CB (21264C)") - UNAME_MACHINE=alphaev68 ;; + UNAME_MACHINE="alphaev68" ;; "EV6.8AL (21264B)") - UNAME_MACHINE=alphaev68 ;; + UNAME_MACHINE="alphaev68" ;; "EV6.8CX (21264D)") - UNAME_MACHINE=alphaev68 ;; + UNAME_MACHINE="alphaev68" ;; "EV6.9A (21264/EV69A)") - UNAME_MACHINE=alphaev69 ;; + UNAME_MACHINE="alphaev69" ;; "EV7 (21364)") - UNAME_MACHINE=alphaev7 ;; + UNAME_MACHINE="alphaev7" ;; "EV7.9 (21364A)") - UNAME_MACHINE=alphaev79 ;; + 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`" + 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 ;; *:AamigaOoSs:*:*) - echo "$UNAME_MACHINE"-unknown-amigaos + echo ${UNAME_MACHINE}-unknown-amigaos exit ;; *:MmorphOoSs:*:*) - echo "$UNAME_MACHINE"-unknown-morphos + echo ${UNAME_MACHINE}-unknown-morphos exit ;; *:OS/390:*:*) echo i370-ibm-openedition @@ -350,7 +336,7 @@ echo powerpc-ibm-os400 exit ;; arm:RISC*:1.012*:*|arm:riscix:1.012*:*) - echo arm-acorn-riscix"$UNAME_RELEASE" + echo arm-acorn-riscix${UNAME_RELEASE} exit ;; arm*:riscos:*:*|arm*:RISCOS:*:*) echo arm-unknown-riscos @@ -377,38 +363,38 @@ sparc) echo sparc-icl-nx7; exit ;; esac ;; s390x:SunOS:*:*) - echo "$UNAME_MACHINE"-ibm-solaris2"`echo "$UNAME_RELEASE" | sed -e 's/^.*//'`" + 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/^.*//'`" + 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/^.*//'`" + echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/^.*//'` exit ;; i86pc:AuroraUX:5.*:* | i86xen:AuroraUX:5.*:*) - echo i386-pc-auroraux"$UNAME_RELEASE" + echo i386-pc-auroraux${UNAME_RELEASE} exit ;; i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*) - eval "$set_cc_for_build" - SUN_ARCH=i386 + 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 "$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) | \ + (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ grep IS_64BIT_ARCH >/dev/null then - SUN_ARCH=x86_64 + SUN_ARCH="x86_64" fi fi - echo "$SUN_ARCH"-pc-solaris2"`echo "$UNAME_RELEASE"|sed -e 's/^.*//'`" + 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/^.*//'`" + echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/^.*//'` exit ;; sun4*:SunOS:*:*) case "`/usr/bin/arch -k`" in @@ -417,25 +403,25 @@ ;; esac # Japanese Language versions have a version number like `4.1.3-JL'. - echo sparc-sun-sunos"`echo "$UNAME_RELEASE"|sed -e 's/-/_/'`" + echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'` exit ;; sun3*:SunOS:*:*) - echo m68k-sun-sunos"$UNAME_RELEASE" + 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 + test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3 case "`/bin/arch`" in sun3) - echo m68k-sun-sunos"$UNAME_RELEASE" + echo m68k-sun-sunos${UNAME_RELEASE} ;; sun4) - echo sparc-sun-sunos"$UNAME_RELEASE" + echo sparc-sun-sunos${UNAME_RELEASE} ;; esac exit ;; aushp:SunOS:*:*) - echo sparc-auspex-sunos"$UNAME_RELEASE" + 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 @@ -446,44 +432,44 @@ # MiNT. But MiNT is downward compatible to TOS, so this should # be no problem. atariste:*MiNT:*:* | atariste:*mint:*:* | atariste:*TOS:*:*) - echo m68k-atari-mint"$UNAME_RELEASE" + echo m68k-atari-mint${UNAME_RELEASE} exit ;; atari*:*MiNT:*:* | atari*:*mint:*:* | atariste:*TOS:*:*) - echo m68k-atari-mint"$UNAME_RELEASE" + echo m68k-atari-mint${UNAME_RELEASE} exit ;; *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*) - echo m68k-atari-mint"$UNAME_RELEASE" + echo m68k-atari-mint${UNAME_RELEASE} exit ;; milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*) - echo m68k-milan-mint"$UNAME_RELEASE" + echo m68k-milan-mint${UNAME_RELEASE} exit ;; hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*) - echo m68k-hades-mint"$UNAME_RELEASE" + echo m68k-hades-mint${UNAME_RELEASE} exit ;; *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*) - echo m68k-unknown-mint"$UNAME_RELEASE" + echo m68k-unknown-mint${UNAME_RELEASE} exit ;; m68k:machten:*:*) - echo m68k-apple-machten"$UNAME_RELEASE" + echo m68k-apple-machten${UNAME_RELEASE} exit ;; powerpc:machten:*:*) - echo powerpc-apple-machten"$UNAME_RELEASE" + echo powerpc-apple-machten${UNAME_RELEASE} exit ;; RISC*:Mach:*:*) echo mips-dec-mach_bsd4.3 exit ;; RISC*:ULTRIX:*:*) - echo mips-dec-ultrix"$UNAME_RELEASE" + echo mips-dec-ultrix${UNAME_RELEASE} exit ;; VAX*:ULTRIX*:*:*) - echo vax-dec-ultrix"$UNAME_RELEASE" + echo vax-dec-ultrix${UNAME_RELEASE} exit ;; 2020:CLIX:*:* | 2430:CLIX:*:*) - echo clipper-intergraph-clix"$UNAME_RELEASE" + echo clipper-intergraph-clix${UNAME_RELEASE} exit ;; mips:*:*:UMIPS | mips:*:*:RISCos) - eval "$set_cc_for_build" - sed 's/^ //' << EOF > "$dummy.c" + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c #ifdef __cplusplus #include <stdio.h> /* for printf() prototype */ int main (int argc, char *argv) { @@ -492,23 +478,23 @@ #endif #if defined (host_mips) && defined (MIPSEB) #if defined (SYSTYPE_SYSV) - printf ("mips-mips-riscos%ssysv\\n", argv1); exit (0); + printf ("mips-mips-riscos%ssysv\n", argv1); exit (0); #endif #if defined (SYSTYPE_SVR4) - printf ("mips-mips-riscos%ssvr4\\n", argv1); exit (0); + printf ("mips-mips-riscos%ssvr4\n", argv1); exit (0); #endif #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD) - printf ("mips-mips-riscos%sbsd\\n", argv1); exit (0); + printf ("mips-mips-riscos%sbsd\n", argv1); 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"` && + $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" + echo mips-mips-riscos${UNAME_RELEASE} exit ;; Motorola:PowerMAX_OS:*:*) echo powerpc-motorola-powermax @@ -534,17 +520,17 @@ AViiON:dgux:*:*) # DG/UX returns AViiON for all architectures UNAME_PROCESSOR=`/usr/bin/uname -p` - if "$UNAME_PROCESSOR" = mc88100 || "$UNAME_PROCESSOR" = mc88110 + if $UNAME_PROCESSOR = mc88100 || $UNAME_PROCESSOR = mc88110 then - if "$TARGET_BINARY_INTERFACE"x = m88kdguxelfx || \ - "$TARGET_BINARY_INTERFACE"x = x + if ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx || \ + ${TARGET_BINARY_INTERFACE}x = x then - echo m88k-dg-dgux"$UNAME_RELEASE" + echo m88k-dg-dgux${UNAME_RELEASE} else - echo m88k-dg-dguxbcs"$UNAME_RELEASE" + echo m88k-dg-dguxbcs${UNAME_RELEASE} fi else - echo i586-dg-dgux"$UNAME_RELEASE" + echo i586-dg-dgux${UNAME_RELEASE} fi exit ;; M88*:DolphinOS:*:*) # DolphinOS (SVR3) @@ -561,7 +547,7 @@ echo m68k-tektronix-bsd exit ;; *:IRIX*:*:*) - echo mips-sgi-irix"`echo "$UNAME_RELEASE"|sed -e 's/-/_/g'`" + 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 @@ -573,14 +559,14 @@ if -x /usr/bin/oslevel ; then IBM_REV=`/usr/bin/oslevel` else - IBM_REV="$UNAME_VERSION.$UNAME_RELEASE" + IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} fi - echo "$UNAME_MACHINE"-ibm-aix"$IBM_REV" + 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" + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c #include <sys/systemcfg.h> main() @@ -591,7 +577,7 @@ exit(0); } EOF - if $CC_FOR_BUILD -o "$dummy" "$dummy.c" && SYSTEM_NAME=`"$dummy"` + if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` then echo "$SYSTEM_NAME" else @@ -605,7 +591,7 @@ 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 + if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then IBM_ARCH=rs6000 else IBM_ARCH=powerpc @@ -614,18 +600,18 @@ 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" + IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} fi - echo "$IBM_ARCH"-ibm-aix"$IBM_REV" + echo ${IBM_ARCH}-ibm-aix${IBM_REV} exit ;; *:AIX:*:*) echo rs6000-ibm-aix exit ;; - ibmrt:4.4BSD:*|romp-ibm:4.4BSD:*) + 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 + echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to exit ;; # report: romp-ibm BSD 4.3 *:BOSX:*:*) echo rs6000-bull-bosx @@ -640,28 +626,28 @@ 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 ;; + HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/^.*.0B*//'` + case "${UNAME_MACHINE}" in + 9000/31? ) HP_ARCH=m68000 ;; + 9000/34?? ) HP_ARCH=m68k ;; 9000/6780-90-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 + 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 + 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" + if "${HP_ARCH}" = "" ; then + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c #define _HPUX_SOURCE #include <stdlib.h> @@ -694,13 +680,13 @@ exit (0); } EOF - (CCOPTS="" $CC_FOR_BUILD -o "$dummy" "$dummy.c" 2>/dev/null) && HP_ARCH=`"$dummy"` + (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 + if ${HP_ARCH} = "hppa2.0w" then - eval "$set_cc_for_build" + 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 @@ -711,23 +697,23 @@ # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess # => hppa64-hp-hpux11.23 - if echo __LP64__ | (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | + if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | grep -q __LP64__ then - HP_ARCH=hppa2.0w + HP_ARCH="hppa2.0w" else - HP_ARCH=hppa64 + HP_ARCH="hppa64" fi fi - echo "$HP_ARCH"-hp-hpux"$HPUX_REV" + 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" + 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" + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c #include <unistd.h> int main () @@ -752,11 +738,11 @@ exit (0); } EOF - $CC_FOR_BUILD -o "$dummy" "$dummy.c" && SYSTEM_NAME=`"$dummy"` && + $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:*:*) + 9000/7??:4.3bsd:*:* | 9000/8?79:4.3bsd:*:* ) echo hppa1.1-hp-bsd exit ;; 9000/8??:4.3bsd:*:*) @@ -765,7 +751,7 @@ *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*) echo hppa1.0-hp-mpeix exit ;; - hp7??:OSF1:*:* | hp8?79:OSF1:*:*) + hp7??:OSF1:*:* | hp8?79:OSF1:*:* ) echo hppa1.1-hp-osf exit ;; hp8??:OSF1:*:*) @@ -773,9 +759,9 @@ exit ;; i*86:OSF1:*:*) if -x /usr/sbin/sysversion ; then - echo "$UNAME_MACHINE"-unknown-osf1mk + echo ${UNAME_MACHINE}-unknown-osf1mk else - echo "$UNAME_MACHINE"-unknown-osf1 + echo ${UNAME_MACHINE}-unknown-osf1 fi exit ;; parisc*:Lites*:*:*) @@ -800,109 +786,127 @@ echo c4-convex-bsd exit ;; CRAY*Y-MP:*:*:*) - echo ymp-cray-unicos"$UNAME_RELEASE" | sed -e 's/\.^.*$/.X/' + echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.^.*$/.X/' exit ;; CRAY*A-Z90:*:*:*) - echo "$UNAME_MACHINE"-cray-unicos"$UNAME_RELEASE" \ + echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \ | sed -e 's/CRAY.*\(A-Z90\)/\1/' \ -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \ -e 's/\.^.*$/.X/' exit ;; CRAY*TS:*:*:*) - echo t90-cray-unicos"$UNAME_RELEASE" | sed -e 's/\.^.*$/.X/' + echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.^.*$/.X/' exit ;; CRAY*T3E:*:*:*) - echo alphaev5-cray-unicosmk"$UNAME_RELEASE" | sed -e 's/\.^.*$/.X/' + echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.^.*$/.X/' exit ;; CRAY*SV1:*:*:*) - echo sv1-cray-unicos"$UNAME_RELEASE" | sed -e 's/\.^.*$/.X/' + echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.^.*$/.X/' exit ;; *:UNICOS/mp:*:*) - echo craynv-cray-unicosmp"$UNAME_RELEASE" | sed -e 's/\.^.*$/.X/' + echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.^.*$/.X/' exit ;; F3001: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/ /_/'` + 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/ /_/'` + 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" + echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE} exit ;; sparc*:BSD/OS:*:*) - echo sparc-unknown-bsdi"$UNAME_RELEASE" + echo sparc-unknown-bsdi${UNAME_RELEASE} exit ;; *:BSD/OS:*:*) - echo "$UNAME_MACHINE"-unknown-bsdi"$UNAME_RELEASE" + echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE} exit ;; *:FreeBSD:*:*) UNAME_PROCESSOR=`/usr/bin/uname -p` - case "$UNAME_PROCESSOR" in + case ${UNAME_PROCESSOR} in amd64) - UNAME_PROCESSOR=x86_64 ;; - i386) - UNAME_PROCESSOR=i586 ;; + echo x86_64-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/-(.*//'` ;; + *) + echo ${UNAME_PROCESSOR}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/-(.*//'` ;; esac - echo "$UNAME_PROCESSOR"-unknown-freebsd"`echo "$UNAME_RELEASE"|sed -e 's/-(.*//'`" exit ;; i*:CYGWIN*:*) - echo "$UNAME_MACHINE"-pc-cygwin + echo ${UNAME_MACHINE}-pc-cygwin exit ;; *:MINGW64*:*) - echo "$UNAME_MACHINE"-pc-mingw64 + echo ${UNAME_MACHINE}-pc-mingw64 exit ;; *:MINGW*:*) - echo "$UNAME_MACHINE"-pc-mingw32 + echo ${UNAME_MACHINE}-pc-mingw32 exit ;; *:MSYS*:*) - echo "$UNAME_MACHINE"-pc-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 + echo ${UNAME_MACHINE}-pc-pw32 exit ;; *:Interix*:*) - case "$UNAME_MACHINE" in + case ${UNAME_MACHINE} in x86) - echo i586-pc-interix"$UNAME_RELEASE" + echo i586-pc-interix${UNAME_RELEASE} exit ;; authenticamd | genuineintel | EM64T) - echo x86_64-unknown-interix"$UNAME_RELEASE" + echo x86_64-unknown-interix${UNAME_RELEASE} exit ;; IA64) - echo ia64-unknown-interix"$UNAME_RELEASE" + echo ia64-unknown-interix${UNAME_RELEASE} exit ;; esac ;; + 34586:Windows_95:* | 34586:Windows_98:* | 34586: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 + 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/^.*//'`" + 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,/.*$,,'`" + 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 ":upper:" ":lower:"``echo "$UNAME_RELEASE"|sed -e 's/-(.*//'`-$LIBC" + 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 + echo ${UNAME_MACHINE}-pc-minix exit ;; aarch64:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; aarch64_be:Linux:*:*) UNAME_MACHINE=aarch64_be - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; alpha:Linux:*:*) case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in @@ -915,64 +919,61 @@ 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" + if test "$?" = 0 ; then LIBC="gnulibc1" ; fi + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; arc:Linux:*:* | arceb:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; arm*:Linux:*:*) - eval "$set_cc_for_build" + 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" + 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 + echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabi else - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"eabihf + echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabihf fi fi exit ;; avr32*:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; cris:Linux:*:*) - echo "$UNAME_MACHINE"-axis-linux-"$LIBC" + echo ${UNAME_MACHINE}-axis-linux-${LIBC} exit ;; crisv32:Linux:*:*) - echo "$UNAME_MACHINE"-axis-linux-"$LIBC" + echo ${UNAME_MACHINE}-axis-linux-${LIBC} exit ;; e2k:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; frv:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; hexagon:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; i*86:Linux:*:*) - echo "$UNAME_MACHINE"-pc-linux-"$LIBC" + echo ${UNAME_MACHINE}-pc-linux-${LIBC} exit ;; ia64:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" - exit ;; - k1om:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; m32r*:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; m68*:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; mips:Linux:*:* | mips64:Linux:*:*) - eval "$set_cc_for_build" - sed 's/^ //' << EOF > "$dummy.c" + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c #undef CPU #undef ${UNAME_MACHINE} #undef ${UNAME_MACHINE}el @@ -986,74 +987,64 @@ #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; } + eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^CPU'` + test x"${CPU}" != x && { echo "${CPU}-unknown-linux-${LIBC}"; exit; } ;; - mips64el:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" - exit ;; openrisc*:Linux:*:*) - echo or1k-unknown-linux-"$LIBC" + echo or1k-unknown-linux-${LIBC} exit ;; or32:Linux:*:* | or1k*:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; padre:Linux:*:*) - echo sparc-unknown-linux-"$LIBC" + echo sparc-unknown-linux-${LIBC} exit ;; parisc64:Linux:*:* | hppa64:Linux:*:*) - echo hppa64-unknown-linux-"$LIBC" + 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" ;; + 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" + echo powerpc64-unknown-linux-${LIBC} exit ;; ppc:Linux:*:*) - echo powerpc-unknown-linux-"$LIBC" + echo powerpc-unknown-linux-${LIBC} exit ;; ppc64le:Linux:*:*) - echo powerpc64le-unknown-linux-"$LIBC" + echo powerpc64le-unknown-linux-${LIBC} exit ;; ppcle:Linux:*:*) - echo powerpcle-unknown-linux-"$LIBC" - exit ;; - riscv32:Linux:*:* | riscv64:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo powerpcle-unknown-linux-${LIBC} exit ;; s390:Linux:*:* | s390x:Linux:*:*) - echo "$UNAME_MACHINE"-ibm-linux-"$LIBC" + echo ${UNAME_MACHINE}-ibm-linux-${LIBC} exit ;; sh64*:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; sh*:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; sparc:Linux:*:* | sparc64:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; tile*:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; vax:Linux:*:*) - echo "$UNAME_MACHINE"-dec-linux-"$LIBC" + echo ${UNAME_MACHINE}-dec-linux-${LIBC} exit ;; x86_64:Linux:*:*) - if objdump -f /bin/sh | grep -q elf32-x86-64; then - echo "$UNAME_MACHINE"-pc-linux-"$LIBC"x32 - else - echo "$UNAME_MACHINE"-pc-linux-"$LIBC" - fi + echo ${UNAME_MACHINE}-pc-linux-${LIBC} exit ;; xtensa*:Linux:*:*) - echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; i*86:DYNIX/ptx:4*:*) # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. @@ -1067,34 +1058,34 @@ # 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" + 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 + echo ${UNAME_MACHINE}-pc-os2-emx exit ;; i*86:XTS-300:*:STOP) - echo "$UNAME_MACHINE"-unknown-stop + echo ${UNAME_MACHINE}-unknown-stop exit ;; i*86:atheos:*:*) - echo "$UNAME_MACHINE"-unknown-atheos + echo ${UNAME_MACHINE}-unknown-atheos exit ;; i*86:syllable:*:*) - echo "$UNAME_MACHINE"-pc-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" + echo i386-unknown-lynxos${UNAME_RELEASE} exit ;; i*86:*DOS:*:*) - echo "$UNAME_MACHINE"-pc-msdosdjgpp + echo ${UNAME_MACHINE}-pc-msdosdjgpp exit ;; - i*86:*:4.*:*) - UNAME_REL=`echo "$UNAME_RELEASE" | sed 's/\/MP$//'` + 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" + echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL} else - echo "$UNAME_MACHINE"-pc-sysv"$UNAME_REL" + echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL} fi exit ;; i*86:*:5:678*) @@ -1104,12 +1095,12 @@ *Pentium) UNAME_MACHINE=i586 ;; *Pent*|*Celeron) UNAME_MACHINE=i686 ;; esac - echo "$UNAME_MACHINE-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}{$UNAME_VERSION}" + 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' </usr/options/cb.name` - echo "$UNAME_MACHINE"-pc-isc"$UNAME_REL" + echo ${UNAME_MACHINE}-pc-isc$UNAME_REL elif /bin/uname -X 2>/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 @@ -1119,9 +1110,9 @@ && UNAME_MACHINE=i686 (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \ && UNAME_MACHINE=i686 - echo "$UNAME_MACHINE"-pc-sco"$UNAME_REL" + echo ${UNAME_MACHINE}-pc-sco$UNAME_REL else - echo "$UNAME_MACHINE"-pc-sysv32 + echo ${UNAME_MACHINE}-pc-sysv32 fi exit ;; pc:*:*:*) @@ -1129,7 +1120,7 @@ # 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 configure will decide that + # prints for the "djgpp" host, or else GDB configury will decide that # this is a cross-build. echo i586-pc-msdosdjgpp exit ;; @@ -1141,9 +1132,9 @@ 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 + 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 + echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4 fi exit ;; mini*:CTIX:SYS*5:*) @@ -1163,9 +1154,9 @@ test -r /etc/.relid \ && OS_REL=.`sed -n 's/^ * ^ * \(0-90-9\).*/\1/p' < /etc/.relid` /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ - && { echo i486-ncr-sysv4.3"$OS_REL"; exit; } + && { 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; } ;; + && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; 334??:*:4.0:* | 334??,*:*:4.0:*) /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4; exit; } ;; @@ -1174,28 +1165,28 @@ test -r /etc/.relid \ && OS_REL=.`sed -n 's/^ * ^ * \(0-90-9\).*/\1/p' < /etc/.relid` /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ - && { echo i486-ncr-sysv4.3"$OS_REL"; exit; } + && { 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; } + && { 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; } ;; + && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*) - echo m68k-unknown-lynxos"$UNAME_RELEASE" + 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" + echo sparc-unknown-lynxos${UNAME_RELEASE} exit ;; rs6000:LynxOS:2.*:*) - echo rs6000-unknown-lynxos"$UNAME_RELEASE" + echo rs6000-unknown-lynxos${UNAME_RELEASE} exit ;; PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.01*:* | PowerPC:LynxOS:4.02*:*) - echo powerpc-unknown-lynxos"$UNAME_RELEASE" + echo powerpc-unknown-lynxos${UNAME_RELEASE} exit ;; SMBES:UNIX_SV:*:*) - echo mips-dde-sysv"$UNAME_RELEASE" + echo mips-dde-sysv${UNAME_RELEASE} exit ;; RM*:ReliantUNIX-*:*:*) echo mips-sni-sysv4 @@ -1206,7 +1197,7 @@ *:SINIX-*:*:*) if uname -p 2>/dev/null >/dev/null ; then UNAME_MACHINE=`(uname -p) 2>/dev/null` - echo "$UNAME_MACHINE"-sni-sysv4 + echo ${UNAME_MACHINE}-sni-sysv4 else echo ns32k-sni-sysv fi @@ -1226,23 +1217,23 @@ exit ;; i*86:VOS:*:*) # From Paul.Green@stratus.com. - echo "$UNAME_MACHINE"-stratus-vos + 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" + echo m68k-apple-aux${UNAME_RELEASE} exit ;; news*:NEWS-OS:6*:*) echo mips-sony-newsos6 exit ;; R34000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*) if -d /usr/nec ; then - echo mips-nec-sysv"$UNAME_RELEASE" + echo mips-nec-sysv${UNAME_RELEASE} else - echo mips-unknown-sysv"$UNAME_RELEASE" + echo mips-unknown-sysv${UNAME_RELEASE} fi exit ;; BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only. @@ -1261,56 +1252,46 @@ echo x86_64-unknown-haiku exit ;; SX-4:SUPER-UX:*:*) - echo sx4-nec-superux"$UNAME_RELEASE" + echo sx4-nec-superux${UNAME_RELEASE} exit ;; SX-5:SUPER-UX:*:*) - echo sx5-nec-superux"$UNAME_RELEASE" + echo sx5-nec-superux${UNAME_RELEASE} exit ;; SX-6:SUPER-UX:*:*) - echo sx6-nec-superux"$UNAME_RELEASE" + echo sx6-nec-superux${UNAME_RELEASE} exit ;; SX-7:SUPER-UX:*:*) - echo sx7-nec-superux"$UNAME_RELEASE" + echo sx7-nec-superux${UNAME_RELEASE} exit ;; SX-8:SUPER-UX:*:*) - echo sx8-nec-superux"$UNAME_RELEASE" + echo sx8-nec-superux${UNAME_RELEASE} exit ;; SX-8R:SUPER-UX:*:*) - echo sx8r-nec-superux"$UNAME_RELEASE" - exit ;; - SX-ACE:SUPER-UX:*:*) - echo sxace-nec-superux"$UNAME_RELEASE" + echo sx8r-nec-superux${UNAME_RELEASE} exit ;; Power*:Rhapsody:*:*) - echo powerpc-apple-rhapsody"$UNAME_RELEASE" + echo powerpc-apple-rhapsody${UNAME_RELEASE} exit ;; *:Rhapsody:*:*) - echo "$UNAME_MACHINE"-apple-rhapsody"$UNAME_RELEASE" + echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE} exit ;; *:Darwin:*:*) UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown - eval "$set_cc_for_build" + 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 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 + (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 - # On 10.4-10.6 one might compile for PowerPC via gcc -arch ppc - if (echo '#ifdef __POWERPC__'; echo IS_PPC; echo '#endif') | \ - (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \ - grep IS_PPC >/dev/null - then - UNAME_PROCESSOR=powerpc - fi fi elif test "$UNAME_PROCESSOR" = i386 ; then # Avoid executing cc on OS X 10.9, as it ships with a stub @@ -1321,33 +1302,27 @@ # that Apple uses in portable devices. UNAME_PROCESSOR=x86_64 fi - echo "$UNAME_PROCESSOR"-apple-darwin"$UNAME_RELEASE" + echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE} exit ;; *:procnto*:*:* | *:QNX:0123456789*:*) UNAME_PROCESSOR=`uname -p` - if test "$UNAME_PROCESSOR" = x86; then + if test "$UNAME_PROCESSOR" = "x86"; then UNAME_PROCESSOR=i386 UNAME_MACHINE=pc fi - echo "$UNAME_PROCESSOR"-"$UNAME_MACHINE"-nto-qnx"$UNAME_RELEASE" + 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" + 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" + echo nse-tandem-nsk${UNAME_RELEASE} exit ;; - NSV-*:NONSTOP_KERNEL:*:*) - echo nsv-tandem-nsk"$UNAME_RELEASE" - exit ;; - NSX-*:NONSTOP_KERNEL:*:*) - echo nsx-tandem-nsk"$UNAME_RELEASE" + NSR-?:NONSTOP_KERNEL:*:*) + echo nsr-tandem-nsk${UNAME_RELEASE} exit ;; *:NonStop-UX:*:*) echo mips-compaq-nonstopux @@ -1356,18 +1331,18 @@ echo bs2000-siemens-sysv exit ;; DS/*:UNIX_System_V:*:*) - echo "$UNAME_MACHINE"-"$UNAME_SYSTEM"-"$UNAME_RELEASE" + 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 + if test "$cputype" = "386"; then UNAME_MACHINE=i386 else UNAME_MACHINE="$cputype" fi - echo "$UNAME_MACHINE"-unknown-plan9 + echo ${UNAME_MACHINE}-unknown-plan9 exit ;; *:TOPS-10:*:*) echo pdp10-unknown-tops10 @@ -1388,14 +1363,14 @@ echo pdp10-unknown-its exit ;; SEI:*:*:SEIUX) - echo mips-sei-seiux"$UNAME_RELEASE" + echo mips-sei-seiux${UNAME_RELEASE} exit ;; *:DragonFly:*:*) - echo "$UNAME_MACHINE"-unknown-dragonfly"`echo "$UNAME_RELEASE"|sed -e 's/-(.*//'`" + echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/-(.*//'` exit ;; *:*VMS:*:*) UNAME_MACHINE=`(uname -p) 2>/dev/null` - case "$UNAME_MACHINE" in + case "${UNAME_MACHINE}" in A*) echo alpha-dec-vms ; exit ;; I*) echo ia64-dec-vms ; exit ;; V*) echo vax-dec-vms ; exit ;; @@ -1404,48 +1379,34 @@ echo i386-pc-xenix exit ;; i*86:skyos:*:*) - echo "$UNAME_MACHINE"-pc-skyos"`echo "$UNAME_RELEASE" | sed -e 's/ .*$//'`" + echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//' exit ;; i*86:rdos:*:*) - echo "$UNAME_MACHINE"-pc-rdos + echo ${UNAME_MACHINE}-pc-rdos exit ;; i*86:AROS:*:*) - echo "$UNAME_MACHINE"-pc-aros + echo ${UNAME_MACHINE}-pc-aros exit ;; x86_64:VMkernel:*:*) - echo "$UNAME_MACHINE"-unknown-esx - exit ;; - amd64:Isilon\ OneFS:*:*) - echo x86_64-unknown-onefs + echo ${UNAME_MACHINE}-unknown-esx exit ;; esac -echo "$0: unable to guess system type" >&2 - -case "$UNAME_MACHINE:$UNAME_SYSTEM" in - mips:Linux | mips64:Linux) - # If we got here on MIPS GNU/Linux, output extra information. - cat >&2 <<EOF - -NOTE: MIPS GNU/Linux systems require a C compiler to fully recognize -the system type. Please install a C compiler and try again. -EOF - ;; -esac - cat >&2 <<EOF +$0: unable to guess system type -This script (version $timestamp), has failed to recognize the -operating system you are using. If your script is old, overwrite *all* -copies of config.guess and config.sub with the latest versions from: +This script, last modified $timestamp, has failed to recognize +the operating system you are using. It is advised that you +download the most up to date version of the config scripts from - https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess + http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD and - https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub + http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub;hb=HEAD -If $0 has already been updated, send the following data and any -information you think might be pertinent to config-patches@gnu.org to -provide the necessary information to handle your system. +If the version you run ($0) is already up to date, please +send the following data and any information you think might be +pertinent to <config-patches@gnu.org> in order to provide the needed +information to handle your system. config.guess timestamp = $timestamp @@ -1464,16 +1425,16 @@ /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" +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-functions 'time-stamp) +# eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'"
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/config/config.sub -> _service:tar_scm:libunwind-1.7.2.tar.gz/config/config.sub
Changed
@@ -1,8 +1,8 @@ #! /bin/sh # Configuration validation subroutine script. -# Copyright 1992-2018 Free Software Foundation, Inc. +# Copyright 1992-2015 Free Software Foundation, Inc. -timestamp='2018-02-22' +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 @@ -15,7 +15,7 @@ # 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 <https://www.gnu.org/licenses/>. +# along with this program; if not, see <http://www.gnu.org/licenses/>. # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a @@ -33,7 +33,7 @@ # Otherwise, we print the canonical config type on stdout and succeed. # You can get the latest version of this script from: -# https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub +# 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 @@ -53,11 +53,12 @@ me=`echo "$0" | sed -e 's,.*/,,'` usage="\ -Usage: $0 OPTION CPU-MFR-OPSYS or ALIAS +Usage: $0 OPTION CPU-MFR-OPSYS + $0 OPTION ALIAS Canonicalize a configuration name. -Options: +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 @@ -67,7 +68,7 @@ version="\ GNU config.sub ($timestamp) -Copyright 1992-2018 Free Software Foundation, Inc. +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." @@ -94,7 +95,7 @@ *local*) # First pass through any local machine types. - echo "$1" + echo $1 exit ;; * ) @@ -112,24 +113,24 @@ # 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/'` +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* | cloudabi*-eabi* | \ + kopensolaris*-gnu* | \ storm-chaos* | os2-emx* | rtmk-nova*) os=-$maybe_os - basic_machine=`echo "$1" | sed 's/^\(.*\)-\(^-*-^-*\)$/\1/'` + 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/^\(.*\)-\(^-*-^-*\)$/\1/'`-unknown ;; *) - basic_machine=`echo "$1" | sed 's/-^-*$//'` - if "$basic_machine" != "$1" - then os=`echo "$1" | sed 's/.*-/-/'` + basic_machine=`echo $1 | sed 's/-^-*$//'` + if $basic_machine != $1 + then os=`echo $1 | sed 's/.*-/-/'` else os=; fi ;; esac @@ -178,44 +179,44 @@ ;; -sco6) os=-sco5v6 - basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco5) os=-sco3.2v5 - basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco4) os=-sco3.2v4 - basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + 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/'` + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco3.2v4-9*) # Don't forget version if it is 3.2v4 or newer. - basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + 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/'` + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco*) os=-sco3.2v2 - basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -udk*) - basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -isc) os=-isc2.2 - basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + 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/'` + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -lynx*178) os=-lynxos178 @@ -227,7 +228,10 @@ os=-lynxos ;; -ptx*) - basic_machine=`echo "$1" | sed -e 's/86-.*/86-sequent/'` + basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'` + ;; + -windowsnt*) + os=`echo $os | sed -e 's/windowsnt/winnt/'` ;; -psos*) os=-psos @@ -260,7 +264,7 @@ | fido | fr30 | frv | ft32 \ | h8300 | h8500 | hppa | hppa1.01 | hppa2.0 | hppa2.0nw | hppa64 \ | hexagon \ - | i370 | i860 | i960 | ia16 | ia64 \ + | i370 | i860 | i960 | ia64 \ | ip2k | iq2000 \ | k1om \ | le32 | le64 \ @@ -296,9 +300,8 @@ | nios | nios2 | nios2eb | nios2el \ | ns16k | ns32k \ | open8 | or1k | or1knd | or32 \ - | pdp10 | pj | pjl \ + | pdp10 | pdp11 | pj | pjl \ | powerpc | powerpc64 | powerpc64le | powerpcle \ - | pru \ | pyramid \ | riscv32 | riscv64 \ | rl78 | rx \ @@ -312,7 +315,7 @@ | ubicom32 \ | v850 | v850e | v850e1 | v850e2 | v850es | v850e2v3 \ | visium \ - | wasm32 \ + | we32k \ | x86 | xc16x | xstormy16 | xtensa \ | z8k | z80) basic_machine=$basic_machine-unknown @@ -333,7 +336,7 @@ basic_machine=$basic_machine-unknown os=-none ;; - m88110 | m680123460 | m683?2 | m68360 | m5200 | v70 | w65) + m88110 | m680123460 | m683?2 | m68360 | m5200 | v70 | w65 | z8k) ;; ms1) basic_machine=mt-unknown @@ -362,7 +365,7 @@ ;; # Object if more than one company name word. *-*-*) - echo Invalid configuration \`"$1"\': machine \`"$basic_machine"\' not recognized 1>&2 + echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 exit 1 ;; # Recognize the basic CPU types with company name. @@ -385,7 +388,7 @@ | h8300-* | h8500-* \ | hppa-* | hppa1.01-* | hppa2.0-* | hppa2.0nw-* | hppa64-* \ | hexagon-* \ - | i*86-* | i860-* | i960-* | ia16-* | ia64-* \ + | i*86-* | i860-* | i960-* | ia64-* \ | ip2k-* | iq2000-* \ | k1om-* \ | le32-* | le64-* \ @@ -426,7 +429,6 @@ | orion-* \ | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \ | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* \ - | pru-* \ | pyramid-* \ | riscv32-* | riscv64-* \ | rl78-* | romp-* | rs6000-* | rx-* \ @@ -443,7 +445,6 @@ | v850-* | v850e-* | v850e1-* | v850es-* | v850e2-* | v850e2v3-* \ | vax-* \ | visium-* \ - | wasm32-* \ | we32k-* \ | x86-* | x86_64-* | xc16x-* | xps100-* \ | xstormy16-* | xtensa*-* \ @@ -457,7 +458,7 @@ # 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-pc + basic_machine=i386-unknown os=-bsd ;; 3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc) @@ -491,7 +492,7 @@ basic_machine=x86_64-pc ;; amd64-*) - basic_machine=x86_64-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=x86_64-`echo $basic_machine | sed 's/^^-*-//'` ;; amdahl) basic_machine=580-amdahl @@ -520,7 +521,7 @@ basic_machine=i386-pc os=-aros ;; - asmjs) + asmjs) basic_machine=asmjs-unknown ;; aux) @@ -536,7 +537,7 @@ os=-linux ;; blackfin-*) - basic_machine=bfin-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=bfin-`echo $basic_machine | sed 's/^^-*-//'` os=-linux ;; bluegene*) @@ -544,13 +545,13 @@ os=-cnk ;; c54x-*) - basic_machine=tic54x-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=tic54x-`echo $basic_machine | sed 's/^^-*-//'` ;; c55x-*) - basic_machine=tic55x-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=tic55x-`echo $basic_machine | sed 's/^^-*-//'` ;; c6x-*) - basic_machine=tic6x-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=tic6x-`echo $basic_machine | sed 's/^^-*-//'` ;; c90) basic_machine=c90-cray @@ -639,18 +640,10 @@ basic_machine=rs6000-bull os=-bosx ;; - dpx2*) + dpx2* | dpx2*-bull) basic_machine=m68k-bull os=-sysv3 ;; - e500v12) - basic_machine=powerpc-unknown - os=$os"spe" - ;; - e500v12-*) - basic_machine=powerpc-`echo "$basic_machine" | sed 's/^^-*-//'` - os=$os"spe" - ;; ebmon29k) basic_machine=a29k-amd os=-ebmon @@ -740,6 +733,9 @@ hp9k80-90-9 | hp80-90-9) basic_machine=hppa1.0-hp ;; + hppa-next) + os=-nextstep3 + ;; hppaosf) basic_machine=hppa1.1-hp os=-osf @@ -752,26 +748,26 @@ basic_machine=i370-ibm ;; i*86v32) - basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'` + basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv32 ;; i*86v4*) - basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'` + basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv4 ;; i*86v) - basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'` + basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv ;; i*86sol2) - basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'` + basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-solaris2 ;; i386mach) basic_machine=i386-mach os=-mach ;; - vsta) + i386-vsta | vsta) basic_machine=i386-unknown os=-vsta ;; @@ -790,16 +786,19 @@ os=-sysv ;; leon-*|leon3-9-*) - basic_machine=sparc-`echo "$basic_machine" | sed 's/-.*//'` + basic_machine=sparc-`echo $basic_machine | sed 's/-.*//'` ;; m68knommu) basic_machine=m68k-unknown os=-linux ;; m68knommu-*) - basic_machine=m68k-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=m68k-`echo $basic_machine | sed 's/^^-*-//'` os=-linux ;; + m88k-omron*) + basic_machine=m88k-omron + ;; magnum | m3230) basic_machine=mips-mips os=-sysv @@ -831,10 +830,10 @@ os=-mint ;; mips3*-*) - basic_machine=`echo "$basic_machine" | sed -e 's/mips3/mips64/'` + basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'` ;; mips3*) - basic_machine=`echo "$basic_machine" | sed -e 's/mips3/mips64/'`-unknown + basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown ;; monitor) basic_machine=m68k-rom68k @@ -853,7 +852,7 @@ os=-msdos ;; ms1-*) - basic_machine=`echo "$basic_machine" | sed -e 's/ms1-/mt-/'` + basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'` ;; msys) basic_machine=i686-pc @@ -895,7 +894,7 @@ basic_machine=v70-nec os=-sysv ;; - next | m*-next) + next | m*-next ) basic_machine=m68k-next case $os in -nextstep* ) @@ -940,12 +939,6 @@ nsr-tandem) basic_machine=nsr-tandem ;; - nsv-tandem) - basic_machine=nsv-tandem - ;; - nsx-tandem) - basic_machine=nsx-tandem - ;; op50n-* | op60c-*) basic_machine=hppa1.1-oki os=-proelf @@ -978,7 +971,7 @@ os=-linux ;; parisc-*) - basic_machine=hppa-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=hppa-`echo $basic_machine | sed 's/^^-*-//'` os=-linux ;; pbd) @@ -994,7 +987,7 @@ basic_machine=i386-pc ;; pc98-*) - basic_machine=i386-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=i386-`echo $basic_machine | sed 's/^^-*-//'` ;; pentium | p5 | k5 | k6 | nexgen | viac3) basic_machine=i586-pc @@ -1009,16 +1002,16 @@ basic_machine=i786-pc ;; pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*) - basic_machine=i586-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=i586-`echo $basic_machine | sed 's/^^-*-//'` ;; pentiumpro-* | p6-* | 6x86-* | athlon-*) - basic_machine=i686-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=i686-`echo $basic_machine | sed 's/^^-*-//'` ;; pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*) - basic_machine=i686-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=i686-`echo $basic_machine | sed 's/^^-*-//'` ;; pentium4-*) - basic_machine=i786-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=i786-`echo $basic_machine | sed 's/^^-*-//'` ;; pn) basic_machine=pn-gould @@ -1028,23 +1021,23 @@ ppc | ppcbe) basic_machine=powerpc-unknown ;; ppc-* | ppcbe-*) - basic_machine=powerpc-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=powerpc-`echo $basic_machine | sed 's/^^-*-//'` ;; - ppcle | powerpclittle) + ppcle | powerpclittle | ppc-le | powerpc-little) basic_machine=powerpcle-unknown ;; ppcle-* | powerpclittle-*) - basic_machine=powerpcle-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=powerpcle-`echo $basic_machine | sed 's/^^-*-//'` ;; ppc64) basic_machine=powerpc64-unknown ;; - ppc64-*) basic_machine=powerpc64-`echo "$basic_machine" | sed 's/^^-*-//'` + ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^^-*-//'` ;; - ppc64le | powerpc64little) + ppc64le | powerpc64little | ppc64-le | powerpc64-little) basic_machine=powerpc64le-unknown ;; ppc64le-* | powerpc64little-*) - basic_machine=powerpc64le-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=powerpc64le-`echo $basic_machine | sed 's/^^-*-//'` ;; ps2) basic_machine=i386-ibm @@ -1098,10 +1091,17 @@ sequent) basic_machine=i386-sequent ;; + sh) + basic_machine=sh-hitachi + os=-hms + ;; sh5el) basic_machine=sh5le-unknown ;; - simso-wrs) + sh64) + basic_machine=sh64-unknown + ;; + sparclite-wrs | simso-wrs) basic_machine=sparclite-wrs os=-vxworks ;; @@ -1120,7 +1120,7 @@ os=-sysv4 ;; strongarm-* | thumb-*) - basic_machine=arm-`echo "$basic_machine" | sed 's/^^-*-//'` + basic_machine=arm-`echo $basic_machine | sed 's/^^-*-//'` ;; sun2) basic_machine=m68000-sun @@ -1242,9 +1242,6 @@ basic_machine=hppa1.1-winbond os=-proelf ;; - x64) - basic_machine=x86_64-pc - ;; xbox) basic_machine=i686-pc os=-mingw32 @@ -1253,12 +1250,20 @@ basic_machine=xps100-honeywell ;; xscale-* | xscaleebl-*) - basic_machine=`echo "$basic_machine" | sed 's/^xscale/arm/'` + 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 @@ -1287,6 +1292,10 @@ 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 ;; @@ -1296,6 +1305,9 @@ sh1234 | sh24a | sh24aeb | sh34eb | sh1234le | sh23ele) basic_machine=sh-unknown ;; + sparc | sparcv8 | sparcv9 | sparcv9b | sparcv9v) + basic_machine=sparc-sun + ;; cydra) basic_machine=cydra-cydrome ;; @@ -1315,7 +1327,7 @@ # Make sure to match an already-canonicalized machine name. ;; *) - echo Invalid configuration \`"$1"\': machine \`"$basic_machine"\' not recognized 1>&2 + echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 exit 1 ;; esac @@ -1323,10 +1335,10 @@ # Here we canonicalize certain aliases for manufacturers. case $basic_machine in *-digital*) - basic_machine=`echo "$basic_machine" | sed 's/digital.*/dec/'` + basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'` ;; *-commodore*) - basic_machine=`echo "$basic_machine" | sed 's/commodore.*/cbm/'` + basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'` ;; *) ;; @@ -1337,8 +1349,8 @@ if x"$os" != x"" then case $os in - # First match some system type aliases that might get confused - # with valid system types. + # 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 @@ -1349,19 +1361,18 @@ -solaris) os=-solaris2 ;; + -svr4*) + os=-sysv4 + ;; -unixware*) os=-sysv4.2uw ;; -gnu/linux*) os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'` ;; - # es1800 is here to avoid being matched by es* (a different OS) - -es1800*) - os=-ose - ;; - # Now accept the basic system types. + # First accept the basic system types. # The portable systems comes first. - # Each alternative MUST end in a * to match a version number. + # 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 | -sunos34*\ @@ -1371,26 +1382,24 @@ | -aos* | -aros* | -cloudabi* | -sortix* \ | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \ | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \ - | -hiux* | -knetbsd* | -mirbsd* | -netbsd* \ - | -bitrig* | -openbsd* | -solidbsd* | -libertybsd* \ + | -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* | -glidix* \ + | -chorusos* | -chorusrdb* | -cegcc* \ | -cygwin* | -msys* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ - | -midipix* | -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \ + | -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \ | -linux-newlib* | -linux-musl* | -linux-uclibc* \ | -uxpv* | -beos* | -mpeix* | -udk* | -moxiebox* \ - | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* \ + | -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* | -windiss* \ + | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \ | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \ - | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es* \ - | -onefs* | -tirtos* | -phoenix* | -fuchsia* | -redox* | -bme* \ - | -midnightbsd*) + | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es* | -tirtos*) # Remember, each alternative MUST END IN *, to match a version number. ;; -qnx*) @@ -1407,12 +1416,12 @@ -nto*) os=`echo $os | sed -e 's|nto|nto-qnx|'` ;; - -sim | -xray | -os68k* | -v88r* \ - | -windows* | -osx | -abug | -netware* | -os9* \ + -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|'` + os=`echo $os | sed -e 's|mac|macos|'` ;; -linux-dietlibc) os=-linux-dietlibc @@ -1421,10 +1430,10 @@ os=`echo $os | sed -e 's|linux|linux-gnu|'` ;; -sunos5*) - os=`echo "$os" | sed -e 's|sunos5|solaris2|'` + os=`echo $os | sed -e 's|sunos5|solaris2|'` ;; -sunos6*) - os=`echo "$os" | sed -e 's|sunos6|solaris3|'` + os=`echo $os | sed -e 's|sunos6|solaris3|'` ;; -opened*) os=-openedition @@ -1435,6 +1444,12 @@ -wince*) os=-wince ;; + -osfrose*) + os=-osfrose + ;; + -osf*) + os=-osf + ;; -utek*) os=-bsd ;; @@ -1459,7 +1474,7 @@ -nova*) os=-rtmk-nova ;; - -ns2) + -ns2 ) os=-nextstep2 ;; -nsk*) @@ -1481,7 +1496,7 @@ -oss*) os=-sysv3 ;; - -svr4*) + -svr4) os=-sysv4 ;; -svr3) @@ -1496,38 +1511,32 @@ -ose*) os=-ose ;; + -es1800*) + os=-ose + ;; + -xenix) + os=-xenix + ;; -*mint | -mint0-9* | -*MiNT | -MiNT0-9*) os=-mint ;; + -aros*) + os=-aros + ;; -zvmoe) os=-zvmoe ;; -dicos*) os=-dicos ;; - -pikeos*) - # Until real need of OS specific support for - # particular features comes up, bare metal - # configurations are quite functional. - case $basic_machine in - arm*) - os=-eabi - ;; - *) - os=-elf - ;; - esac - ;; -nacl*) ;; - -ios) - ;; -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 + echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2 exit 1 ;; esac @@ -1617,12 +1626,12 @@ sparc-* | *-sun) os=-sunos4.1.1 ;; - pru-*) - os=-elf - ;; *-be) os=-beos ;; + *-haiku) + os=-haiku + ;; *-ibm) os=-aix ;; @@ -1662,7 +1671,7 @@ m88k-omron*) os=-luna ;; - *-next) + *-next ) os=-nextstep ;; *-sequent) @@ -1677,6 +1686,9 @@ i370-*) os=-mvs ;; + *-next) + os=-nextstep3 + ;; *-gould) os=-sysv ;; @@ -1786,15 +1798,15 @@ vendor=stratus ;; esac - basic_machine=`echo "$basic_machine" | sed "s/unknown/$vendor/"` + basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"` ;; esac -echo "$basic_machine$os" +echo $basic_machine$os exit # Local variables: -# eval: (add-hook 'write-file-functions 'time-stamp) +# eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'"
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/config/depcomp -> _service:tar_scm:libunwind-1.7.2.tar.gz/config/depcomp
Changed
@@ -1,9 +1,9 @@ #! /bin/sh # depcomp - compile a program generating dependencies as side-effects -scriptversion=2018-03-07.03; # UTC +scriptversion=2013-05-30.07; # UTC -# Copyright (C) 1999-2021 Free Software Foundation, Inc. +# 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 @@ -16,7 +16,7 @@ # 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 <https://www.gnu.org/licenses/>. +# along with this program. If not, see <http://www.gnu.org/licenses/>. # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a @@ -783,9 +783,9 @@ # Local Variables: # mode: shell-script # sh-indentation: 2 -# eval: (add-hook 'before-save-hook 'time-stamp) +# eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" -# time-stamp-time-zone: "UTC0" +# time-stamp-time-zone: "UTC" # time-stamp-end: "; # UTC" # End:
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/config/install-sh -> _service:tar_scm:libunwind-1.7.2.tar.gz/config/install-sh
Changed
@@ -1,7 +1,7 @@ #!/bin/sh # install - install a program, script, or datafile -scriptversion=2020-11-14.01; # UTC +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 @@ -69,11 +69,6 @@ # Desired mode of installed file. mode=0755 -# Create dirs (including intermediate dirs) using mode 755. -# This is like GNU 'install' as of coreutils 8.32 (2020). -mkdir_umask=22 - -backupsuffix= chgrpcmd= chmodcmd=$chmodprog chowncmd= @@ -104,28 +99,18 @@ --version display version info and exit. -c (ignored) - -C install only if different (preserve data modification time) + -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. - -p pass -p to $cpprog. -s $stripprog installed files. - -S SUFFIX attempt to back up existing files, with suffix SUFFIX. -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 - -By default, rm is invoked with -f; when overridden with RMPROG, -it's up to you to specify -f if you want it. - -If -S is not specified, no backups are attempted. - -Email bug reports to bug-automake@gnu.org. -Automake home page: https://www.gnu.org/software/automake/ " while test $# -ne 0; do @@ -152,13 +137,8 @@ -o) chowncmd="$chownprog $2" shift;; - -p) cpprog="$cpprog -p";; - -s) stripcmd=$stripprog;; - -S) backupsuffix="$2" - shift;; - -t) is_target_a_directory=always dst_arg=$2 @@ -275,10 +255,6 @@ dstdir=$dst test -d "$dstdir" dstdir_status=$? - # Don't chown directories that already exist. - if test $dstdir_status = 0; then - chowncmd="" - fi else # Waiting for this to be detected by the "$cpprog $src $dsttmp" command @@ -295,18 +271,15 @@ fi dst=$dst_arg - # If destination is a directory, append the input filename. + # 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 - dstbase=`basename "$src"` - case $dst in - */) dst=$dst$dstbase;; - *) dst=$dst/$dstbase;; - esac + dst=$dstdir/`basename "$src"` dstdir_status=0 else dstdir=`dirname "$dst"` @@ -315,16 +288,27 @@ fi fi - case $dstdir in - */) dstdirslash=$dstdir;; - *) dstdirslash=$dstdir/;; - esac - 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. + *23672367) mkdir_umask=$umask;; + .*00202 | .0202 | .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 @@ -334,49 +318,50 @@ fi posix_mkdir=false - # The $RANDOM variable is not portable (e.g., dash). Use it - # here however when possible just to lower collision chance. - tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$ - - trap ' - ret=$? - rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null - exit $ret - ' 0 - - # Because "mkdir -p" follows existing symlinks and we likely work - # directly in world-writeable /tmp, make sure that the '$tmpdir' - # directory is successfully created first before we actually test - # 'mkdir -p'. - 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;; + case $umask in + *1235670-70-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 @@ -387,7 +372,7 @@ then : else - # mkdir does not conform to POSIX, + # 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. @@ -416,7 +401,7 @@ prefixes= else if $posix_mkdir; then - (umask $mkdir_umask && + (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 @@ -449,25 +434,14 @@ else # Make a couple of temp file names in the proper directory. - dsttmp=${dstdirslash}_inst.$$_ - rmtmp=${dstdirslash}_rm.$$_ + 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 && - { test -z "$stripcmd" || { - # Create $dsttmp read-write so that cp doesn't create it read-only, - # which would cause strip to fail. - if test -z "$doit"; then - : >"$dsttmp" # No need to fork-exec 'touch'. - else - $doit touch "$dsttmp" - fi - } - } && - $doit_exec $cpprog "$src" "$dsttmp") && + (umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") && # and set any options; do chmod last to preserve setuid bits. # @@ -493,13 +467,6 @@ then rm -f "$dsttmp" else - # If $backupsuffix is set, and the file being installed - # already exists, attempt a backup. Don't worry if it fails, - # e.g., if mv doesn't support -f. - if test -n "$backupsuffix" && test -f "$dst"; then - $doit $mvcmd -f "$dst" "$dst$backupsuffix" 2>/dev/null - fi - # Rename the file to the real destination. $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null || @@ -514,9 +481,9 @@ # file should still install successfully. { test ! -f "$dst" || - $doit $rmcmd "$dst" 2>/dev/null || + $doit $rmcmd -f "$dst" 2>/dev/null || { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null && - { $doit $rmcmd "$rmtmp" 2>/dev/null; :; } + { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; } } || { echo "$0: cannot unlink or rename $dst" >&2 (exit 1); exit 1 @@ -533,9 +500,9 @@ done # Local variables: -# eval: (add-hook 'before-save-hook 'time-stamp) +# eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" -# time-stamp-time-zone: "UTC0" +# time-stamp-time-zone: "UTC" # time-stamp-end: "; # UTC" # End:
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/config/ltmain.sh -> _service:tar_scm:libunwind-1.7.2.tar.gz/config/ltmain.sh
Changed
@@ -31,7 +31,7 @@ PROGRAM=libtool PACKAGE=libtool -VERSION="2.4.6 Debian-2.4.6-15" +VERSION="2.4.6 Debian-2.4.6-0.1" package_revision=2.4.6 @@ -387,7 +387,7 @@ # putting '$debug_cmd' at the start of all your functions, you can get # bash to show function call trace with: # -# debug_cmd='echo "${FUNCNAME0} $*" >&2' bash your-script-name +# debug_cmd='eval echo "${FUNCNAME0} $*" >&2' bash your-script-name debug_cmd=${debug_cmd-":"} exit_cmd=: @@ -1370,7 +1370,7 @@ #! /bin/sh # Set a version string for this script. -scriptversion=2015-10-07.11; # UTC +scriptversion=2014-01-07.03; # UTC # A portable, pluggable option parser for Bourne shell. # Written by Gary V. Vaughan, 2010 @@ -1530,8 +1530,6 @@ { $debug_cmd - _G_rc_run_hooks=false - case " $hookable_fns " in *" $1 "*) ;; *) func_fatal_error "'$1' does not support hook funcions.n" ;; @@ -1540,16 +1538,16 @@ eval _G_hook_fns=\$$1_hooks; shift for _G_hook in $_G_hook_fns; do - if eval $_G_hook '"$@"'; then - # store returned options list back into positional - # parameters for next 'cmd' execution. - eval _G_hook_result=\$${_G_hook}_result - eval set dummy "$_G_hook_result"; shift - _G_rc_run_hooks=: - fi + eval $_G_hook '"$@"' + + # store returned options list back into positional + # parameters for next 'cmd' execution. + eval _G_hook_result=\$${_G_hook}_result + eval set dummy "$_G_hook_result"; shift done - $_G_rc_run_hooks && func_run_hooks_result=$_G_hook_result + func_quote_for_eval ${1+"$@"} + func_run_hooks_result=$func_quote_for_eval_result } @@ -1559,16 +1557,10 @@ ## --------------- ## # In order to add your own option parsing hooks, you must accept the -# full positional parameter list in your hook function, you may remove/edit -# any options that you action, and then pass back the remaining unprocessed +# full positional parameter list in your hook function, remove any +# options that you action, and then pass back the remaining unprocessed # options in '<hooked_function_name>_result', escaped suitably for -# 'eval'. In this case you also must return $EXIT_SUCCESS to let the -# hook's caller know that it should pay attention to -# '<hooked_function_name>_result'. Returning $EXIT_FAILURE signalizes that -# arguments are left untouched by the hook and therefore caller will ignore the -# result variable. -# -# Like this: +# 'eval'. Like this: # # my_options_prep () # { @@ -1578,11 +1570,9 @@ # usage_message=$usage_message' # -s, --silent don'\''t print informational messages # ' -# # No change in '$@' (ignored completely by this hook). There is -# # no need to do the equivalent (but slower) action: -# # func_quote_for_eval ${1+"$@"} -# # my_options_prep_result=$func_quote_for_eval_result -# false +# +# func_quote_for_eval ${1+"$@"} +# my_options_prep_result=$func_quote_for_eval_result # } # func_add_hook func_options_prep my_options_prep # @@ -1591,37 +1581,25 @@ # { # $debug_cmd # -# args_changed=false -# # # Note that for efficiency, we parse as many options as we can # # recognise in a loop before passing the remainder back to the # # caller on the first unrecognised argument we encounter. # while test $# -gt 0; do # opt=$1; shift # case $opt in -# --silent|-s) opt_silent=: -# args_changed=: -# ;; +# --silent|-s) opt_silent=: ;; # # Separate non-argument short options: # -s*) func_split_short_opt "$_G_opt" # set dummy "$func_split_short_opt_name" \ # "-$func_split_short_opt_arg" ${1+"$@"} # shift -# args_changed=: # ;; -# *) # Make sure the first unrecognised option "$_G_opt" -# # is added back to "$@", we could need that later -# # if $args_changed is true. -# set dummy "$_G_opt" ${1+"$@"}; shift; break ;; +# *) set dummy "$_G_opt" "$*"; shift; break ;; # esac # done # -# if $args_changed; then -# func_quote_for_eval ${1+"$@"} -# my_silent_option_result=$func_quote_for_eval_result -# fi -# -# $args_changed +# func_quote_for_eval ${1+"$@"} +# my_silent_option_result=$func_quote_for_eval_result # } # func_add_hook func_parse_options my_silent_option # @@ -1633,32 +1611,16 @@ # $opt_silent && $opt_verbose && func_fatal_help "\ # '--silent' and '--verbose' options are mutually exclusive." # -# false +# func_quote_for_eval ${1+"$@"} +# my_option_validation_result=$func_quote_for_eval_result # } # func_add_hook func_validate_options my_option_validation # -# You'll also need to manually amend $usage_message to reflect the extra +# You'll alse need to manually amend $usage_message to reflect the extra # options you parse. It's preferable to append if you can, so that # multiple option parsing hooks can be added safely. -# func_options_finish ARG... -# ---------------------------- -# Finishing the option parse loop (call 'func_options' hooks ATM). -func_options_finish () -{ - $debug_cmd - - _G_func_options_finish_exit=false - if func_run_hooks func_options ${1+"$@"}; then - func_options_finish_result=$func_run_hooks_result - _G_func_options_finish_exit=: - fi - - $_G_func_options_finish_exit -} - - # func_options ARG... # --------------------- # All the functions called inside func_options are hookable. See the @@ -1668,28 +1630,17 @@ { $debug_cmd - _G_rc_options=false + func_options_prep ${1+"$@"} + eval func_parse_options \ + ${func_options_prep_result+"$func_options_prep_result"} + eval func_validate_options \ + ${func_parse_options_result+"$func_parse_options_result"} - for my_func in options_prep parse_options validate_options options_finish - do - if eval func_$my_func '${1+"$@"}'; then - eval _G_res_var='$'"func_${my_func}_result" - eval set dummy "$_G_res_var" ; shift - _G_rc_options=: - fi - done + eval func_run_hooks func_options \ + ${func_validate_options_result+"$func_validate_options_result"} - # Save modified positional parameters for caller. As a top-level - # options-parser function we always need to set the 'func_options_result' - # variable (regardless the $_G_rc_options value). - if $_G_rc_options; then - func_options_result=$_G_res_var - else - func_quote_for_eval ${1+"$@"} - func_options_result=$func_quote_for_eval_result - fi - - $_G_rc_options + # save modified positional parameters for caller + func_options_result=$func_run_hooks_result } @@ -1698,9 +1649,9 @@ # All initialisations required before starting the option parse loop. # Note that when calling hook functions, we pass through the list of # positional parameters. If a hook function modifies that list, and -# needs to propagate that back to rest of this script, then the complete +# needs to propogate that back to rest of this script, then the complete # modified list must be put in 'func_run_hooks_result' before -# returning $EXIT_SUCCESS (otherwise $EXIT_FAILURE is returned). +# returning. func_hookable func_options_prep func_options_prep () { @@ -1710,14 +1661,10 @@ opt_verbose=false opt_warning_types= - _G_rc_options_prep=false - if func_run_hooks func_options_prep ${1+"$@"}; then - _G_rc_options_prep=: - # save modified positional parameters for caller - func_options_prep_result=$func_run_hooks_result - fi + func_run_hooks func_options_prep ${1+"$@"} - $_G_rc_options_prep + # save modified positional parameters for caller + func_options_prep_result=$func_run_hooks_result } @@ -1731,20 +1678,18 @@ func_parse_options_result= - _G_rc_parse_options=false # this just eases exit handling while test $# -gt 0; do # Defer to hook functions for initial option parsing, so they # get priority in the event of reusing an option name. - if func_run_hooks func_parse_options ${1+"$@"}; then - eval set dummy "$func_run_hooks_result"; shift - _G_rc_parse_options=: - fi + func_run_hooks func_parse_options ${1+"$@"} + + # Adjust func_parse_options positional parameters to match + eval set dummy "$func_run_hooks_result"; shift # Break out of the loop if we already parsed every option. test $# -gt 0 || break - _G_match_parse_options=: _G_opt=$1 shift case $_G_opt in @@ -1759,10 +1704,7 @@ ;; --warnings|--warning|-W) - if test $# = 0 && func_missing_arg $_G_opt; then - _G_rc_parse_options=: - break - fi + test $# = 0 && func_missing_arg $_G_opt && break case " $warning_categories $1" in *" $1 "*) # trailing space prevents matching last $1 above @@ -1815,25 +1757,15 @@ shift ;; - --) _G_rc_parse_options=: ; break ;; + --) break ;; -*) func_fatal_help "unrecognised option: '$_G_opt'" ;; - *) set dummy "$_G_opt" ${1+"$@"}; shift - _G_match_parse_options=false - break - ;; + *) set dummy "$_G_opt" ${1+"$@"}; shift; break ;; esac - - $_G_match_parse_options && _G_rc_parse_options=: done - - if $_G_rc_parse_options; then - # save modified positional parameters for caller - func_quote_for_eval ${1+"$@"} - func_parse_options_result=$func_quote_for_eval_result - fi - - $_G_rc_parse_options + # save modified positional parameters for caller + func_quote_for_eval ${1+"$@"} + func_parse_options_result=$func_quote_for_eval_result } @@ -1846,21 +1778,16 @@ { $debug_cmd - _G_rc_validate_options=false - # Display all warnings if -W was not given. test -n "$opt_warning_types" || opt_warning_types=" $warning_categories" - if func_run_hooks func_validate_options ${1+"$@"}; then - # save modified positional parameters for caller - func_validate_options_result=$func_run_hooks_result - _G_rc_validate_options=: - fi + func_run_hooks func_validate_options ${1+"$@"} # Bail if the options were screwed! $exit_cmd $EXIT_FAILURE - $_G_rc_validate_options + # save modified positional parameters for caller + func_validate_options_result=$func_run_hooks_result } @@ -2141,7 +2068,7 @@ compiler: $LTCC compiler flags: $LTCFLAGS linker: $LD (gnu? $with_gnu_ld) - version: $progname $scriptversion Debian-2.4.6-15 + version: $progname (GNU libtool) 2.4.6 automake: `($AUTOMAKE --version) 2>/dev/null |$SED 1q` autoconf: `($AUTOCONF --version) 2>/dev/null |$SED 1q` @@ -2343,8 +2270,6 @@ nonopt= preserve_args= - _G_rc_lt_options_prep=: - # Shorthand for --mode=foo, only valid as the first argument case $1 in clean|clea|cle|cl) @@ -2368,18 +2293,11 @@ uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u) shift; set dummy --mode uninstall ${1+"$@"}; shift ;; - *) - _G_rc_lt_options_prep=false - ;; esac - if $_G_rc_lt_options_prep; then - # Pass back the list of options. - func_quote_for_eval ${1+"$@"} - libtool_options_prep_result=$func_quote_for_eval_result - fi - - $_G_rc_lt_options_prep + # Pass back the list of options. + func_quote_for_eval ${1+"$@"} + libtool_options_prep_result=$func_quote_for_eval_result } func_add_hook func_options_prep libtool_options_prep @@ -2391,12 +2309,9 @@ { $debug_cmd - _G_rc_lt_parse_options=false - # Perform our own loop to consume as many options as possible in # each iteration. while test $# -gt 0; do - _G_match_lt_parse_options=: _G_opt=$1 shift case $_G_opt in @@ -2471,22 +2386,15 @@ func_append preserve_args " $_G_opt" ;; - # An option not handled by this hook function: - *) set dummy "$_G_opt" ${1+"$@"} ; shift - _G_match_lt_parse_options=false - break - ;; + # An option not handled by this hook function: + *) set dummy "$_G_opt" ${1+"$@"}; shift; break ;; esac - $_G_match_lt_parse_options && _G_rc_lt_parse_options=: done - if $_G_rc_lt_parse_options; then - # save modified positional parameters for caller - func_quote_for_eval ${1+"$@"} - libtool_parse_options_result=$func_quote_for_eval_result - fi - $_G_rc_lt_parse_options + # save modified positional parameters for caller + func_quote_for_eval ${1+"$@"} + libtool_parse_options_result=$func_quote_for_eval_result } func_add_hook func_parse_options libtool_parse_options @@ -7367,13 +7275,10 @@ # -specs=* GCC specs files # -stdlib=* select c++ std lib with clang # -fsanitize=* Clang/GCC memory and address sanitizer - # -fuse-ld=* Linker select flags for GCC - # -static-* direct GCC to link specific libraries statically - # -fcilkplus Cilk Plus language extension features for C/C++ -64|-mips0-9|-r0-90-9*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \ -t45*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \ -O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*| \ - -specs=*|-fsanitize=*|-fuse-ld=*|-static-*|-fcilkplus) + -specs=*|-fsanitize=*) func_quote_for_eval "$arg" arg=$func_quote_for_eval_result func_append compile_command " $arg"
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/config/missing -> _service:tar_scm:libunwind-1.7.2.tar.gz/config/missing
Changed
@@ -1,9 +1,9 @@ #! /bin/sh # Common wrapper for a few potentially missing GNU programs. -scriptversion=2018-03-07.03; # UTC +scriptversion=2013-10-28.13; # UTC -# Copyright (C) 1996-2021 Free Software Foundation, Inc. +# Copyright (C) 1996-2014 Free Software Foundation, Inc. # Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996. # This program is free software; you can redistribute it and/or modify @@ -17,7 +17,7 @@ # 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 <https://www.gnu.org/licenses/>. +# along with this program. If not, see <http://www.gnu.org/licenses/>. # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a @@ -101,9 +101,9 @@ exit $st fi -perl_URL=https://www.perl.org/ -flex_URL=https://github.com/westes/flex -gnu_software_URL=https://www.gnu.org/software +perl_URL=http://www.perl.org/ +flex_URL=http://flex.sourceforge.net/ +gnu_software_URL=http://www.gnu.org/software program_details () { @@ -207,9 +207,9 @@ exit $st # Local variables: -# eval: (add-hook 'before-save-hook 'time-stamp) +# eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" -# time-stamp-time-zone: "UTC0" +# time-stamp-time-zone: "UTC" # time-stamp-end: "; # UTC" # End:
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/config/test-driver -> _service:tar_scm:libunwind-1.7.2.tar.gz/config/test-driver
Changed
@@ -1,9 +1,9 @@ #! /bin/sh # test-driver - basic testsuite driver script. -scriptversion=2018-03-07.03; # UTC +scriptversion=2013-07-13.22; # UTC -# Copyright (C) 2011-2021 Free Software Foundation, Inc. +# 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 @@ -16,7 +16,7 @@ # 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 <https://www.gnu.org/licenses/>. +# along with this program. If not, see <http://www.gnu.org/licenses/>. # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a @@ -42,13 +42,11 @@ { cat <<END Usage: - test-driver --test-name NAME --log-file PATH --trs-file PATH - --expect-failure {yes|no} --color-tests {yes|no} - --enable-hard-errors {yes|no} -- + test-driver --test-name=NAME --log-file=PATH --trs-file=PATH + --expect-failure={yes|no} --color-tests={yes|no} + --enable-hard-errors={yes|no} -- TEST-SCRIPT TEST-SCRIPT-ARGUMENTS - The '--test-name', '--log-file' and '--trs-file' options are mandatory. -See the GNU Automake documentation for information. END } @@ -105,11 +103,8 @@ trap "st=141; $do_exit" 13 trap "st=143; $do_exit" 15 -# Test script is run here. We create the file first, then append to it, -# to ameliorate tests themselves also writing to the log file. Our tests -# don't, but others can (automake bug#35762). -: >"$log_file" -"$@" >>"$log_file" 2>&1 +# Test script is run here. +"$@" >$log_file 2>&1 estatus=$? if test $enable_hard_errors = no && test $estatus -eq 99; then @@ -131,7 +126,7 @@ # 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" +echo "$res $test_name (exit status: $estatus)" >>$log_file # Report outcome to console. echo "${col}${res}${std}: $test_name" @@ -145,9 +140,9 @@ # Local Variables: # mode: shell-script # sh-indentation: 2 -# eval: (add-hook 'before-save-hook 'time-stamp) +# eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" -# time-stamp-time-zone: "UTC0" +# time-stamp-time-zone: "UTC" # time-stamp-end: "; # UTC" # End:
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/configure -> _service:tar_scm:libunwind-1.7.2.tar.gz/configure
Changed
@@ -1,6 +1,6 @@ #! /bin/sh # Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.69 for libunwind 1.6.2. +# Generated by GNU Autoconf 2.69 for libunwind 1.7.2. # # Report bugs to <libunwind-devel@nongnu.org>. # @@ -590,8 +590,8 @@ # Identity of this package. PACKAGE_NAME='libunwind' PACKAGE_TARNAME='libunwind' -PACKAGE_VERSION='1.6.2' -PACKAGE_STRING='libunwind 1.6.2' +PACKAGE_VERSION='1.7.2' +PACKAGE_STRING='libunwind 1.7.2' PACKAGE_BUGREPORT='libunwind-devel@nongnu.org' PACKAGE_URL='' @@ -657,6 +657,7 @@ ARCH arch build_arch +UNW_TESTDRIVER HAVE_ZLIB_FALSE HAVE_ZLIB_TRUE LIBZ @@ -683,6 +684,8 @@ OS_HPUX_TRUE OS_LINUX_FALSE OS_LINUX_TRUE +ARCH_LOONGARCH64_FALSE +ARCH_LOONGARCH64_TRUE ARCH_RISCV_FALSE ARCH_RISCV_TRUE ARCH_S390X_FALSE @@ -765,6 +768,7 @@ AMDEPBACKSLASH AMDEP_FALSE AMDEP_TRUE +am__quote am__include DEPDIR OBJEXT @@ -781,9 +785,6 @@ AM_DEFAULT_VERBOSITY AM_DEFAULT_V AM_V -CSCOPE -ETAGS -CTAGS am__untar am__tar AMTAR @@ -857,8 +858,7 @@ PACKAGE_TARNAME PACKAGE_NAME PATH_SEPARATOR -SHELL -am__quote' +SHELL' ac_subst_files='' ac_user_opts=' enable_option_checking @@ -889,6 +889,7 @@ enable_minidebuginfo enable_zlibdebuginfo enable_per_thread_cache +with_testdriver ' ac_precious_vars='build_alias host_alias @@ -1456,7 +1457,7 @@ # 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 libunwind 1.6.2 to adapt to many kinds of systems. +\`configure' configures libunwind 1.7.2 to adapt to many kinds of systems. Usage: $0 OPTION... VAR=VALUE... @@ -1528,7 +1529,7 @@ if test -n "$ac_init_help"; then case $ac_init_help in - short | recursive ) echo "Configuration of libunwind 1.6.2:";; + short | recursive ) echo "Configuration of libunwind 1.7.2:";; esac cat <<\_ACEOF @@ -1569,8 +1570,7 @@ --enable-zlibdebuginfo Enables support for ZLIB-compressed symbol tables --enable-per-thread-cache build with support for UNW_CACHE_PER_THREAD (which - imposes a hight TLS memory usage) (default: - disabled) + imposes a high TLS memory usage) (default: disabled) Optional Packages: --with-PACKAGE=ARG use PACKAGE ARG=yes @@ -1583,6 +1583,8 @@ --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-testdriver use designated test driver instead of default + LOG_DRIVER Some influential environment variables: CC C compiler command @@ -1667,7 +1669,7 @@ test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF -libunwind configure 1.6.2 +libunwind configure 1.7.2 generated by GNU Autoconf 2.69 Copyright (C) 2012 Free Software Foundation, Inc. @@ -2497,7 +2499,7 @@ This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. -It was created by libunwind $as_me 1.6.2, which was +It was created by libunwind $as_me 1.7.2, which was generated by GNU Autoconf 2.69. Invocation command line was $ $0 $@ @@ -2875,6 +2877,7 @@ ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. + # 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 @@ -2985,7 +2988,7 @@ test "$program_prefix$program_suffix$program_transform_name" = \ NONENONEs,x,x, && program_prefix=${target_alias}- -am__api_version='1.16' +am__api_version='1.15' # Find a good install program. We prefer a C program (faster), # so one script is as good as another. But avoid the broken or @@ -3161,7 +3164,12 @@ am_aux_dir=`cd "$ac_aux_dir" && pwd` if test x"${MISSING+set}" != xset; then - MISSING="\${SHELL} '$am_aux_dir/missing'" + 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 @@ -3466,7 +3474,7 @@ # Define the identity of the package. PACKAGE='libunwind' - VERSION='1.6.2' + VERSION='1.7.2' cat >>confdefs.h <<_ACEOF @@ -3496,8 +3504,8 @@ # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: -# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html> -# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html> +# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html> +# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html> mkdir_p='$(MKDIR_P)' # We need awk for the "check" target (and possibly the TAP driver). The @@ -3516,20 +3524,6 @@ -# Variables for tags utilities; see am/tags.am -if test -z "$CTAGS"; then - CTAGS=ctags -fi - -if test -z "$ETAGS"; then - ETAGS=etags -fi - -if test -z "$CSCOPE"; then - CSCOPE=cscope -fi - - # 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 @@ -3562,7 +3556,7 @@ 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: <https://www.gnu.org/software/coreutils/>. +that behaves properly: <http://www.gnu.org/software/coreutils/>. If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM @@ -3573,6 +3567,45 @@ fi fi +# 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=0;; +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='\' + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to enable maintainer-specific portions of Makefiles" >&5 $as_echo_n "checking whether to enable maintainer-specific portions of Makefiles... " >&6; } @@ -4450,45 +4483,45 @@ ac_config_commands="$ac_config_commands depfiles" -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} supports the include directive" >&5 -$as_echo_n "checking whether ${MAKE-make} supports the include directive... " >&6; } -cat > confinc.mk << 'END' + +am_make=${MAKE-make} +cat > confinc << 'END' am__doit: - @echo this is the am__doit target >confinc.out + @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= -# BSD make does it like this. -echo '.include "confinc.mk" # ignored' > confmf.BSD -# Other make implementations (GNU, Solaris 10, AIX) do it like this. -echo 'include confinc.mk # ignored' > confmf.GNU -_am_result=no -for s in GNU BSD; do - { echo "$as_me:$LINENO: ${MAKE-make} -f confmf.$s && cat confinc.out" >&5 - (${MAKE-make} -f confmf.$s && cat confinc.out) >&5 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } - case $?:`cat confinc.out 2>/dev/null` in #( - '0:this is the am__doit target') : - case $s in #( - BSD) : - am__include='.include' am__quote='"' ;; #( - *) : - am__include='include' am__quote='' ;; -esac ;; #( - *) : +_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 - if test "$am__include" != "#"; then - _am_result="yes ($s style)" - break - fi -done -rm -f confinc.* confmf.* -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: ${_am_result}" >&5 -$as_echo "${_am_result}" >&6; } + 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 : @@ -6827,7 +6860,7 @@ fi : ${AR=ar} -: ${AR_FLAGS=cr} +: ${AR_FLAGS=cru} @@ -7328,8 +7361,11 @@ test $ac_status = 0; }; then # Now try to grab the symbols. nlist=conftest.nm - $ECHO "$as_me:$LINENO: $NM conftest.$ac_objext | $lt_cv_sys_global_symbol_pipe > $nlist" >&5 - if eval "$NM" conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist 2>&5 && test -s "$nlist"; then + 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" @@ -8548,8 +8584,8 @@ _LT_EOF echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&5 $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&5 - echo "$AR cr libconftest.a conftest.o" >&5 - $AR cr libconftest.a conftest.o 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 @@ -8581,11 +8617,11 @@ # 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,*-darwin912*) + 10.0,*86*-darwin8*|10.0,*-darwin91*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; 10.012,.*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; - 10.*|11.*) + 10.*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; esac ;; @@ -9440,6 +9476,10 @@ $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= @@ -9685,12 +9725,6 @@ lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-static' ;; - # flang / f18. f95 an alias for gfortran or flang on Debian - flang* | f18* | f95*) - lt_prog_compiler_wl='-Wl,' - lt_prog_compiler_pic='-fPIC' - lt_prog_compiler_static='-static' - ;; # icc used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. icc* | ifort*) @@ -13633,7 +13667,7 @@ # 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"' + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else GXX=no @@ -14125,7 +14159,7 @@ # 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"' + 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 yes = "$GXX"; then @@ -14190,7 +14224,7 @@ # 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"' + 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 yes = "$GXX"; then @@ -14529,7 +14563,7 @@ # 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"' + 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 @@ -14613,7 +14647,7 @@ # 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"' + 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. @@ -14624,7 +14658,7 @@ # 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"' + 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' @@ -16924,10 +16958,10 @@ fi -for ac_header in asm/ptrace_offsets.h asm/ptrace.h endian.h sys/endian.h sys/param.h \ - execinfo.h ia64intrin.h sys/uc_access.h unistd.h signal.h sys/types.h \ - sys/procfs.h sys/ptrace.h sys/syscall.h byteswap.h elf.h sys/elf.h \ - link.h sys/link.h +for ac_header in asm/ptrace_offsets.h asm/ptrace.h asm/vsyscall.h endian.h sys/endian.h \ + sys/param.h execinfo.h ia64intrin.h sys/uc_access.h unistd.h signal.h \ + sys/types.h sys/procfs.h sys/ptrace.h sys/syscall.h byteswap.h elf.h \ + sys/elf.h link.h sys/link.h do : as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default" @@ -17150,6 +17184,34 @@ fi +ac_fn_c_check_type "$LINENO" "procfs_status" "ac_cv_type_procfs_status" "$ac_includes_default +#if HAVE_SYS_PROCFS_H +# include <sys/procfs.h> +#endif + +" +if test "x$ac_cv_type_procfs_status" = xyes; then : + +cat >>confdefs.h <<_ACEOF +#define HAVE_PROCFS_STATUS 1 +_ACEOF + + +fi +ac_fn_c_check_type "$LINENO" "elf_fpregset_t" "ac_cv_type_elf_fpregset_t" "$ac_includes_default +#if HAVE_SYS_PROCFS_H +# include <sys/procfs.h> +#endif + +" +if test "x$ac_cv_type_elf_fpregset_t" = xyes; then : + +cat >>confdefs.h <<_ACEOF +#define HAVE_ELF_FPREGSET_T 1 +_ACEOF + + +fi ac_fn_c_check_decl "$LINENO" "PTRACE_POKEUSER" "ac_cv_have_decl_PTRACE_POKEUSER" "$ac_includes_default @@ -17379,7 +17441,7 @@ for ac_func in dl_iterate_phdr dl_phdr_removals_counter dlmodinfo getunwind \ - ttrace mincore pipe2 + ttrace mincore pipe2 sigaltstack do : as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh` ac_fn_c_check_func "$LINENO" "$ac_func" "$as_ac_var" @@ -17457,6 +17519,8 @@ build_arch=tilegx ;; #( riscv*) : build_arch=riscv ;; #( + loongarch64*) : + build_arch=loongarch64 ;; #( *) : build_arch=$build_cpu ;; esac @@ -17483,6 +17547,8 @@ host_arch=tilegx ;; #( riscv*) : host_arch=riscv ;; #( + loongarch64*) : + host_arch=loongarch64 ;; #( *) : host_arch=$host_cpu ;; esac @@ -17509,6 +17575,8 @@ target_arch=tilegx ;; #( riscv*) : target_arch=riscv ;; #( + loongarch64*) : + target_arch=loongarch64 ;; #( *) : target_arch=$target_cpu ;; esac @@ -17535,7 +17603,7 @@ enableval=$enable_coredump; else case $host_arch in #( - aarch64*|arm*|mips*|sh*|x86*|tile*|riscv*) : + aarch64*|arm*|mips*|sh*|x86*|tile*|riscv*|loongarch64) : enable_coredump=yes ;; #( *) : enable_coredump=no ;; @@ -17794,6 +17862,14 @@ ARCH_RISCV_FALSE= fi + if test x$target_arch = xloongarch64; then + ARCH_LOONGARCH64_TRUE= + ARCH_LOONGARCH64_FALSE='#' +else + ARCH_LOONGARCH64_TRUE='#' + ARCH_LOONGARCH64_FALSE= +fi + if expr x$target_os : xlinux >/dev/null; then OS_LINUX_TRUE= OS_LINUX_FALSE='#' @@ -17842,7 +17918,7 @@ $as_echo "32" >&6; };; (aarch64|ia64|ppc64|x86_64|s390x|tilegx) use_elf64=yes; { $as_echo "$as_me:${as_lineno-$LINENO}: result: 64" >&5 $as_echo "64" >&6; };; -(mips|riscv) use_elfxx=yes; { $as_echo "$as_me:${as_lineno-$LINENO}: result: xx" >&5 +(mips|riscv|loongarch64) use_elfxx=yes; { $as_echo "$as_me:${as_lineno-$LINENO}: result: xx" >&5 $as_echo "xx" >&6; };; *) as_fn_error $? "Unknown ELF target: ${target_arch}" "$LINENO" 5 esac @@ -17930,6 +18006,7 @@ mips*) enable_cxx_exceptions=no;; tile*) enable_cxx_exceptions=no;; s390x*) enable_cxx_exceptions=no;; + loongarch*) enable_cxx_exceptions=no;; *) enable_cxx_exceptions=yes;; esac @@ -18341,7 +18418,7 @@ ARCH=`echo $target_arch | tr a-z A-Z` PKG_MAJOR=1 -PKG_MINOR=6 +PKG_MINOR=7 PKG_EXTRA=2 PKG_MAINTAINER=libunwind-devel@nongnu.org @@ -18410,6 +18487,16 @@ esac +# Check whether --with-testdriver was given. +if test "${with_testdriver+set}" = set; then : + withval=$with_testdriver; +else + with_testdriver=\$\(top_srcdir\)/config/test-driver +fi + +UNW_TESTDRIVER=$with_testdriver + + @@ -18466,7 +18553,7 @@ fi -if test "x$LATEX2MAN" = "x"; then +if test "x$LATEX2MAN" = "x" && test "x$enable_documentation" = "xyes"; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: latex2man not found. Install latex2man. Disabling docs." >&5 $as_echo "$as_me: WARNING: latex2man not found. Install latex2man. Disabling docs." >&2;} enable_documentation="no"; @@ -18743,6 +18830,10 @@ as_fn_error $? "conditional \"ARCH_RISCV\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi +if test -z "${ARCH_LOONGARCH64_TRUE}" && test -z "${ARCH_LOONGARCH64_FALSE}"; then + as_fn_error $? "conditional \"ARCH_LOONGARCH64\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi if test -z "${OS_LINUX_TRUE}" && test -z "${OS_LINUX_FALSE}"; then as_fn_error $? "conditional \"OS_LINUX\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 @@ -19200,7 +19291,7 @@ # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" -This file was extended by libunwind $as_me 1.6.2, which was +This file was extended by libunwind $as_me 1.7.2, which was generated by GNU Autoconf 2.69. Invocation command line was CONFIG_FILES = $CONFIG_FILES @@ -19266,7 +19357,7 @@ cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/\\""\`\$/\\\\&/g'`" ac_cs_version="\\ -libunwind config.status 1.6.2 +libunwind config.status 1.7.2 configured by $0, generated by GNU Autoconf 2.69, with options \\"\$ac_cs_config\\" @@ -19385,7 +19476,7 @@ # # INIT-COMMANDS # -AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}" +AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir" # The HP-UX ksh and POSIX shell print the target directory to stdout @@ -20392,35 +20483,29 @@ # 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. - # TODO: see whether this extra hack can be removed once we start - # requiring Autoconf 2.70 or later. - case $CONFIG_FILES in #( - *\'*) : - eval set x "$CONFIG_FILES" ;; #( - *) : - set x $CONFIG_FILES ;; #( - *) : - ;; -esac + case $CONFIG_FILES in + *\'*) eval set x "$CONFIG_FILES" ;; + *) set x $CONFIG_FILES ;; + esac shift - # Used to flag and report bootstrapping failures. - am_rc=0 - for am_mf + for mf do # Strip MF so we end up with the name of the file. - am_mf=`$as_echo "$am_mf" | sed -e 's/:.*$//'` - # Check whether this is an Automake generated Makefile which includes - # dependency-tracking related rules and includes. - # Grep'ing the whole file directly is not great: AIX grep has a line + 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. - sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \ - || continue - am_dirpart=`$as_dirname -- "$am_mf" || -$as_expr X"$am_mf" : 'X\(.*^/\)//*^/^/*/*$' \| \ - X"$am_mf" : 'X\(//\)^/' \| \ - X"$am_mf" : 'X\(//\)$' \| \ - X"$am_mf" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X"$am_mf" | + 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 @@ -20438,50 +20523,53 @@ q } s/.*/./; q'` - am_filepart=`$as_basename -- "$am_mf" || -$as_expr X/"$am_mf" : '.*/\(^/^/*\)/*$' \| \ - X"$am_mf" : 'X\(//\)$' \| \ - X"$am_mf" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X/"$am_mf" | - sed '/^.*\/\(^/^/*\)\/*$/{ + 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\/\(\/\/\)$/{ + /^X\(\/\/\)^/.*/{ s//\1/ q } - /^X\/\(\/\).*/{ + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` - { echo "$as_me:$LINENO: cd "$am_dirpart" \ - && sed -e '/# am--include-marker/d' "$am_filepart" \ - | $MAKE -f - am--depfiles" >&5 - (cd "$am_dirpart" \ - && sed -e '/# am--include-marker/d' "$am_filepart" \ - | $MAKE -f - am--depfiles) >&5 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } || am_rc=$? + as_dir=$dirpart/$fdir; as_fn_mkdir_p + # echo "creating $dirpart/$file" + echo '# dummy' > "$dirpart/$file" + done done - if test $am_rc -ne 0; then - { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "Something went wrong bootstrapping makefile fragments - for automatic dependency tracking. If GNU make was not used, consider - re-running the configure script with MAKE=\"gmake\" (or whatever is - necessary). You can also try re-running configure with the - '--disable-dependency-tracking' option to at least be able to build - the package (albeit without support for automatic dependency tracking). -See \`config.log' for more details" "$LINENO" 5; } - fi - { am_dirpart=; unset am_dirpart;} - { am_filepart=; unset am_filepart;} - { am_mf=; unset am_mf;} - { am_rc=; unset am_rc;} - rm -f conftest-deps.mk } ;; "libtool":C) @@ -20499,6 +20587,7 @@ cat <<_LT_EOF >> "$cfgfile" #! $SHELL # Generated automatically by $as_me ($PACKAGE) $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. # Provide generalized library-building support services.
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/configure.ac -> _service:tar_scm:libunwind-1.7.2.tar.gz/configure.ac
Changed
@@ -1,14 +1,18 @@ +dnl Process this file with autoconf to produce a configure script. + define(pkg_major, 1) -define(pkg_minor, 6) +define(pkg_minor, 7) define(pkg_extra, 2) define(pkg_maintainer, libunwind-devel@nongnu.org) define(mkvers, $1.$2.$3) -dnl Process this file with autoconf to produce a configure script. + AC_INIT(libunwind,mkvers(pkg_major, pkg_minor, pkg_extra),pkg_maintainer) AC_CONFIG_SRCDIR(src/mi/backtrace.c) AC_CONFIG_AUX_DIR(config) +AC_CONFIG_MACRO_DIRS(m4) AC_CANONICAL_TARGET -AM_INIT_AUTOMAKE(1.6 subdir-objects) +AM_INIT_AUTOMAKE(1.7 subdir-objects -Wall) +AM_SILENT_RULES(yes) AM_MAINTAINER_MODE AC_CONFIG_HEADERS(include/config.h) @@ -34,10 +38,10 @@ dnl Checks for header files. AC_HEADER_STDC -AC_CHECK_HEADERS(asm/ptrace_offsets.h asm/ptrace.h endian.h sys/endian.h sys/param.h \ - execinfo.h ia64intrin.h sys/uc_access.h unistd.h signal.h sys/types.h \ - sys/procfs.h sys/ptrace.h sys/syscall.h byteswap.h elf.h sys/elf.h \ - link.h sys/link.h) +AC_CHECK_HEADERS(asm/ptrace_offsets.h asm/ptrace.h asm/vsyscall.h endian.h sys/endian.h \ + sys/param.h execinfo.h ia64intrin.h sys/uc_access.h unistd.h signal.h \ + sys/types.h sys/procfs.h sys/ptrace.h sys/syscall.h byteswap.h elf.h \ + sys/elf.h link.h sys/link.h) dnl Checks for typedefs, structures, and compiler characteristics. AC_C_CONST @@ -48,7 +52,7 @@ CPPFLAGS="${CPPFLAGS} -D_GNU_SOURCE" AC_CHECK_MEMBERS(struct dl_phdr_info.dlpi_subs,,,#include <link.h>) -AC_CHECK_TYPES(struct elf_prstatus, struct prstatus, , , +AC_CHECK_TYPES(struct elf_prstatus, struct prstatus, procfs_status, elf_fpregset_t, , , $ac_includes_default #if HAVE_SYS_PROCFS_H # include <sys/procfs.h> @@ -69,7 +73,7 @@ dnl Checks for library functions. AC_CHECK_FUNCS(dl_iterate_phdr dl_phdr_removals_counter dlmodinfo getunwind \ - ttrace mincore pipe2) + ttrace mincore pipe2 sigaltstack) AC_MSG_CHECKING(if building with AltiVec) AC_COMPILE_IFELSE(AC_LANG_SOURCE( @@ -98,6 +102,7 @@ amd64,$2=x86_64, tile*,$2=tilegx, riscv*,$2=riscv, + loongarch64*,$2=loongarch64, $2=$1) ) dnl SET_ARCH @@ -120,7 +125,7 @@ AC_ARG_ENABLE(coredump, AS_HELP_STRING(--enable-coredump,building libunwind-coredump library),, - AS_CASE($host_arch, aarch64*|arm*|mips*|sh*|x86*|tile*|riscv*, enable_coredump=yes, enable_coredump=no) + AS_CASE($host_arch, aarch64*|arm*|mips*|sh*|x86*|tile*|riscv*|loongarch64, enable_coredump=yes, enable_coredump=no) ) AC_MSG_CHECKING(if we should build libunwind-coredump) @@ -189,6 +194,7 @@ AM_CONDITIONAL(ARCH_TILEGX, test x$target_arch = xtilegx) AM_CONDITIONAL(ARCH_S390X, test x$target_arch = xs390x) AM_CONDITIONAL(ARCH_RISCV, test x$target_arch = xriscv) +AM_CONDITIONAL(ARCH_LOONGARCH64, test x$target_arch = xloongarch64) AM_CONDITIONAL(OS_LINUX, expr x$target_os : xlinux >/dev/null) AM_CONDITIONAL(OS_HPUX, expr x$target_os : xhpux >/dev/null) AM_CONDITIONAL(OS_FREEBSD, expr x$target_os : xfreebsd >/dev/null) @@ -199,7 +205,7 @@ case "${target_arch}" in (arm|hppa|ppc32|x86|sh) use_elf32=yes; AC_MSG_RESULT(32);; (aarch64|ia64|ppc64|x86_64|s390x|tilegx) use_elf64=yes; AC_MSG_RESULT(64);; -(mips|riscv) use_elfxx=yes; AC_MSG_RESULT(xx);; +(mips|riscv|loongarch64) use_elfxx=yes; AC_MSG_RESULT(xx);; *) AC_MSG_ERROR(Unknown ELF target: ${target_arch}) esac AM_CONDITIONAL(USE_ELF32, test x$use_elf32 = xyes) @@ -246,6 +252,7 @@ mips*) enable_cxx_exceptions=no;; tile*) enable_cxx_exceptions=no;; s390x*) enable_cxx_exceptions=no;; + loongarch*) enable_cxx_exceptions=no;; *) enable_cxx_exceptions=yes;; esac ) @@ -332,7 +339,7 @@ AC_MSG_CHECKING(whether to support UNW_CACHE_PER_THREAD) AC_ARG_ENABLE(per-thread-cache, -AS_HELP_STRING(--enable-per-thread-cache, build with support for UNW_CACHE_PER_THREAD (which imposes a hight TLS memory usage) (default: disabled))) +AS_HELP_STRING(--enable-per-thread-cache, build with support for UNW_CACHE_PER_THREAD (which imposes a high TLS memory usage) (default: disabled))) AC_MSG_RESULT($enable_per_thread_cache) AS_IF(test x$enable_per_thread_cache = xyes, AC_DEFINE(HAVE___CACHE_PER_THREAD, 1, @@ -425,6 +432,12 @@ *) BACKTRACELIB="";; esac +AC_ARG_WITH(testdriver, + AS_HELP_STRING(--with-testdriver, + use designated test driver instead of default LOG_DRIVER), + , + with_testdriver=\$\(top_srcdir\)/config/test-driver) +AC_SUBST(UNW_TESTDRIVER, $with_testdriver) AC_SUBST(build_arch) AC_SUBST(target_os) @@ -443,7 +456,7 @@ AC_SUBST(BACKTRACELIB) AC_PATH_PROG(LATEX2MAN,latex2man) -if test "x$LATEX2MAN" = "x"; then +if test "x$LATEX2MAN" = "x" && test "x$enable_documentation" = "xyes"; then AC_MSG_WARN(latex2man not found. Install latex2man. Disabling docs.) enable_documentation="no"; fi
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/Makefile.am -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/Makefile.am
Changed
@@ -7,7 +7,9 @@ unw_get_accessors.man \ unw_get_proc_info.man \ unw_get_proc_info_by_ip.man \ + unw_get_proc_info_in_range.man \ unw_get_proc_name.man \ + unw_get_proc_name_by_ip.man \ unw_get_fpreg.man \ unw_get_reg.man \ unw_getcontext.man \ @@ -37,7 +39,9 @@ unw_get_accessors.tex \ unw_get_proc_info.tex \ unw_get_proc_info_by_ip.tex \ + unw_get_proc_info_in_range.tex \ unw_get_proc_name.tex \ + unw_get_proc_name_by_ip.tex \ unw_get_fpreg.tex \ unw_get_reg.tex \ unw_getcontext.tex \ @@ -62,16 +66,16 @@ L2H_CMD = $(L2M) -H -t $(srcdir)/libunwind.trans .tex.man: - $(L2M_CMD) $< $@ + $(AM_V_GEN)$(L2M_CMD) $< $@ -cp $@ $(srcdir)/$@ -html: +html-local: for n in $(man3_MANS); do \ page=`basename $$n .man`; \ $(L2H_CMD) $(srcdir)/$$page.tex "$$page(3).raw"; \ done -pdf: +pdf-local: for n in $(man3_MANS); do \ page=`basename $$n .man`; \ $(L2P) $(srcdir)/$$page.tex "$$page(3).pdf"; \
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/Makefile.in -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/Makefile.in
Changed
@@ -1,7 +1,7 @@ -# Makefile.in generated by automake 1.16.4 from Makefile.am. +# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ -# Copyright (C) 1994-2021 Free Software Foundation, Inc. +# 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, @@ -90,7 +90,9 @@ target_triplet = @target@ subdir = doc ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/acinclude.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)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) @@ -170,8 +172,6 @@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ -CSCOPE = @CSCOPE@ -CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ @@ -187,7 +187,6 @@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ -ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ @@ -238,6 +237,7 @@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ +UNW_TESTDRIVER = @UNW_TESTDRIVER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ @@ -311,7 +311,9 @@ unw_get_accessors.man \ unw_get_proc_info.man \ unw_get_proc_info_by_ip.man \ + unw_get_proc_info_in_range.man \ unw_get_proc_name.man \ + unw_get_proc_name_by_ip.man \ unw_get_fpreg.man \ unw_get_reg.man \ unw_getcontext.man \ @@ -341,7 +343,9 @@ unw_get_accessors.tex \ unw_get_proc_info.tex \ unw_get_proc_info_by_ip.tex \ + unw_get_proc_info_in_range.tex \ unw_get_proc_name.tex \ + unw_get_proc_name_by_ip.tex \ unw_get_fpreg.tex \ unw_get_reg.tex \ unw_getcontext.tex \ @@ -386,8 +390,8 @@ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ + 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) @@ -453,10 +457,8 @@ cscope cscopelist: -distdir: $(BUILT_SOURCES) - $(MAKE) $(AM_MAKEFLAGS) distdir-am -distdir-am: $(DISTFILES) +distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/.^$$\\*/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/.^$$\\*/\\\\&/g'`; \ list='$(DISTFILES)'; \ @@ -536,7 +538,9 @@ dvi-am: -html-am: +html: html-am + +html-am: html-local info: info-am @@ -578,7 +582,9 @@ mostlyclean-am: mostlyclean-generic mostlyclean-libtool -pdf-am: +pdf: pdf-am + +pdf-am: pdf-local ps: ps-am @@ -592,31 +598,31 @@ .PHONY: all all-am check check-am clean 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-dvi \ - install-dvi-am install-exec install-exec-am install-html \ - install-html-am install-info install-info-am install-man \ - install-man3 install-pdf install-pdf-am install-ps \ + distclean-libtool distdir dvi dvi-am html html-am html-local \ + 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-man3 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-man \ - uninstall-man3 + pdf-local ps ps-am tags-am uninstall uninstall-am \ + uninstall-man uninstall-man3 .PRECIOUS: Makefile .tex.man: - $(L2M_CMD) $< $@ + $(AM_V_GEN)$(L2M_CMD) $< $@ -cp $@ $(srcdir)/$@ -html: +html-local: for n in $(man3_MANS); do \ page=`basename $$n .man`; \ $(L2H_CMD) $(srcdir)/$$page.tex "$$page(3).raw"; \ done -pdf: +pdf-local: for n in $(man3_MANS); do \ page=`basename $$n .man`; \ $(L2P) $(srcdir)/$$page.tex "$$page(3).pdf"; \
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/libunwind-dynamic.man -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/libunwind-dynamic.man
Changed
@@ -1,5 +1,5 @@ '\" t -.\" Manual page created with latex2man on Thu Aug 16 09:44:44 MDT 2007 +.\" Manual page created with latex2man on Sun Aug 29 23:45:06 CEST 2021 .\" NOTE: This file is generated, DO NOT EDIT. .de Vb .ft CW @@ -10,479 +10,479 @@ .fi .. -.TH "LIBUNWIND\-DYNAMIC" "3" "16 August 2007" "Programming Library " "Programming Library " +.TH "LIBUNWIND\-DYNAMIC" "3" "29 August 2021" "Programming Library " "Programming Library " .SH NAME libunwind\-dynamic -\-\- libunwind\-support for runtime\-generated code +\-\- libunwind\-support for runtime\-generated code .PP .SH INTRODUCTION .PP For libunwind -to do its job, it needs to be able to reconstruct +to do its job, it needs to be able to reconstruct the \fIframe state\fP -of each frame in a call\-chain. The frame state -describes the subset of the machine\-state that consists of the +of each frame in a call\-chain. The frame state +describes the subset of the machine\-state that consists of the \fIframe registers\fP -(typically the instruction\-pointer and the -stack\-pointer) and all callee\-saved registers (preserved registers). -The frame state describes each register either by providing its -current value (for frame registers) or by providing the location at -which the current value is stored (callee\-saved registers). +(typically the instruction\-pointer and the +stack\-pointer) and all callee\-saved registers (preserved registers). +The frame state describes each register either by providing its +current value (for frame registers) or by providing the location at +which the current value is stored (callee\-saved registers). .PP -For statically generated code, the compiler normally takes care of +For statically generated code, the compiler normally takes care of emitting \fIunwind\-info\fP -which provides the minimum amount of -information needed to reconstruct the frame\-state for each instruction -in a procedure. For dynamically generated code, the runtime code -generator must use the dynamic unwind\-info interface provided by +which provides the minimum amount of +information needed to reconstruct the frame\-state for each instruction +in a procedure. For dynamically generated code, the runtime code +generator must use the dynamic unwind\-info interface provided by libunwind -to supply the equivalent information. This manual -page describes the format of this information in detail. +to supply the equivalent information. This manual +page describes the format of this information in detail. .PP For the purpose of this discussion, a \fIprocedure\fP -is defined to +is defined to be an arbitrary piece of \fIcontiguous\fP -code. Normally, each -procedure directly corresponds to a function in the source\-language -but this is not strictly required. For example, a runtime -code\-generator could translate a given function into two separate -(discontiguous) procedures: one for frequently\-executed (hot) code and -one for rarely\-executed (cold) code. Similarly, simple -source\-language functions (usually leaf functions) may get translated -into code for which the default unwind\-conventions apply and for such -code, it is not strictly necessary to register dynamic unwind\-info. +code. Normally, each +procedure directly corresponds to a function in the source\-language +but this is not strictly required. For example, a runtime +code\-generator could translate a given function into two separate +(discontiguous) procedures: one for frequently\-executed (hot) code and +one for rarely\-executed (cold) code. Similarly, simple +source\-language functions (usually leaf functions) may get translated +into code for which the default unwind\-conventions apply and for such +code, it is not strictly necessary to register dynamic unwind\-info. .PP A procedure logically consists of a sequence of \fIregions\fP\&. -Regions are nested in the sense that the frame state at the end of one -region is, by default, assumed to be the frame state for the next -region. Each region is thought of as being divided into a +Regions are nested in the sense that the frame state at the end of one +region is, by default, assumed to be the frame state for the next +region. Each region is thought of as being divided into a \fIprologue\fP, a \fIbody\fP, and an \fIepilogue\fP\&. -Each of them -can be empty. If non\-empty, the prologue sets up the frame state for -the body. For example, the prologue may need to allocate some space -on the stack and save certain callee\-saved registers. The body -performs the actual work of the procedure but does not change the -frame state in any way. If non\-empty, the epilogue restores the -previous frame state and as such it undoes or cancels the effect of -the prologue. In fact, a single epilogue may undo the effect of the -prologues of several (nested) regions. -.PP -We should point out that even though the prologue, body, and epilogue -are logically separate entities, optimizing code\-generators will -generally interleave instructions from all three entities. For this +Each of them +can be empty. If non\-empty, the prologue sets up the frame state for +the body. For example, the prologue may need to allocate some space +on the stack and save certain callee\-saved registers. The body +performs the actual work of the procedure but does not change the +frame state in any way. If non\-empty, the epilogue restores the +previous frame state and as such it undoes or cancels the effect of +the prologue. In fact, a single epilogue may undo the effect of the +prologues of several (nested) regions. +.PP +We should point out that even though the prologue, body, and epilogue +are logically separate entities, optimizing code\-generators will +generally interleave instructions from all three entities. For this reason, the dynamic unwind\-info interface of libunwind -makes no -distinction whatsoever between prologue and body. Similarly, the -exact set of instructions that make up an epilogue is also irrelevant. -The only point in the epilogue that needs to be described explicitly -by the dynamic unwind\-info is the point at which the stack\-pointer -gets restored. The reason this point needs to be described is that -once the stack\-pointer is restored, all values saved in the -deallocated portion of the stack frame become invalid and hence +makes no +distinction whatsoever between prologue and body. Similarly, the +exact set of instructions that make up an epilogue is also irrelevant. +The only point in the epilogue that needs to be described explicitly +by the dynamic unwind\-info is the point at which the stack\-pointer +gets restored. The reason this point needs to be described is that +once the stack\-pointer is restored, all values saved in the +deallocated portion of the stack frame become invalid and hence libunwind -needs to know about it. The portion of the frame -state not saved on the stack is assume to remain valid through the end -of the region. For this reason, there is usually no need to describe -instructions which restore the contents of callee\-saved registers. -.PP -Within a region, each instruction that affects the frame state in some -fashion needs to be described with an operation descriptor. For this -purpose, each instruction in the region is assigned a unique index. -Exactly how this index is derived depends on the architecture. For -example, on RISC and EPIC\-style architecture, instructions have a -fixed size so it\&'s possible to simply number the instructions. In -contrast, most CISC use variable\-length instruction encodings, so it -is usually necessary to use a byte\-offset as the index. Given the -instruction index, the operation descriptor specifies the effect of -the instruction in an abstract manner. For example, it might express -that the instruction stores calle\-saved register r1 -at offset 16 -in the stack frame. +needs to know about it. The portion of the frame +state not saved on the stack is assumed to remain valid through the end +of the region. For this reason, there is usually no need to describe +instructions which restore the contents of callee\-saved registers. +.PP +Within a region, each instruction that affects the frame state in some +fashion needs to be described with an operation descriptor. For this +purpose, each instruction in the region is assigned a unique index. +Exactly how this index is derived depends on the architecture. For +example, on RISC and EPIC\-style architecture, instructions have a +fixed size so it\&'s possible to simply number the instructions. In +contrast, most CISC use variable\-length instruction encodings, so it +is usually necessary to use a byte\-offset as the index. Given the +instruction index, the operation descriptor specifies the effect of +the instruction in an abstract manner. For example, it might express +that the instruction stores callee\-saved register r1 +at offset 16 +in the stack frame. .PP .SH PROCEDURES .PP -A runtime code\-generator registers the dynamic unwind\-info of a +A runtime code\-generator registers the dynamic unwind\-info of a procedure by setting up a structure of type unw_dyn_info_t and calling _U_dyn_register(), -passing the address of the -structure as the sole argument. The members of the +passing the address of the +structure as the sole argument. The members of the unw_dyn_info_t -structure are described below: +structure are described below: .TP void *next Private to libunwind\&. -Must not be used -by the application. +Must not be used +by the application. .TP void *prev Private to libunwind\&. -Must not be used -by the application. +Must not be used +by the application. .TP unw_word_t start_ip - The start\-address of the -instructions of the procedure (remember: procedure are defined to be -contiguous pieces of code, so a single code\-range is sufficient). + The start\-address of the +instructions of the procedure (remember: procedure are defined to be +contiguous pieces of code, so a single code\-range is sufficient). .TP unw_word_t end_ip - The end\-address of the -instructions of the procedure (non\-inclusive, that is, + The end\-address of the +instructions of the procedure (non\-inclusive, that is, end_ip\-start_ip -is the size of the procedure in -bytes). +is the size of the procedure in +bytes). .TP unw_word_t gp - The global\-pointer value in use -for this procedure. The exact meaing of the global\-pointer is -architecture\-specific and on some architecture, it is not used at -all. + The global\-pointer value in use +for this procedure. The exact meaning of the global\-pointer is +architecture\-specific and on some architecture, it is not used at +all. .TP int32_t format - The format of the unwind\-info. + The format of the unwind\-info. This member can be one of UNW_INFO_FORMAT_DYNAMIC, UNW_INFO_FORMAT_TABLE, -or +or UNW_INFO_FORMAT_REMOTE_TABLE\&. .TP union u - This union contains one sub\-member -structure for every possible unwind\-info format: + This union contains one sub\-member +structure for every possible unwind\-info format: .RS .TP unw_dyn_proc_info_t pi - This member is used + This member is used for format UNW_INFO_FORMAT_DYNAMIC\&. .TP unw_dyn_table_info_t ti - This member is used + This member is used for format UNW_INFO_FORMAT_TABLE\&. .TP unw_dyn_remote_table_info_t rti - This member + This member is used for format UNW_INFO_FORMAT_REMOTE_TABLE\&. .RE .RS .PP -The format of these sub\-members is described in detail below. +The format of these sub\-members is described in detail below. .RE .PP .SS PROC\-INFO FORMAT .PP -This is the preferred dynamic unwind\-info format and it is generally -the one used by full\-blown runtime code\-generators. In this format, -the details of a procedure are described by a structure of type +This is the preferred dynamic unwind\-info format and it is generally +the one used by full\-blown runtime code\-generators. In this format, +the details of a procedure are described by a structure of type unw_dyn_proc_info_t\&. -This structure contains the following -members: +This structure contains the following +members: .PP .RE .TP unw_word_t name_ptr - The address of a -(human\-readable) name of the procedure or 0 if no such name is -available. If non\-zero, The string stored at this address must be -ASCII NUL terminated. For source languages that use name\-mangling -(such as C++ or Java) the string stored at this address should be + The address of a +(human\-readable) name of the procedure or 0 if no such name is +available. If non\-zero, the string stored at this address must be +ASCII NUL terminated. For source languages that use name\-mangling +(such as C++ or Java) the string stored at this address should be the \fIdemangled\fP -version of the name. +version of the name. .PP .TP unw_word_t handler - The address of the -personality\-routine for this procedure. Personality\-routines are -used in conjunction with exception handling. See the C++ ABI draft -(http://www.codesourcery.com/cxx\-abi/) for an overview and a -description of the personality routine. If the procedure has no + The address of the +personality\-routine for this procedure. Personality\-routines are +used in conjunction with exception handling. See the C++ ABI draft +(http://www.codesourcery.com/cxx\-abi/) for an overview and a +description of the personality routine. If the procedure has no personality routine, handler -must be set to 0. +must be set to 0. .PP .TP uint32_t flags - A bitmask of flags. At the -moment, no flags have been defined and this member must be -set to 0. + A bitmask of flags. At the +moment, no flags have been defined and this member must be +set to 0. .PP .TP unw_dyn_region_info_t *regions - A NULL\-terminated -linked list of region\-descriptors. See section ``Region -descriptors\&'' below for more details. + A NULL\-terminated +linked list of region\-descriptors. See section ``Region +descriptors\&'' below for more details. .PP .SS TABLE\-INFO FORMAT .PP -This format is generally used when the dynamically generated code was -derived from static code and the unwind\-info for the dynamic and the -static versions is identical. For example, this format can be useful -when loading statically\-generated code into an address\-space in a -non\-standard fashion (i.e., through some means other than +This format is generally used when the dynamically generated code was +derived from static code and the unwind\-info for the dynamic and the +static versions are identical. For example, this format can be useful +when loading statically\-generated code into an address\-space in a +non\-standard fashion (i.e., through some means other than dlopen()). -In this format, the details of a group of procedures +In this format, the details of a group of procedures is described by a structure of type unw_dyn_table_info\&. -This structure contains the following members: +This structure contains the following members: .PP .TP unw_word_t name_ptr - The address of a -(human\-readable) name of the procedure or 0 if no such name is -available. If non\-zero, The string stored at this address must be -ASCII NUL terminated. For source languages that use name\-mangling -(such as C++ or Java) the string stored at this address should be + The address of a +(human\-readable) name of the procedure or 0 if no such name is +available. If non\-zero, the string stored at this address must be +ASCII NUL terminated. For source languages that use name\-mangling +(such as C++ or Java) the string stored at this address should be the \fIdemangled\fP -version of the name. +version of the name. .PP .TP unw_word_t segbase - The segment\-base value -that needs to be added to the segment\-relative values stored in the -unwind\-info. The exact meaning of this value is -architecture\-specific. + The segment\-base value +that needs to be added to the segment\-relative values stored in the +unwind\-info. The exact meaning of this value is +architecture\-specific. .PP .TP unw_word_t table_len - The length of the + The length of the unwind\-info (table_data) -counted in units of words +counted in units of words (unw_word_t). .PP .TP unw_word_t table_data - A pointer to the actual -data encoding the unwind\-info. The exact format is -architecture\-specific (see architecture\-specific sections below). + A pointer to the actual +data encoding the unwind\-info. The exact format is +architecture\-specific (see architecture\-specific sections below). .PP .SS REMOTE TABLE\-INFO FORMAT .PP -The remote table\-info format has the same basic purpose as the regular +The remote table\-info format has the same basic purpose as the regular table\-info format. The only difference is that when libunwind -uses the unwind\-info, it will keep the table data in the target -address\-space (which may be remote). Consequently, the type of the +uses the unwind\-info, it will keep the table data in the target +address\-space (which may be remote). Consequently, the type of the table_data member is unw_word_t -rather than a pointer. +rather than a pointer. This implies that libunwind -will have to access the table\-data +will have to access the table\-data via the address\-space\&'s access_mem() -call\-back, rather than -through a direct memory reference. -.PP -From the point of view of a runtime\-code generator, the remote -table\-info format offers no advantage and it is expected that such -generators will describe their procedures either with the proc\-info -format or the normal table\-info format. The main reason that the -remote table\-info format exists is to enable the +call\-back, rather than +through a direct memory reference. +.PP +From the point of view of a runtime\-code generator, the remote +table\-info format offers no advantage and it is expected that such +generators will describe their procedures either with the proc\-info +format or the normal table\-info format. The main reason that the +remote table\-info format exists is to enable the address\-space\-specific find_proc_info() -callback (see +callback (see unw_create_addr_space(3)) -to return unwind tables whose -data remains in remote memory. This can speed up unwinding (e.g., for -a debugger) because it reduces the amount of data that needs to be -loaded from remote memory. +to return unwind tables whose +data remains in remote memory. This can speed up unwinding (e.g., for +a debugger) because it reduces the amount of data that needs to be +loaded from remote memory. .PP .SH REGIONS DESCRIPTORS .PP -A region descriptor is a variable length structure that describes how -each instruction in the region affects the frame state. Of course, -most instructions in a region usualy do not change the frame state and -for those, nothing needs to be recorded in the region descriptor. A -region descriptor is a structure of type +A region descriptor is a variable length structure that describes how +each instruction in the region affects the frame state. Of course, +most instructions in a region usually do not change the frame state and +for those, nothing needs to be recorded in the region descriptor. A +region descriptor is a structure of type unw_dyn_region_info_t -and has the following members: +and has the following members: .TP unw_dyn_region_info_t *next - A pointer to the + A pointer to the next region. If this is the last region, next is NULL\&. .TP int32_t insn_count - The length of the region in -instructions. Each instruction is assumed to have a fixed size (see -architecture\-specific sections for details). The value of + The length of the region in +instructions. Each instruction is assumed to have a fixed size (see +architecture\-specific sections for details). The value of insn_count -may be negative in the last region of a procedure +may be negative in the last region of a procedure (i.e., it may be negative only if next is NULL). -A +A negative value indicates that the region covers the last \fIN\fP instructions of the procedure, where \fIN\fP -is the absolute value +is the absolute value of insn_count\&. .TP uint32_t op_count - The (allocated) length of + The (allocated) length of the op_count -array. +array. .TP unw_dyn_op_t op - An array of dynamic unwind -directives. See Section ``Dynamic unwind directives\&'' for a -description of the directives. + An array of dynamic unwind +directives. See Section ``Dynamic unwind directives\&'' for a +description of the directives. .PP A region descriptor with an insn_count -of zero is an +of zero is an \fIempty region\fP -and such regions are perfectly legal. In fact, -empty regions can be useful to establish a particular frame state -before the start of another region. -.PP -A single region list can be shared across multiple procedures provided -those procedures share a common prologue and epilogue (their bodies -may differ, of course). Normally, such procedures consist of a canned -prologue, the body, and a canned epilogue. This could be described by -two regions: one covering the prologue and one covering the epilogue. -Since the body length is variable, the latter region would need to +and such regions are perfectly legal. In fact, +empty regions can be useful to establish a particular frame state +before the start of another region. +.PP +A single region list can be shared across multiple procedures provided +those procedures share a common prologue and epilogue (their bodies +may differ, of course). Normally, such procedures consist of a canned +prologue, the body, and a canned epilogue. This could be described by +two regions: one covering the prologue and one covering the epilogue. +Since the body length is variable, the latter region would need to specify a negative value in insn_count -such that +such that libunwind -knows that the region covers the end of the procedure +knows that the region covers the end of the procedure (up to the address specified by end_ip). .PP -The region descriptor is a variable length structure to make it -possible to allocate all the necessary memory with a single -memory\-allocation request. To facilitate the allocation of a region +The region descriptor is a variable length structure to make it +possible to allocate all the necessary memory with a single +memory\-allocation request. To facilitate the allocation of a region descriptors libunwind -provides a helper routine with the -following synopsis: +provides a helper routine with the +following synopsis: .PP size_t _U_dyn_region_size(int op_count); .PP -This routine returns the number of bytes needed to hold a region +This routine returns the number of bytes needed to hold a region descriptor with space for op_count -unwind directives. Note +unwind directives. Note that the length of the op -array does not have to match exactly -with the number of directives in a region. Instead, it is sufficient +array does not have to match exactly +with the number of directives in a region. Instead, it is sufficient if the op -array contains at least as many entries as there are -directives, since the end of the directives can always be indicated +array contains at least as many entries as there are +directives, since the end of the directives can always be indicated with the UNW_DYN_STOP -directive. +directive. .PP .SH DYNAMIC UNWIND DIRECTIVES .PP -A dynamic unwind directive describes how the frame state changes -at a particular point within a region. The description is in +A dynamic unwind directive describes how the frame state changes +at a particular point within a region. The description is in the form of a structure of type unw_dyn_op_t\&. -This -structure has the following members: +This +structure has the following members: .TP int8_t tag - The operation tag. Must be one + The operation tag. Must be one of the unw_dyn_operation_t -values described below. +values described below. .TP int8_t qp - The qualifying predicate that controls -whether or not this directive is active. This is useful for -predicated architecturs such as IA\-64 or ARM, where the contents of -another (callee\-saved) register determines whether or not an -instruction is executed (takes effect). If the directive is always -active, this member should be set to the manifest constant + The qualifying predicate that controls +whether or not this directive is active. This is useful for +predicated architectures such as IA\-64 or ARM, where the contents of +another (callee\-saved) register determines whether or not an +instruction is executed (takes effect). If the directive is always +active, this member should be set to the manifest constant _U_QP_TRUE -(this constant is defined for all -architectures, predicated or not). +(this constant is defined for all +architectures, predicated or not). .TP int16_t reg - The number of the register affected -by the instruction. + The number of the register affected +by the instruction. .TP int32_t when - The region\-relative number of -the instruction to which this directive applies. For example, -a value of 0 means that the effect described by this directive -has taken place once the first instruction in the region has -executed. + The region\-relative number of +the instruction to which this directive applies. For example, +a value of 0 means that the effect described by this directive +has taken place once the first instruction in the region has +executed. .TP unw_word_t val - The value to be applied by the -operation tag. The exact meaning of this value varies by tag. See -Section ``Operation tags\&'' below. + The value to be applied by the +operation tag. The exact meaning of this value varies by tag. See +Section ``Operation tags\&'' below. .PP -It is perfectly legitimate to specify multiple dynamic unwind +It is perfectly legitimate to specify multiple dynamic unwind directives with the same when -value, if a particular instruction -has a complex effect on the frame state. +value, if a particular instruction +has a complex effect on the frame state. .PP -Empty regions by definition contain no actual instructions and as such -the directives are not tied to a particular instruction. By +Empty regions by definition contain no actual instructions and as such +the directives are not tied to a particular instruction. By convention, the when -member should be set to 0, however. +member should be set to 0, however. .PP -There is no need for the dynamic unwind directives to appear +There is no need for the dynamic unwind directives to appear in order of increasing when -values. If the directives happen to -be sorted in that order, it may result in slightly faster execution, -but a runtime code\-generator should not go to extra lengths just to -ensure that the directives are sorted. +values. If the directives happen to +be sorted in that order, it may result in slightly faster execution, +but a runtime code\-generator should not go to extra lengths just to +ensure that the directives are sorted. .PP IMPLEMENTATION NOTE: should libunwind -implementations for -certain architectures prefer the list of unwind directives to be -sorted, it is recommended that such implementations first check -whether the list happens to be sorted already and, if not, sort the -directives explicitly before the first use. With this approach, the -overhead of explicit sorting is only paid when there is a real benefit -and if the runtime code\-generator happens to generated sorted lists -naturally, the performance penalty is limited to a simple O(N) check. +implementations for +certain architectures prefer the list of unwind directives to be +sorted, it is recommended that such implementations first check +whether the list happens to be sorted already and, if not, sort the +directives explicitly before the first use. With this approach, the +overhead of explicit sorting is only paid when there is a real benefit +and if the runtime code\-generator happens to generate sorted lists +naturally, the performance penalty is limited to a simple O(N) check. .PP .SS OPERATIONS TAGS .PP -The possible operation tags are defined by enumeration type +The possible operation tags are defined by enumeration type unw_dyn_operation_t -which defines the following -values: +which defines the following +values: .PP .TP UNW_DYN_STOP - Marks the end of the dynamic unwind + Marks the end of the dynamic unwind directive list. All remaining entries in the op -array of the -region\-descriptor are ignored. This tag is guaranteed to have a -value of 0. +array of the +region\-descriptor are ignored. This tag is guaranteed to have a +value of 0. .PP .TP UNW_DYN_SAVE_REG - Marks an instruction which saves + Marks an instruction which saves register reg to register val\&. .PP .TP UNW_DYN_SPILL_FP_REL - Marks an instruction which + Marks an instruction which spills register reg -to a frame\-pointer\-relative location. The -frame\-pointer\-relative offset is given by the value stored in member +to a frame\-pointer\-relative location. The +frame\-pointer\-relative offset is given by the value stored in member val\&. -See the architecture\-specific sections for a description -of the stack frame layout. +See the architecture\-specific sections for a description +of the stack frame layout. .PP .TP UNW_DYN_SPILL_SP_REL - Marks an instruction which + Marks an instruction which spills register reg -to a stack\-pointer\-relative location. The -stack\-pointer\-relative offset is given by the value stored in member +to a stack\-pointer\-relative location. The +stack\-pointer\-relative offset is given by the value stored in member val\&. -See the architecture\-specific sections for a description -of the stack frame layout. +See the architecture\-specific sections for a description +of the stack frame layout. .PP .TP UNW_DYN_ADD - Marks an instruction which adds + Marks an instruction which adds the constant value val to register reg\&. -To add subtract -a constant value, store the two\&'s\-complement of the value in +To add subtract +a constant value, store the two\&'s\-complement of the value in val\&. -The set of registers that can be specified for this tag -is described in the architecture\-specific sections below. +The set of registers that can be specified for this tag +is described in the architecture\-specific sections below. .PP .TP UNW_DYN_POP_FRAMES @@ -496,29 +496,29 @@ .TP UNW_DYN_ALIAS .PP -unw_dyn_op_t -.PP -_U_dyn_op_save_reg(); -_U_dyn_op_spill_fp_rel(); -_U_dyn_op_spill_sp_rel(); -_U_dyn_op_add(); -_U_dyn_op_pop_frames(); -_U_dyn_op_label_state(); -_U_dyn_op_copy_state(); -_U_dyn_op_alias(); -_U_dyn_op_stop(); +unw_dyn_op_t +.PP +_U_dyn_op_save_reg(); +_U_dyn_op_spill_fp_rel(); +_U_dyn_op_spill_sp_rel(); +_U_dyn_op_add(); +_U_dyn_op_pop_frames(); +_U_dyn_op_label_state(); +_U_dyn_op_copy_state(); +_U_dyn_op_alias(); +_U_dyn_op_stop(); .PP .SH IA\-64 SPECIFICS .PP -\- meaning of segbase member in table\-info/table\-remote\-info format -\- format of table_data in table\-info/table\-remote\-info format -\- instruction size: each bundle is counted as 3 instructions, regardless -of template (MLX) -\- describe stack\-frame layout, especially with regards to sp\-relative -and fp\-relative addressing -\- UNW_DYN_ADD can only add to ``sp\&'' (always a negative value); use -POP_FRAMES otherwise +\- meaning of segbase member in table\-info/table\-remote\-info format +\- format of table_data in table\-info/table\-remote\-info format +\- instruction size: each bundle is counted as 3 instructions, regardless +of template (MLX) +\- describe stack\-frame layout, especially with regards to sp\-relative +and fp\-relative addressing +\- UNW_DYN_ADD can only add to ``sp\&'' (always a negative value); use +POP_FRAMES otherwise .PP .SH SEE ALSO
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/libunwind-dynamic.tex -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/libunwind-dynamic.tex
Changed
@@ -64,7 +64,7 @@ once the stack-pointer is restored, all values saved in the deallocated portion of the stack frame become invalid and hence \Prog{libunwind} needs to know about it. The portion of the frame -state not saved on the stack is assume to remain valid through the end +state not saved on the stack is assumed to remain valid through the end of the region. For this reason, there is usually no need to describe instructions which restore the contents of callee-saved registers. @@ -78,7 +78,7 @@ is usually necessary to use a byte-offset as the index. Given the instruction index, the operation descriptor specifies the effect of the instruction in an abstract manner. For example, it might express -that the instruction stores calle-saved register \Var{r1} at offset 16 +that the instruction stores callee-saved register \Var{r1} at offset 16 in the stack frame. \section{Procedures} @@ -101,7 +101,7 @@ \Var{end\_ip}-\Var{start\_ip} is the size of the procedure in bytes). \item\Type{unw\_word\_t} \Var{gp} The global-pointer value in use - for this procedure. The exact meaing of the global-pointer is + for this procedure. The exact meaning of the global-pointer is architecture-specific and on some architecture, it is not used at all. \item\Type{int32\_t} \Var{format} The format of the unwind-info. @@ -132,7 +132,7 @@ \item\Type{unw\_word\_t} \Var{name\_ptr} The address of a (human-readable) name of the procedure or 0 if no such name is - available. If non-zero, The string stored at this address must be + available. If non-zero, the string stored at this address must be ASCII NUL terminated. For source languages that use name-mangling (such as C++ or Java) the string stored at this address should be the \emph{demangled} version of the name. @@ -158,7 +158,7 @@ This format is generally used when the dynamically generated code was derived from static code and the unwind-info for the dynamic and the -static versions is identical. For example, this format can be useful +static versions are identical. For example, this format can be useful when loading statically-generated code into an address-space in a non-standard fashion (i.e., through some means other than \Func{dlopen}()). In this format, the details of a group of procedures @@ -168,7 +168,7 @@ \item\Type{unw\_word\_t} \Var{name\_ptr} The address of a (human-readable) name of the procedure or 0 if no such name is - available. If non-zero, The string stored at this address must be + available. If non-zero, the string stored at this address must be ASCII NUL terminated. For source languages that use name-mangling (such as C++ or Java) the string stored at this address should be the \emph{demangled} version of the name. @@ -214,7 +214,7 @@ A region descriptor is a variable length structure that describes how each instruction in the region affects the frame state. Of course, -most instructions in a region usualy do not change the frame state and +most instructions in a region usually do not change the frame state and for those, nothing needs to be recorded in the region descriptor. A region descriptor is a structure of type \Type{unw\_dyn\_region\_info\_t} and has the following members: @@ -278,7 +278,7 @@ of the \Type{unw\_dyn\_operation\_t} values described below. \item\Type{int8\_t} \Var{qp} The qualifying predicate that controls whether or not this directive is active. This is useful for - predicated architecturs such as IA-64 or ARM, where the contents of + predicated architectures such as IA-64 or ARM, where the contents of another (callee-saved) register determines whether or not an instruction is executed (takes effect). If the directive is always active, this member should be set to the manifest constant @@ -315,7 +315,7 @@ whether the list happens to be sorted already and, if not, sort the directives explicitly before the first use. With this approach, the overhead of explicit sorting is only paid when there is a real benefit -and if the runtime code-generator happens to generated sorted lists +and if the runtime code-generator happens to generate sorted lists naturally, the performance penalty is limited to a simple O(N) check. \subsection{Operations tags}
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/libunwind.man -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/libunwind.man
Changed
@@ -1,5 +1,5 @@ '\" t -.\" Manual page created with latex2man on Thu Jan 12 06:50:29 PST 2017 +.\" Manual page created with latex2man on Sun Aug 29 23:45:06 CEST 2021 .\" NOTE: This file is generated, DO NOT EDIT. .de Vb .ft CW @@ -10,7 +10,7 @@ .fi .. -.TH "LIBUNWIND" "3" "12 January 2017" "Programming Library " "Programming Library " +.TH "LIBUNWIND" "3" "29 August 2021" "Programming Library " "Programming Library " .SH NAME libunwind \-\- a (mostly) platform\-independent unwind API @@ -215,8 +215,9 @@ Normally, libunwind supports both local and remote unwinding (the latter will be explained in the next section). However, if you -tell libunwind that your program only needs local unwinding, then a -special implementation can be selected which may run much faster than +tell libunwind +that your program only needs local unwinding, then +a special implementation can be selected which may run much faster than the generic implementation which supports both kinds of unwinding. To select this optimized version, simply define the macro UNW_LOCAL_ONLY @@ -357,7 +358,7 @@ All libunwind routines are thread\-safe. What this means is that multiple threads may use libunwind -simulatenously. +simultaneously. However, any given cursor may be accessed by only one thread at any given time. .PP @@ -431,11 +432,11 @@ object. In particular, by selecting the policy UNW_CACHE_NONE, it is possible to turn off caching -completely, therefore eliminating the risk of stale data alltogether +completely, therefore eliminating the risk of stale data altogether (at the cost of slower execution). By default, caching is enabled for local unwinding only. The cache size can be dynamically changed with unw_set_cache_size(), -which also fluches the current cache. +which also flushes the current cache. .PP .SH FILES
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/libunwind.tex -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/libunwind.tex
Changed
@@ -128,8 +128,8 @@ Normally, \Prog{libunwind} supports both local and remote unwinding (the latter will be explained in the next section). However, if you -tell libunwind that your program only needs local unwinding, then a -special implementation can be selected which may run much faster than +tell \Prog{libunwind} that your program only needs local unwinding, then +a special implementation can be selected which may run much faster than the generic implementation which supports both kinds of unwinding. To select this optimized version, simply define the macro \Const{UNW\_LOCAL\_ONLY} before including the headerfile @@ -238,7 +238,7 @@ All \Prog{libunwind} routines are thread-safe. What this means is -that multiple threads may use \Prog{libunwind} simulatenously. +that multiple threads may use \Prog{libunwind} simultaneously. However, any given cursor may be accessed by only one thread at any given time. @@ -293,10 +293,10 @@ select the exact caching policy in use for a given address-space object. In particular, by selecting the policy \Const{UNW\_CACHE\_NONE}, it is possible to turn off caching -completely, therefore eliminating the risk of stale data alltogether +completely, therefore eliminating the risk of stale data altogether (at the cost of slower execution). By default, caching is enabled for local unwinding only. The cache size can be dynamically changed with -\Func{unw\_set\_cache\_size}(), which also fluches the current cache. +\Func{unw\_set\_cache\_size}(), which also flushes the current cache. \section{Files}
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/unw_backtrace.man -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_backtrace.man
Changed
@@ -1,5 +1,7 @@ +.\" *********************************** start of \input{common.tex} +.\" *********************************** end of \input{common.tex} '\" t -.\" Manual page created with latex2man on Fri Aug 31 13:39:04 EEST 2012 +.\" Manual page created with latex2man on Thu Jan 5 15:33:00 2023 .\" NOTE: This file is generated, DO NOT EDIT. .de Vb .ft CW @@ -10,7 +12,7 @@ .fi .. -.TH "UNW\\_BACKTRACE" "3" "31 August 2012" "Programming Library " "Programming Library " +.TH "UNW\\_BACKTRACE" "3" "05 January 2023" "Programming Library " "Programming Library " .SH NAME unw_backtrace \-\- return backtrace for the calling program @@ -25,6 +27,12 @@ unw_backtrace(void **buffer, int size); .br +int +unw_backtrace2(void **buffer, +int size, +unw_context_t *ctxt, +int flag); +.br .PP #include <execinfo.h> .br @@ -44,7 +52,7 @@ pointed by buffer\&. The routine is only available for local unwinding. .PP -Note that many (but not all) systems provide practically identical function +Note that many (but not all) systems provide a practically identical function called backtrace(). The prototype for this function is usually obtained by including the <execinfo.h> @@ -61,6 +69,17 @@ it may end up calling unw_backtrace(). .PP +In case you want to obtain the backtrace from a specific unw_context_t, +you can call unw_backtrace2 +with that context passing 0 +for flag. +If the unw_context_t +is known to be a signal frame (i.e., from the third argument +in a sigaction handler on linux), unw_backtrace2 +can be used to collect +only the frames before the signal frame passing the UNW_INIT_SIGNAL_FRAME +flag. +.PP .SH RETURN VALUE .PP
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/unw_backtrace.tex -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_backtrace.tex
Changed
@@ -13,6 +13,7 @@ \File{\#include $<$libunwind.h$>$}\\ \Type{int} \Func{unw\_backtrace}(\Type{void~**}\Var{buffer}, \Type{int}~\Var{size});\\ +\Type{int} \Func{unw\_backtrace2}(\Type{void~**}\Var{buffer}, \Type{int}~\Var{size}, \Type{unw_context_t~*}\Var{ctxt}, \Type{int}~\Var{flag});\\ \File{\#include $<$execinfo.h$>$}\\ @@ -24,7 +25,7 @@ the calling program. The routine fills up to \Var{size} addresses in the array pointed by \Var{buffer}. The routine is only available for local unwinding. -Note that many (but not all) systems provide practically identical function +Note that many (but not all) systems provide a practically identical function called \Func{backtrace}(). The prototype for this function is usually obtained by including the \File{$<$execinfo.h$>$} header file -- a prototype for \Func{backtrace}() is not provided by \Prog{libunwind}. \Prog{libunwind} weakly @@ -32,6 +33,12 @@ calling \Func{backtrace}() is linked against \Prog{libunwind}, it may end up calling \Func{unw\_backtrace}(). +In case you want to obtain the backtrace from a specific \Type{unw\_context\_t}, +you can call \Func{unw\_backtrace2} with that context passing \Const{0} for flag. +If the \Type{unw\_context_t} is known to be a signal frame (i.e., from the third argument +in a sigaction handler on linux), \Func{unw\_backtrace2} can be used to collect +only the frames before the signal frame passing the \Const{UNW\_INIT\_SIGNAL\_FRAME} flag. + \section{Return Value} The routine returns the number of addresses stored in the array pointed by
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/unw_get_proc_info.man -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_get_proc_info.man
Changed
@@ -1,5 +1,5 @@ '\" t -.\" Manual page created with latex2man on Thu Aug 16 09:44:44 MDT 2007 +.\" Manual page created with latex2man on Sun Aug 29 23:45:06 CEST 2021 .\" NOTE: This file is generated, DO NOT EDIT. .de Vb .ft CW @@ -10,7 +10,7 @@ .fi .. -.TH "UNW\\_GET\\_PROC\\_INFO" "3" "16 August 2007" "Programming Library " "Programming Library " +.TH "UNW\\_GET\\_PROC\\_INFO" "3" "29 August 2021" "Programming Library " "Programming Library " .SH NAME unw_get_proc_info \-\- get info on current procedure @@ -96,7 +96,7 @@ is equal to UNW_INFO_FORMAT_DYNAMIC\&. If the unwind\-info consists of a (target\-specific) unwind table, it is -equal to to UNW_INFO_FORMAT_TABLE\&. +equal to UNW_INFO_FORMAT_TABLE\&. All other values are reserved for future use by libunwind\&. This member exists @@ -138,7 +138,7 @@ Note that for the purposes of libunwind, the code of a procedure is assumed to occupy a single, contiguous range of -addresses. For this reason, it is alwas possible to describe the +addresses. For this reason, it is always possible to describe the extent of a procedure with the start_ip and end_ip members. If a single function/routine is split into multiple,
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/unw_get_proc_info.tex -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_get_proc_info.tex
Changed
@@ -53,7 +53,7 @@ procedure. If the unwind-info consists of dynamic procedure info, \Var{format} is equal to \Const{UNW\_INFO\_FORMAT\_DYNAMIC}. If the unwind-info consists of a (target-specific) unwind table, it is - equal to to \Const{UNW\_INFO\_FORMAT\_TABLE}. All other values are + equal to \Const{UNW\_INFO\_FORMAT\_TABLE}. All other values are reserved for future use by \Prog{libunwind}. This member exists for use by the \Func{find\_proc\_info}() call-back (see \Func{unw\_create\_addr\_space}(3)). The @@ -75,7 +75,7 @@ \end{description} Note that for the purposes of \Prog{libunwind}, the code of a procedure is assumed to occupy a single, contiguous range of -addresses. For this reason, it is alwas possible to describe the +addresses. For this reason, it is always possible to describe the extent of a procedure with the \Var{start\_ip} and \Var{end\_ip} members. If a single function/routine is split into multiple, discontiguous pieces, \Prog{libunwind} will treat each piece as a
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/unw_get_proc_info_by_ip.man -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_get_proc_info_by_ip.man
Changed
@@ -1,5 +1,5 @@ '\" t -.\" Manual page created with latex2man on Thu Aug 16 09:44:45 MDT 2007 +.\" Manual page created with latex2man on Sun Aug 29 23:45:06 CEST 2021 .\" NOTE: This file is generated, DO NOT EDIT. .de Vb .ft CW @@ -10,7 +10,7 @@ .fi .. -.TH "UNW\\_GET\\_PROC\\_INFO\\_BY\\_IP" "3" "16 August 2007" "Programming Library " "Programming Library " +.TH "UNW\\_GET\\_PROC\\_INFO\\_BY\\_IP" "3" "29 August 2021" "Programming Library " "Programming Library " .SH NAME unw_get_proc_info_by_ip \-\- get procedure info by IP @@ -42,7 +42,7 @@ is more flexible, it also tends to run slower (and often much slower) than unw_get_proc_info(). .PP -The routine expects the followins arguments: as +The routine expects the following arguments: as is the address\-space in which the instruction\-pointer should be looked up. For a look\-up in the local address\-space, @@ -68,7 +68,7 @@ Note that for the purposes of libunwind, the code of a procedure is assumed to occupy a single, contiguous range of -addresses. For this reason, it is alwas possible to describe the +addresses. For this reason, it is always possible to describe the extent of a procedure with the start_ip and end_ip members. If a single function/routine is split into multiple, @@ -86,7 +86,7 @@ .SH THREAD AND SIGNAL SAFETY .PP -unw_get_proc_info() +unw_get_proc_info_by_ip() is thread\-safe. If the local address\-space is passed in argument as, this routine is also @@ -108,9 +108,9 @@ The unwind\-info for the procedure has version or format that is not understood by libunwind\&. .PP -In addition, unw_get_proc_info() -may return any error -returned by the access_mem() +In addition, unw_get_proc_info_by_ip() +may return any +error returned by the access_mem() call\-back (see unw_create_addr_space(3)). .PP
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/unw_get_proc_info_by_ip.tex -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_get_proc_info_by_ip.tex
Changed
@@ -25,7 +25,7 @@ is more flexible, it also tends to run slower (and often much slower) than \Func{unw\_get\_proc\_info}(). -The routine expects the followins arguments: \Var{as} is the +The routine expects the following arguments: \Var{as} is the address-space in which the instruction-pointer should be looked up. For a look-up in the local address-space, \Var{unw\_local\_addr\_space} can be passed for this argument. @@ -41,7 +41,7 @@ Note that for the purposes of \Prog{libunwind}, the code of a procedure is assumed to occupy a single, contiguous range of -addresses. For this reason, it is alwas possible to describe the +addresses. For this reason, it is always possible to describe the extent of a procedure with the \Var{start\_ip} and \Var{end\_ip} members. If a single function/routine is split into multiple, discontiguous pieces, \Prog{libunwind} will treat each piece as a @@ -55,7 +55,7 @@ \section{Thread and Signal Safety} -\Func{unw\_get\_proc\_info}() is thread-safe. If the local +\Func{unw\_get\_proc\_info\_by\_ip}() is thread-safe. If the local address-space is passed in argument \Var{as}, this routine is also safe to use from a signal handler. @@ -68,8 +68,8 @@ \item\Const{UNW\_EBADVERSION} The unwind-info for the procedure has version or format that is not understood by \Prog{libunwind}. \end{Description} -In addition, \Func{unw\_get\_proc\_info}() may return any error -returned by the \Func{access\_mem}() call-back (see +In addition, \Func{unw\_get\_proc\_info\_by\_ip}() may return any +error returned by the \Func{access\_mem}() call-back (see \Func{unw\_create\_addr\_space}(3)). \section{See Also}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_get_proc_info_in_range.man
Added
@@ -0,0 +1,109 @@ +.\" *********************************** start of \input{common.tex} +.\" *********************************** end of \input{common.tex} +'\" t +.\" Manual page created with latex2man on Wed Jun 29 18:53:42 2022 +.\" NOTE: This file is generated, DO NOT EDIT. +.de Vb +.ft CW +.nf +.. +.de Ve +.ft R + +.fi +.. +.TH "UNW\\_GET\\_PROC\\_INFO\\_IN\\_RANGE" "3" "29 June 2022" "Programming Library " "Programming Library " +.SH NAME +unw_get_proc_info_in_range +\-\- get procedure info in IP range and a frame index table +.PP +.SH SYNOPSIS + +.PP +#include <libunwind.h> +.br +.PP +int +unw_get_proc_info_in_range(unw_word_t start_ip, +unw_word_t end_ip, +unw_word_t eh_frame_table, +unw_word_t eh_frame_table_len, +unw_word_t exidx_frame_table, +unw_word_t exidx_frame_table_len,, +unw_addr_space_t *as, +void *arg); +.br +.PP +.SH DESCRIPTION + +.PP +The unw_get_proc_info_in_range() +routine returns the same +kind of auxiliary information about a procedure as +unw_get_proc_info_by_ip(), +except that the info is looked up in +instruction\-pointer (IP) range and frame table instead of just at IP. This +is equally flexible because it is possible to look up the info for an arbitrary +procedure, even if it is not part of the current call\-chain. However, since it +is more flexible, it also tends to run slower (and often much slower) +than unw_get_proc_info(). +.PP +.SH RETURN VALUE + +.PP +On successful completion, unw_get_proc_info_in_range() +returns 0. Otherwise the negative value of one of the error\-codes +below is returned. +.PP +.SH THREAD AND SIGNAL SAFETY + +.PP +unw_get_proc_info_in_range() +is thread\-safe. If the local +address\-space is passed in argument as, +this routine is also +safe to use from a signal handler. +.PP +.SH ERRORS + +.PP +.TP +UNW_EUNSPEC + An unspecified error occurred. +.TP +UNW_ENOINFO + Libunwind +was unable to locate +unwind\-info for the procedure. +.TP +UNW_EBADVERSION + The unwind\-info for the procedure has +version or format that is not understood by libunwind\&. +.TP +UNW_EINVAL + An unsupported table encoding was specified. +.PP +In addition, unw_get_proc_info_by_ip() +may return any +error returned by the access_mem() +call\-back (see +unw_create_addr_space(3)). +.PP +.SH SEE ALSO + +.PP +libunwind(3), +unw_get_proc_info_in_range(3), +unw_create_addr_space(3), +unw_get_proc_name(3), +unw_get_proc_info(3) +.PP +.SH AUTHOR + +.PP +David Mosberger\-Tang +.br +Email: \fBdmosberger@gmail.com\fP +.br +WWW: \fBhttp://www.nongnu.org/libunwind/\fP\&. +.\" NOTE: This file is generated, DO NOT EDIT.
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_get_proc_info_in_range.tex
Added
@@ -0,0 +1,70 @@ +\documentclass{article} +\usepackagefancyhdr,pdf{latex2man} + +\input{common.tex} + +\begin{document} + +\begin{Name}{3}{unw\_get\_proc\_info\_in\_range}{David Mosberger-Tang}{Programming Library}{unw\_get\_proc\_info\_in\_range}unw\_get\_proc\_info\_in\_range -- get procedure info in IP range and a frame index table +\end{Name} + +\section{Synopsis} + +\File{\#include $<$libunwind.h$>$}\\ + +\Type{int} \Func{unw\_get\_proc\_info\_in\_range}(\Type{unw\_word\_t~}\Var{start_ip}, \Type{unw\_word\_t~}\Var{end_ip}, \Type{unw\_word\_t~}\Var{eh_frame_table}, \Type{unw\_word\_t~}\Var{eh_frame_table_len}, \Type{unw\_word\_t~}\Var{exidx_frame_table}, \Type{unw\_word\_t~}\Var{exidx_frame_table_len,}, \Type{unw\_addr\_space\_t~*}\Var{as}, \Type{void~*}\Var{arg});\\ + +\section{Description} + +The \Func{unw\_get\_proc\_info\_in\_range}() routine returns the same +kind of auxiliary information about a procedure as +\Func{unw\_get\_proc\_info\_by\_ip}(), except that the info is looked up in +instruction-pointer (IP) range and frame table instead of just at IP. This +is equally flexible because it is possible to look up the info for an arbitrary +procedure, even if it is not part of the current call-chain. However, since it +is more flexible, it also tends to run slower (and often much slower) +than \Func{unw\_get\_proc\_info}(). + +\section{Return Value} + +On successful completion, \Func{unw\_get\_proc\_info\_in\_range}() +returns 0. Otherwise the negative value of one of the error-codes +below is returned. + +\section{Thread and Signal Safety} + +\Func{unw\_get\_proc\_info\_in\_range}() is thread-safe. If the local +address-space is passed in argument \Var{as}, this routine is also +safe to use from a signal handler. + +\section{Errors} + +\begin{Description} +\item\Const{UNW\_EUNSPEC} An unspecified error occurred. +\item\Const{UNW\_ENOINFO} \Prog{Libunwind} was unable to locate + unwind-info for the procedure. +\item\Const{UNW\_EBADVERSION} The unwind-info for the procedure has + version or format that is not understood by \Prog{libunwind}. +\item\Const{UNW\_EINVAL} An unsupported table encoding was specified. +\end{Description} +In addition, \Func{unw\_get\_proc\_info\_by\_ip}() may return any +error returned by the \Func{access\_mem}() call-back (see +\Func{unw\_create\_addr\_space}(3)). + +\section{See Also} + +\SeeAlso{libunwind(3)}, +\SeeAlso{unw\_get\_proc\_info\_in\_range(3)}, +\SeeAlso{unw\_create\_addr\_space(3)}, +\SeeAlso{unw\_get\_proc\_name(3)}, +\SeeAlso{unw\_get\_proc\_info(3)} + +\section{Author} + +\noindent +David Mosberger-Tang\\ +Email: \Email{dmosberger@gmail.com}\\ +WWW: \URL{http://www.nongnu.org/libunwind/}. +\LatexManEnd + +\end{document}
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/unw_get_proc_name.man -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_get_proc_name.man
Changed
@@ -1,7 +1,5 @@ -.\" *********************************** start of \input{common.tex} -.\" *********************************** end of \input{common.tex} '\" t -.\" Manual page created with latex2man on Tue Nov 30 16:47:40 2021 +.\" Manual page created with latex2man on Sun Aug 29 23:45:06 CEST 2021 .\" NOTE: This file is generated, DO NOT EDIT. .de Vb .ft CW @@ -12,7 +10,7 @@ .fi .. -.TH "UNW\\_GET\\_PROC\\_NAME" "3" "30 November 2021" "Programming Library " "Programming Library " +.TH "UNW\\_GET\\_PROC\\_NAME" "3" "29 August 2021" "Programming Library " "Programming Library " .SH NAME unw_get_proc_name \-\- get name of current procedure @@ -61,7 +59,7 @@ information has been stripped from a program, procedure names may be completely unavailable or may be limited to those exported via a dynamic symbol table. In such cases, unw_get_proc_name() -may return the name of a label or a preceeding (nearby) procedure. +may return the name of a label or a preceding (nearby) procedure. However, the offset returned through offp is always relative to the returned name, which ensures that the value (address) of the
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/unw_get_proc_name.tex -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_get_proc_name.tex
Changed
@@ -34,7 +34,7 @@ information has been stripped from a program, procedure names may be completely unavailable or may be limited to those exported via a dynamic symbol table. In such cases, \Func{unw\_get\_proc\_name}() -may return the name of a label or a preceeding (nearby) procedure. +may return the name of a label or a preceding (nearby) procedure. However, the offset returned through \Var{offp} is always relative to the returned name, which ensures that the value (address) of the returned name plus the returned offset will always be equal to the
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_get_proc_name_by_ip.man
Added
@@ -0,0 +1,139 @@ +'\" t +.\" Manual page created with latex2man on Mon Aug 30 08:48:42 CEST 2021 +.\" NOTE: This file is generated, DO NOT EDIT. +.de Vb +.ft CW +.nf +.. +.de Ve +.ft R + +.fi +.. +.TH "UNW\\_GET\\_PROC\\_NAME\\_BY\\_IP" "3" "30 August 2021" "Programming Library " "Programming Library " +.SH NAME +unw_get_proc_name_by_ip +\-\- get procedure name +.PP +.SH SYNOPSIS + +.PP +#include <libunwind.h> +.br +.PP +int +unw_get_proc_name_by_ip(unw_addr_space_t as, +unw_word_t ip, +char *bufp, +size_t +len, +unw_word_t *offp, +void *arg); +.br +.PP +.SH DESCRIPTION + +.PP +The unw_get_proc_name_by_ip() +routine returns the name of +a procedure just like unw_get_proc_name(), +except that the +name is looked up by instruction\-pointer (IP) instead of a cursor. +.PP +The routine expects the following arguments: as +is the +address\-space in which the instruction\-pointer should be looked up. +For a look\-up in the local address\-space, +unw_local_addr_space +can be passed for this argument. +Argument ip +is the instruction\-pointer for which the procedure +name should be looked up. The bufp +argument is a pointer to +a character buffer that is at least len +bytes long. This buffer +is used to return the name of the procedure. The offp +argument +is a pointer to a word that is used to return the byte\-offset of the +instruction\-pointer relative to the start of the procedure. +Lastly, arg +is the address\-space argument that should be used +when accessing the address\-space. It has the same purpose as the +argument of the same name for unw_init_remote(). +When +accessing the local address\-space (first argument is +unw_local_addr_space), +NULL +must be passed for this +argument. +.PP +Note that on some platforms there is no reliable way to distinguish +between procedure names and ordinary labels. Furthermore, if symbol +information has been stripped from a program, procedure names may be +completely unavailable or may be limited to those exported via a +dynamic symbol table. In such cases, +unw_get_proc_name_by_ip() +may return the name of a label +or a preceding (nearby) procedure. However, the offset returned +through offp +is always relative to the returned name, which +ensures that the value (address) of the returned name plus the +returned offset will always be equal to the instruction\-pointer +ip\&. +.PP +.SH RETURN VALUE + +.PP +On successful completion, unw_get_proc_name_by_ip() +returns 0. Otherwise the negative value of one of the error\-codes +below is returned. +.PP +.SH THREAD AND SIGNAL SAFETY + +.PP +unw_get_proc_name_by_ip() +is thread\-safe. If the local +address\-space is passed in argument as, +this routine is also +safe to use from a signal handler. +.PP +.SH ERRORS + +.PP +.TP +UNW_EUNSPEC + An unspecified error occurred. +.TP +UNW_ENOINFO + Libunwind +was unable to determine +the name of the procedure. +.TP +UNW_ENOMEM + The procedure name is too long to fit +in the buffer provided. A truncated version of the name has been +returned. +.PP +In addition, unw_get_proc_name_by_ip() +may return any error +returned by the access_mem() +call\-back (see +unw_create_addr_space(3)). +.PP +.SH SEE ALSO + +.PP +libunwind(3), +unw_create_addr_space(3), +unw_get_proc_name(3), +unw_init_remote(3) +.PP +.SH AUTHOR + +.PP +David Mosberger\-Tang +.br +Email: \fBdmosberger@gmail.com\fP +.br +WWW: \fBhttp://www.nongnu.org/libunwind/\fP\&. +.\" NOTE: This file is generated, DO NOT EDIT.
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_get_proc_name_by_ip.tex
Added
@@ -0,0 +1,93 @@ +\documentclass{article} +\usepackagefancyhdr,pdf{latex2man} + +\input{common.tex} + +\begin{document} + +\begin{Name}{3}{unw\_get\_proc\_name\_by\_ip}{David Mosberger-Tang}{Programming Library}{unw\_get\_proc\_name}unw\_get\_proc\_name\_by\_ip -- get procedure name +\end{Name} + +\section{Synopsis} + +\File{\#include $<$libunwind.h$>$}\\ + +\Type{int} \Func{unw\_get\_proc\_name\_by\_ip}(\Type{unw\_addr\_space\_t~}\Var{as}, \Type{unw\_word\_t~}\Var{ip}, \Type{char~*}\Var{bufp}, \Type{size\_t} \Var{len}, \Type{unw\_word\_t~*}\Var{offp}, \Type{void~*}\Var{arg});\\ + +\section{Description} + +The \Func{unw\_get\_proc\_name\_by\_ip}() routine returns the name of +a procedure just like \Func{unw\_get\_proc\_name}(), except that the +name is looked up by instruction-pointer (IP) instead of a cursor. + +The routine expects the following arguments: \Var{as} is the +address-space in which the instruction-pointer should be looked up. +For a look-up in the local address-space, +\Var{unw\_local\_addr\_space} can be passed for this argument. +Argument \Var{ip} is the instruction-pointer for which the procedure +name should be looked up. The \Var{bufp} argument is a pointer to +a character buffer that is at least \Var{len} bytes long. This buffer +is used to return the name of the procedure. The \Var{offp} argument +is a pointer to a word that is used to return the byte-offset of the +instruction-pointer relative to the start of the procedure. +Lastly, \Var{arg} is the address-space argument that should be used +when accessing the address-space. It has the same purpose as the +argument of the same name for \Func{unw\_init\_remote}(). When +accessing the local address-space (first argument is +\Var{unw\_local\_addr\_space}), \Const{NULL} must be passed for this +argument. + +Note that on some platforms there is no reliable way to distinguish +between procedure names and ordinary labels. Furthermore, if symbol +information has been stripped from a program, procedure names may be +completely unavailable or may be limited to those exported via a +dynamic symbol table. In such cases, +\Func{unw\_get\_proc\_name\_by\_ip}() may return the name of a label +or a preceding (nearby) procedure. However, the offset returned +through \Var{offp} is always relative to the returned name, which +ensures that the value (address) of the returned name plus the +returned offset will always be equal to the instruction-pointer +\Var{ip}. + +\section{Return Value} + +On successful completion, \Func{unw\_get\_proc\_name\_by\_ip}() +returns 0. Otherwise the negative value of one of the error-codes +below is returned. + +\section{Thread and Signal Safety} + +\Func{unw\_get\_proc\_name\_by\_ip}() is thread-safe. If the local +address-space is passed in argument \Var{as}, this routine is also +safe to use from a signal handler. + +\section{Errors} + +\begin{Description} +\item\Const{UNW\_EUNSPEC} An unspecified error occurred. +\item\Const{UNW\_ENOINFO} \Prog{Libunwind} was unable to determine + the name of the procedure. +\item\Const{UNW\_ENOMEM} The procedure name is too long to fit + in the buffer provided. A truncated version of the name has been + returned. +\end{Description} +In addition, \Func{unw\_get\_proc\_name\_by\_ip}() may return any error +returned by the \Func{access\_mem}() call-back (see +\Func{unw\_create\_addr\_space}(3)). + +\section{See Also} + +\SeeAlso{libunwind(3)}, +\SeeAlso{unw\_create\_addr\_space(3)}, +\SeeAlso{unw\_get\_proc\_name(3)}, +\SeeAlso{unw\_init\_remote(3)} + +\section{Author} + +\noindent +David Mosberger-Tang\\ +Email: \Email{dmosberger@gmail.com}\\ +WWW: \URL{http://www.nongnu.org/libunwind/}. +\LatexManEnd + +\end{document}
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/unw_init_local.man -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_init_local.man
Changed
@@ -1,5 +1,5 @@ '\" t -.\" Manual page created with latex2man on Wed Aug 16 12:11:05 PDT 2017 +.\" Manual page created with latex2man on Sun Aug 29 23:45:06 CEST 2021 .\" NOTE: This file is generated, DO NOT EDIT. .de Vb .ft CW @@ -10,7 +10,7 @@ .fi .. -.TH "UNW\\_INIT\\_LOCAL" "3" "16 August 2017" "Programming Library " "Programming Library " +.TH "UNW\\_INIT\\_LOCAL" "3" "29 August 2021" "Programming Library " "Programming Library " .SH NAME unw_init_local \-\- initialize cursor for local unwinding @@ -44,11 +44,13 @@ ctxt identifies the initial stack frame at which unwinding starts. The machine\-state is expected to be one provided by a call to -unw_getcontext; as such, the instruction pointer may point to the -instruction after the last instruction of a function, and libunwind -will back\-up the instruction pointer before beginning a walk up the -call stack. The machine\-state must remain valid for the duration for -which the cursor c +unw_getcontext(); +as such, the instruction pointer may point to +the instruction after the last instruction of a function, and +libunwind +will back\-up the instruction pointer before beginning +a walk up the call stack. The machine\-state must remain valid for the +duration for which the cursor c is in use. .PP The unw_init_local() @@ -66,11 +68,13 @@ whereas unw_init_remote() is not. .PP -If the unw_context_t is known to be a signal frame (i.e., from the -third argument in a sigaction handler on linux), +If the unw_context_t +is known to be a signal frame (i.e., +from the third argument in a sigaction handler on linux), unw_init_local2() should be used for correct initialization -on some platforms, passing the UNW_INIT_SIGNAL_FRAME flag. +on some platforms, passing the UNW_INIT_SIGNAL_FRAME +flag. .PP .SH RETURN VALUE
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/unw_init_local.tex -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_init_local.tex
Changed
@@ -22,11 +22,11 @@ pointed to by \Var{ctxt}. As such, the machine-state pointed to by \Var{ctxt} identifies the initial stack frame at which unwinding starts. The machine-state is expected to be one provided by a call to -unw_getcontext; as such, the instruction pointer may point to the -instruction after the last instruction of a function, and libunwind -will back-up the instruction pointer before beginning a walk up the -call stack. The machine-state must remain valid for the duration for -which the cursor \Var{c} is in use. +\Func{unw\_getcontext}(); as such, the instruction pointer may point to +the instruction after the last instruction of a function, and +\Prog{libunwind} will back-up the instruction pointer before beginning +a walk up the call stack. The machine-state must remain valid for the +duration for which the cursor \Var{c} is in use. The \Func{unw\_init\_local}() routine can be used only for unwinding in the address space of the current process (i.e., for local unwinding). @@ -37,10 +37,10 @@ including \File{$<$libunwind.h$>$}, whereas \Func{unw\_init\_remote}() is not. -If the unw_context_t is known to be a signal frame (i.e., from the -third argument in a sigaction handler on linux), +If the \Type{unw\_context\_t} is known to be a signal frame (i.e., +from the third argument in a sigaction handler on linux), \Func{unw\_init\_local2}() should be used for correct initialization -on some platforms, passing the UNW_INIT_SIGNAL_FRAME flag. +on some platforms, passing the \Const{UNW\_INIT\_SIGNAL\_FRAME} flag. \section{Return Value}
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/unw_reg_states_iterate.man -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_reg_states_iterate.man
Changed
@@ -1,5 +1,5 @@ '\" t -.\" Manual page created with latex2man on Wed Aug 16 11:09:44 PDT 2017 +.\" Manual page created with latex2man on Sun Aug 29 23:45:06 CEST 2021 .\" NOTE: This file is generated, DO NOT EDIT. .de Vb .ft CW @@ -10,7 +10,7 @@ .fi .. -.TH "UNW\\_REG\\_STATES\\_ITERATE" "3" "16 August 2017" "Programming Library " "Programming Library " +.TH "UNW\\_REG\\_STATES\\_ITERATE" "3" "29 August 2021" "Programming Library " "Programming Library " .SH NAME unw_reg_states_iterate \-\- get register state info on current procedure @@ -53,7 +53,7 @@ end_ip); .PP The callback function may be invoked several times for each call of unw_reg_states_iterate\&. -Each call is associcated with a instruction address range and a set of instructions on how to update register values when returning from the procedure in that address range. For each invocation, the arguments to the callback function are: +Each call is associated with an instruction address range and a set of instructions on how to update register values when returning from the procedure in that address range. For each invocation, the arguments to the callback function are: .TP void * token The token value passed to unw_reg_states_callback\&.
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/doc/unw_reg_states_iterate.tex -> _service:tar_scm:libunwind-1.7.2.tar.gz/doc/unw_reg_states_iterate.tex
Changed
@@ -28,7 +28,7 @@ \Type{size\_t} \Var{reg\_states\_data\_size}, \Type{unw\_word\_t} \Var{start\_ip}, \Type{unw\_word\_t} \Var{end\_ip}); -The callback function may be invoked several times for each call of \Func{unw\_reg\_states\_iterate}. Each call is associcated with a instruction address range and a set of instructions on how to update register values when returning from the procedure in that address range. For each invocation, the arguments to the callback function are: +The callback function may be invoked several times for each call of \Func{unw\_reg\_states\_iterate}. Each call is associated with an instruction address range and a set of instructions on how to update register values when returning from the procedure in that address range. For each invocation, the arguments to the callback function are: \begin{description} \item\Type{void~*} \Var{token} The token value passed to \Var{unw\_reg\_states\_callback}. \\ \item\Type{void~*} \Var{reg\_states\_data} A pointer to data about
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/config.h.in -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/config.h.in
Changed
@@ -21,6 +21,9 @@ /* Define to 1 if you have the <asm/ptrace_offsets.h> header file. */ #undef HAVE_ASM_PTRACE_OFFSETS_H +/* Define to 1 if you have the <asm/vsyscall.h> header file. */ +#undef HAVE_ASM_VSYSCALL_H + /* Define to 1 if you have the <byteswap.h> header file. */ #undef HAVE_BYTESWAP_H @@ -92,6 +95,9 @@ /* Define to 1 if you have the `dl_phdr_removals_counter' function. */ #undef HAVE_DL_PHDR_REMOVALS_COUNTER +/* Define to 1 if the system has the type `elf_fpregset_t'. */ +#undef HAVE_ELF_FPREGSET_T + /* Define to 1 if you have the <elf.h> header file. */ #undef HAVE_ELF_H @@ -128,6 +134,12 @@ /* Define to 1 if you have the `pipe2' function. */ #undef HAVE_PIPE2 +/* Define to 1 if the system has the type `procfs_status'. */ +#undef HAVE_PROCFS_STATUS + +/* Define to 1 if you have the `sigaltstack' function. */ +#undef HAVE_SIGALTSTACK + /* Define to 1 if you have the <signal.h> header file. */ #undef HAVE_SIGNAL_H
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/dwarf.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/dwarf.h
Changed
@@ -231,6 +231,7 @@ DWARF_WHERE_REG, /* register saved in another register */ DWARF_WHERE_EXPR, /* register saved */ DWARF_WHERE_VAL_EXPR, /* register has computed value */ + DWARF_WHERE_CFA, /* register is set to the computed cfa value */ } dwarf_where_t; @@ -313,7 +314,7 @@ void *as_arg; /* argument to address-space callbacks */ unw_addr_space_t as; /* reference to per-address-space info */ - unw_word_t cfa; /* canonical frame address; aka frame-/stack-pointer */ + unw_word_t cfa; /* canonical frame address; aka frame-pointer */ unw_word_t ip; /* instruction pointer */ unw_word_t args_size; /* size of arguments */ unw_word_t eh_argsUNW_TDEP_NUM_EH_REGS; @@ -421,7 +422,7 @@ int need_unwind_info, void *arg); extern int dwarf_find_unwind_table (struct elf_dyn_info *edi, unw_addr_space_t as, - char *path, unw_word_t segbase, unw_word_t mapoff, + const char *path, unw_word_t segbase, unw_word_t mapoff, unw_word_t ip); extern void dwarf_put_unwind_info (unw_addr_space_t as, unw_proc_info_t *pi, void *arg);
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/dwarf_i.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/dwarf_i.h
Changed
@@ -136,7 +136,7 @@ dwarf_readu8 (unw_addr_space_t as, unw_accessors_t *a, unw_word_t *addr, uint8_t *valp, void *arg) { - unw_word_t val, aligned_addr = *addr & -sizeof (unw_word_t); + unw_word_t val, aligned_addr = *addr & (~sizeof (unw_word_t) + 1); unw_word_t off = *addr - aligned_addr; int ret;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/libunwind-aarch64.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/libunwind-aarch64.h
Changed
@@ -37,11 +37,7 @@ #include <stdalign.h> #ifndef UNW_EMPTY_STRUCT -# ifdef __GNUC__ -# define UNW_EMPTY_STRUCT -# else -# define UNW_EMPTY_STRUCT uint8_t unused; -# endif +# define UNW_EMPTY_STRUCT uint8_t unused; #endif #define UNW_TARGET aarch64 @@ -123,6 +119,12 @@ UNW_AARCH64_PC, UNW_AARCH64_PSTATE, + /* Pseudo-register */ + UNW_AARCH64_RA_SIGN_STATE = 34, + + /* SVE Vector Granule pseudo register */ + UNW_AARCH64_VG = 46, + /* 128-bit FP/Advanced SIMD registers. */ UNW_AARCH64_V0 = 64, UNW_AARCH64_V1, @@ -168,7 +170,7 @@ UNW_TDEP_IP = UNW_AARCH64_X30, UNW_TDEP_SP = UNW_AARCH64_SP, - UNW_TDEP_EH = UNW_AARCH64_X0, + UNW_TDEP_EH = UNW_AARCH64_X0 } aarch64_regnum_t; @@ -226,15 +228,24 @@ #else /* On AArch64, we can directly use ucontext_t as the unwind context. */ typedef ucontext_t unw_tdep_context_t; +#if defined(__FreeBSD__) +typedef ucontext_t unw_fpsimd_context_t; +#endif #endif #include "libunwind-common.h" #include "libunwind-dynamic.h" +#if defined(__FreeBSD__) +#define UNW_BASE register uint64_t unw_base __asm__ ("x0") = (uint64_t) unw_ctx->uc_mcontext.mc_gpregs.gp_x0; +#else +#define UNW_BASE register uint64_t unw_base __asm__ ("x0") = (uint64_t) unw_ctx->uc_mcontext.regs; +#endif + #define unw_tdep_getcontext(uc) ({ \ unw_tdep_context_t *unw_ctx = (uc); \ - register uint64_t unw_base __asm__ ("x0") = (uint64_t) unw_ctx->uc_mcontext.regs; \ + UNW_BASE \ __asm__ __volatile__ ( \ "stp x0, x1, %base, #0\n" \ "stp x2, x3, %base, #16\n" \ @@ -243,7 +254,7 @@ "stp x8, x9, %base, #64\n" \ "stp x10, x11, %base, #80\n" \ "stp x12, x13, %base, #96\n" \ - "stp x14, x13, %base, #112\n" \ + "stp x14, x15, %base, #112\n" \ "stp x16, x17, %base, #128\n" \ "stp x18, x19, %base, #144\n" \ "stp x20, x21, %base, #160\n" \
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/libunwind-arm.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/libunwind-arm.h
Changed
@@ -33,11 +33,7 @@ #include <stddef.h> #ifndef UNW_EMPTY_STRUCT -# ifdef __GNUC__ -# define UNW_EMPTY_STRUCT -# else -# define UNW_EMPTY_STRUCT uint8_t unused; -# endif +# define UNW_EMPTY_STRUCT uint8_t unused; #endif #define UNW_TARGET arm @@ -50,7 +46,7 @@ require recompiling all users of this library. Stack allocation is relatively cheap and unwind-state copying is relatively rare, so we want to err on making it rather too big than too small. */ - + /* FIXME for ARM. Too big? What do other things use for similar tasks? */ #define UNW_TDEP_CURSOR_LEN 4096 @@ -77,7 +73,7 @@ UNW_ARM_R13, UNW_ARM_R14, UNW_ARM_R15, - + /* VFPv2 s0-s31 (obsolescent numberings). */ UNW_ARM_S0 = 64, UNW_ARM_S1, @@ -111,7 +107,7 @@ UNW_ARM_S29, UNW_ARM_S30, UNW_ARM_S31, - + /* FPA register numberings. */ UNW_ARM_F0 = 96, UNW_ARM_F1, @@ -121,7 +117,7 @@ UNW_ARM_F5, UNW_ARM_F6, UNW_ARM_F7, - + /* iWMMXt GR register numberings. */ UNW_ARM_wCGR0 = 104, UNW_ARM_wCGR1, @@ -131,7 +127,7 @@ UNW_ARM_wCGR5, UNW_ARM_wCGR6, UNW_ARM_wCGR7, - + /* iWMMXt register numberings. */ UNW_ARM_wR0 = 112, UNW_ARM_wR1, @@ -149,9 +145,9 @@ UNW_ARM_wR13, UNW_ARM_wR14, UNW_ARM_wR15, - + /* Two-byte encodings from here on. */ - + /* SPSR. */ UNW_ARM_SPSR = 128, UNW_ARM_SPSR_FIQ, @@ -159,7 +155,7 @@ UNW_ARM_SPSR_ABT, UNW_ARM_SPSR_UND, UNW_ARM_SPSR_SVC, - + /* User mode registers. */ UNW_ARM_R8_USR = 144, UNW_ARM_R9_USR, @@ -168,7 +164,7 @@ UNW_ARM_R12_USR, UNW_ARM_R13_USR, UNW_ARM_R14_USR, - + /* FIQ registers. */ UNW_ARM_R8_FIQ = 151, UNW_ARM_R9_FIQ, @@ -177,23 +173,23 @@ UNW_ARM_R12_FIQ, UNW_ARM_R13_FIQ, UNW_ARM_R14_FIQ, - + /* IRQ registers. */ UNW_ARM_R13_IRQ = 158, UNW_ARM_R14_IRQ, - + /* ABT registers. */ UNW_ARM_R13_ABT = 160, UNW_ARM_R14_ABT, - + /* UND registers. */ UNW_ARM_R13_UND = 162, UNW_ARM_R14_UND, - + /* SVC registers. */ UNW_ARM_R13_SVC = 164, UNW_ARM_R14_SVC, - + /* iWMMXt control registers. */ UNW_ARM_wC0 = 192, UNW_ARM_wC1, @@ -265,6 +261,7 @@ typedef struct unw_tdep_context { unsigned long regs16; + unsigned long long fpregs16; } unw_tdep_context_t; @@ -272,37 +269,45 @@ may be sufficient for all libunwind use cases. In thumb mode, we return directly back to thumb mode on return (with bx), to avoid altering any registers after unw_resume. */ + +#ifdef __SOFTFP__ +#define VSTMIA "nop\n" /* align return address to value stored by stmia */ +#else +#define VSTMIA "vstmia %base, {d0-d15}\n" /* this also aligns return address to value stored by stmia */ +#endif + #ifndef __thumb__ -#define unw_tdep_getcontext(uc) ({ \ - unw_tdep_context_t *unw_ctx = (uc); \ - register unsigned long *r0 __asm__ ("r0"); \ - unsigned long *unw_base = unw_ctx->regs; \ - __asm__ __volatile__ ( \ - "mov r0, #0\n" \ - "stmia %base, {r0-r15}\n" \ - "nop\n" /* align return address to value stored by stmia */ \ - : r0 "=r" (r0) : base "r" (unw_base) : "memory"); \ +#define unw_tdep_getcontext(uc) ({ \ + unw_tdep_context_t *unw_ctx = (uc); \ + register unsigned long *r0 __asm__ ("r0"); \ + register unsigned long *unw_base __asm__ ("r1") = unw_ctx->regs; \ + __asm__ __volatile__ ( \ + "mov r0, #0\n" \ + "stmia %base!, {r0-r15}\n" \ + VSTMIA \ + : r0 "=r" (r0) : base "r" (unw_base) : "memory"); \ (int)r0; }) #else /* __thumb__ */ -#define unw_tdep_getcontext(uc) ({ \ - unw_tdep_context_t *unw_ctx = (uc); \ - register unsigned long *r0 __asm__ ("r0"); \ - unsigned long *unw_base = unw_ctx->regs; \ - __asm__ __volatile__ ( \ - ".align 2\n" \ - "bx pc\n" \ - "nop\n" \ - ".code 32\n" \ - "mov r0, #0\n" \ - "stmia %base, {r0-r14}\n" \ - "adr r0, ret%=+1\n" \ - "str r0, %base, #60\n" \ - "orr r0, pc, #1\n" \ - "bx r0\n" \ - ".code 16\n" \ - "mov r0, #0\n" \ - "ret%=:\n" \ - : r0 "=r" (r0) : base "r" (unw_base) : "memory", "cc"); \ +#define unw_tdep_getcontext(uc) ({ \ + unw_tdep_context_t *unw_ctx = (uc); \ + register unsigned long *r0 __asm__ ("r0"); \ + register unsigned long *unw_base __asm__ ("r1") = unw_ctx->regs; \ + __asm__ __volatile__ ( \ + ".align 2\n" \ + "bx pc\n" \ + "nop\n" \ + ".code 32\n" \ + "mov r0, #0\n" \ + "stmia %base, {r0-r14}\n" \ + "adr r0, ret%=+1\n" \ + "stmia %base!, {r0}\n" \ + VSTMIA \ + "orr r0, pc, #1\n" \ + "bx r0\n" \ + ".code 16\n" \ + "mov r0, #0\n" \ + "ret%=:\n" \ + : r0 "=r" (r0), base "+r" (unw_base) : : "memory", "cc"); \ (int)r0; }) #endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/libunwind-common.h.in -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/libunwind-common.h.in
Changed
@@ -101,7 +101,7 @@ typedef enum { - UNW_INIT_SIGNAL_FRAME = 1, /* We know this is a signal frame */ + UNW_INIT_SIGNAL_FRAME = 1 /* We know this is a signal frame */ } unw_init_local2_flags_t; @@ -207,6 +207,24 @@ NULL. */ int (*get_proc_name) (unw_addr_space_t, unw_word_t, char *, size_t, unw_word_t *, void *); + + /* Optional call back to return a mask to be used with pointer + * authentication on arm64. + * + * The on bits in the returned mask indicate which bits in a return address + * are part of a pointer authentication code. These are the bits in the + * return address to turn off so that the calling frame can be found + * for the unwinding to continue. + * + * The return value must be host-endian. e.g. if the target is big-endian + * and the host is little endian, the implementation of this function + * must byte swap. + * + * This callback is optional and may be set to NULL. In this case all + * the bits in the return address are used, as if no masking were done. + */ + unw_word_t (*ptrauth_insn_mask) (unw_addr_space_t, void *); + } unw_accessors_t; @@ -233,32 +251,34 @@ /* These routines work both for local and remote unwinding. */ -#define unw_local_addr_space UNW_OBJ(local_addr_space) -#define unw_create_addr_space UNW_OBJ(create_addr_space) -#define unw_destroy_addr_space UNW_OBJ(destroy_addr_space) -#define unw_get_accessors UNW_ARCH_OBJ(get_accessors) -#define unw_get_accessors_int UNW_ARCH_OBJ(get_accessors_int) -#define unw_init_local UNW_OBJ(init_local) -#define unw_init_local2 UNW_OBJ(init_local2) -#define unw_init_remote UNW_OBJ(init_remote) -#define unw_step UNW_OBJ(step) -#define unw_resume UNW_OBJ(resume) -#define unw_get_proc_info UNW_OBJ(get_proc_info) -#define unw_get_proc_info_by_ip UNW_OBJ(get_proc_info_by_ip) -#define unw_reg_states_iterate UNW_OBJ(reg_states_iterate) -#define unw_apply_reg_state UNW_OBJ(apply_reg_state) -#define unw_get_reg UNW_OBJ(get_reg) -#define unw_set_reg UNW_OBJ(set_reg) -#define unw_get_fpreg UNW_OBJ(get_fpreg) -#define unw_set_fpreg UNW_OBJ(set_fpreg) -#define unw_get_save_loc UNW_OBJ(get_save_loc) -#define unw_is_signal_frame UNW_OBJ(is_signal_frame) -#define unw_get_proc_name UNW_OBJ(get_proc_name) -#define unw_set_caching_policy UNW_OBJ(set_caching_policy) -#define unw_set_cache_size UNW_OBJ(set_cache_size) -#define unw_regname UNW_ARCH_OBJ(regname) -#define unw_flush_cache UNW_ARCH_OBJ(flush_cache) -#define unw_strerror UNW_ARCH_OBJ(strerror) +#define unw_local_addr_space UNW_OBJ(local_addr_space) +#define unw_create_addr_space UNW_OBJ(create_addr_space) +#define unw_destroy_addr_space UNW_OBJ(destroy_addr_space) +#define unw_get_accessors UNW_ARCH_OBJ(get_accessors) +#define unw_get_accessors_int UNW_ARCH_OBJ(get_accessors_int) +#define unw_init_local UNW_OBJ(init_local) +#define unw_init_local2 UNW_OBJ(init_local2) +#define unw_init_remote UNW_OBJ(init_remote) +#define unw_step UNW_OBJ(step) +#define unw_resume UNW_OBJ(resume) +#define unw_get_proc_info UNW_OBJ(get_proc_info) +#define unw_get_proc_info_by_ip UNW_OBJ(get_proc_info_by_ip) +#define unw_get_proc_info_in_range UNW_OBJ(get_proc_info_in_range) +#define unw_reg_states_iterate UNW_OBJ(reg_states_iterate) +#define unw_apply_reg_state UNW_OBJ(apply_reg_state) +#define unw_get_reg UNW_OBJ(get_reg) +#define unw_set_reg UNW_OBJ(set_reg) +#define unw_get_fpreg UNW_OBJ(get_fpreg) +#define unw_set_fpreg UNW_OBJ(set_fpreg) +#define unw_get_save_loc UNW_OBJ(get_save_loc) +#define unw_is_signal_frame UNW_OBJ(is_signal_frame) +#define unw_get_proc_name UNW_OBJ(get_proc_name) +#define unw_get_proc_name_by_ip UNW_OBJ(get_proc_name_by_ip) +#define unw_set_caching_policy UNW_OBJ(set_caching_policy) +#define unw_set_cache_size UNW_OBJ(set_cache_size) +#define unw_regname UNW_ARCH_OBJ(regname) +#define unw_flush_cache UNW_ARCH_OBJ(flush_cache) +#define unw_strerror UNW_ARCH_OBJ(strerror) extern unw_addr_space_t unw_create_addr_space (unw_accessors_t *, int); extern void unw_destroy_addr_space (unw_addr_space_t); @@ -277,6 +297,12 @@ extern int unw_get_proc_info (unw_cursor_t *, unw_proc_info_t *); extern int unw_get_proc_info_by_ip (unw_addr_space_t, unw_word_t, unw_proc_info_t *, void *); +extern int unw_get_proc_info_in_range (unw_word_t, unw_word_t, + unw_word_t, unw_word_t, + unw_word_t, unw_word_t, + unw_addr_space_t, unw_word_t, + unw_proc_info_t *, int, + void *); extern int unw_reg_states_iterate (unw_cursor_t *, unw_reg_states_callback, void *); extern int unw_apply_reg_state (unw_cursor_t *, void *); extern int unw_get_reg (unw_cursor_t *, int, unw_word_t *); @@ -286,7 +312,10 @@ extern int unw_get_save_loc (unw_cursor_t *, int, unw_save_loc_t *); extern int unw_is_signal_frame (unw_cursor_t *); extern int unw_get_proc_name (unw_cursor_t *, char *, size_t, unw_word_t *); +extern int unw_get_proc_name_by_ip (unw_addr_space_t, unw_word_t, char *, + size_t, unw_word_t *, void *); extern const char *unw_strerror (int); extern int unw_backtrace (void **, int); +extern int unw_backtrace2 (void **, int, unw_context_t*, int); extern unw_addr_space_t unw_local_addr_space;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/libunwind-dynamic.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/libunwind-dynamic.h
Changed
@@ -77,7 +77,7 @@ UNW_INFO_FORMAT_TABLE, /* unw_dyn_table_t */ UNW_INFO_FORMAT_REMOTE_TABLE, /* unw_dyn_remote_table_t */ UNW_INFO_FORMAT_ARM_EXIDX, /* ARM specific unwind info */ - UNW_INFO_FORMAT_IP_OFFSET, /* Like UNW_INFO_FORMAT_REMOTE_TABLE, but + UNW_INFO_FORMAT_IP_OFFSET /* Like UNW_INFO_FORMAT_REMOTE_TABLE, but table entries are considered relative to di->start_ip, rather than di->segbase */
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/include/libunwind-loongarch64.h
Added
@@ -0,0 +1,139 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2001-2004 Hewlett-Packard Co + Contributed by David Mosberger-Tang <davidm@hpl.hp.com> + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#ifndef LIBUNWIND_H +#define LIBUNWIND_H + +#if defined(__cplusplus) || defined(c_plusplus) +extern "C" { +#endif + +#include <inttypes.h> +#include <ucontext.h> + +#define UNW_TARGET loongarch64 +#define UNW_TARGET_LOONGARCH64 1 + +#define _U_TDEP_QP_TRUE 0 /* see libunwind-dynamic.h */ + +/* This needs to be big enough to accommodate "struct cursor", while + leaving some slack for future expansion. Changing this value will + require recompiling all users of this library. Stack allocation is + relatively cheap and unwind-state copying is relatively rare, so we + want to err on making it rather too big than too small. */ + +/* FIXME for LoongArch64. Too big? What do other things use for similar tasks? */ +#define UNW_TDEP_CURSOR_LEN 4096 + +typedef uint64_t unw_word_t; +typedef int64_t unw_sword_t; + +typedef long double unw_tdep_fpreg_t; + +typedef enum + { + UNW_LOONGARCH64_R0, + UNW_LOONGARCH64_R1, + UNW_LOONGARCH64_R2, + UNW_LOONGARCH64_R3, + UNW_LOONGARCH64_R4, + UNW_LOONGARCH64_R5, + UNW_LOONGARCH64_R6, + UNW_LOONGARCH64_R7, + UNW_LOONGARCH64_R8, + UNW_LOONGARCH64_R9, + UNW_LOONGARCH64_R10, + UNW_LOONGARCH64_R11, + UNW_LOONGARCH64_R12, + UNW_LOONGARCH64_R13, + UNW_LOONGARCH64_R14, + UNW_LOONGARCH64_R15, + UNW_LOONGARCH64_R16, + UNW_LOONGARCH64_R17, + UNW_LOONGARCH64_R18, + UNW_LOONGARCH64_R19, + UNW_LOONGARCH64_R20, + UNW_LOONGARCH64_R21, + UNW_LOONGARCH64_R22, + UNW_LOONGARCH64_R23, + UNW_LOONGARCH64_R24, + UNW_LOONGARCH64_R25, + UNW_LOONGARCH64_R26, + UNW_LOONGARCH64_R27, + UNW_LOONGARCH64_R28, + UNW_LOONGARCH64_R29, + UNW_LOONGARCH64_R30, + UNW_LOONGARCH64_R31, + + UNW_LOONGARCH64_PC = 33, + + /* FIXME: Other registers! */ + + /* For LoongArch64, the CFA is the value of SP (r3) at the call site in the + previous frame. */ + UNW_LOONGARCH64_CFA, + + UNW_TDEP_LAST_REG = UNW_LOONGARCH64_PC, + + UNW_TDEP_IP = UNW_LOONGARCH64_R1, + UNW_TDEP_SP = UNW_LOONGARCH64_R3, + UNW_TDEP_EH = UNW_LOONGARCH64_R0 /* FIXME. */ + } +loongarch64_regnum_t; + +#define UNW_TDEP_NUM_EH_REGS 4 + +typedef struct unw_tdep_save_loc + { + /* Additional target-dependent info on a save location. */ + char unused; + } +unw_tdep_save_loc_t; + +/* On LoongArch64, we can directly use ucontext_t as the unwind context. */ +typedef ucontext_t unw_tdep_context_t; + +typedef struct + { + /* no loongarch64-specific auxiliary proc-info */ + char unused; + } +unw_tdep_proc_info_t; + +#include "libunwind-dynamic.h" +#include "libunwind-common.h" + +#define unw_tdep_getcontext UNW_ARCH_OBJ(getcontext) +extern int unw_tdep_getcontext (ucontext_t *uc); + +#define unw_tdep_is_fpreg UNW_ARCH_OBJ(is_fpreg) +extern int unw_tdep_is_fpreg (int); + +#if defined(__cplusplus) || defined(c_plusplus) +} +#endif + +#endif /* LIBUNWIND_H */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/libunwind-x86.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/libunwind-x86.h
Changed
@@ -34,6 +34,10 @@ #include <inttypes.h> #include <ucontext.h> +#ifndef UNW_EMPTY_STRUCT +# define UNW_EMPTY_STRUCT uint8_t unused; +#endif + #define UNW_TARGET x86 #define UNW_TARGET_X86 1 @@ -158,6 +162,7 @@ typedef struct unw_tdep_save_loc { /* Additional target-dependent info on a save location. */ + UNW_EMPTY_STRUCT } unw_tdep_save_loc_t; @@ -169,6 +174,7 @@ typedef struct { /* no x86-specific auxiliary proc-info */ + UNW_EMPTY_STRUCT } unw_tdep_proc_info_t;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/libunwind.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/libunwind.h
Changed
@@ -29,6 +29,8 @@ # include "libunwind-s390x.h" #elif defined __riscv || defined __riscv__ # include "libunwind-riscv.h" +#elif defined __loongarch64 +# include "libunwind-loongarch64.h" #else # error "Unsupported arch" #endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/libunwind.h.in -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/libunwind.h.in
Changed
@@ -29,6 +29,8 @@ # include "libunwind-s390x.h" #elif defined __riscv || defined __riscv__ # include "libunwind-riscv.h" +#elif defined __loongarch64 +# include "libunwind-loongarch64.h" #else # error "Unsupported arch" #endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/libunwind_i.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/libunwind_i.h
Changed
@@ -55,6 +55,8 @@ #include <string.h> #include <unistd.h> #include <sys/mman.h> +#include <errno.h> +#include <stdio.h> #if defined(HAVE_ELF_H) # include <elf.h> @@ -130,7 +132,7 @@ } static inline int -target_is_big_endian() +target_is_big_endian(void) { return byte_order_is_big_endian(UNW_BYTE_ORDER); } @@ -170,7 +172,7 @@ /* Type of a mask that can be used to inhibit preemption. At the userlevel, preemption is caused by signals and hence sigset_t is - appropriate. In constrast, the Linux kernel uses "unsigned long" + appropriate. In contrast, the Linux kernel uses "unsigned long" to hold the processor "flags" instead. */ typedef sigset_t intrmask_t; @@ -288,6 +290,13 @@ return write (2, string, strlen (string)); } +HIDDEN extern long unw_page_size; + +static inline unw_word_t uwn_page_start(unw_word_t addr) +{ + return addr & ~(unw_page_size - 1); +} + #define mi_init UNWI_ARCH_OBJ(mi_init) extern void mi_init (void); /* machine-independent initializations */ @@ -346,6 +355,10 @@ #include "tdep/libunwind_i.h" +#ifndef TDEP_DWARF_SP +#define TDEP_DWARF_SP UNW_TDEP_SP +#endif + #ifndef tdep_get_func_addr # define tdep_get_func_addr(as,addr,v) (*(v) = addr, 0) #endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/mempool.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/mempool.h
Changed
@@ -63,8 +63,8 @@ pthread_mutex_t lock; size_t obj_size; /* object size (rounded up for alignment) */ size_t chunk_size; /* allocation granularity */ - unsigned int reserve; /* minimum (desired) size of the free-list */ - unsigned int num_free; /* number of objects on the free-list */ + size_t reserve; /* minimum (desired) size of the free-list */ + size_t num_free; /* number of objects on the free-list */ struct object { struct object *next;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/remote.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/remote.h
Changed
@@ -51,7 +51,7 @@ fetch8 (unw_addr_space_t as, unw_accessors_t *a, unw_word_t *addr, int8_t *valp, void *arg) { - unw_word_t val, aligned_addr = *addr & -WSIZE, off = *addr - aligned_addr; + unw_word_t val, aligned_addr = *addr & (~WSIZE + 1), off = *addr - aligned_addr; int ret; *addr += 1; @@ -71,7 +71,7 @@ fetch16 (unw_addr_space_t as, unw_accessors_t *a, unw_word_t *addr, int16_t *valp, void *arg) { - unw_word_t val, aligned_addr = *addr & -WSIZE, off = *addr - aligned_addr; + unw_word_t val, aligned_addr = *addr & (~WSIZE + 1), off = *addr - aligned_addr; int ret; if ((off & 0x1) != 0) @@ -94,7 +94,7 @@ fetch32 (unw_addr_space_t as, unw_accessors_t *a, unw_word_t *addr, int32_t *valp, void *arg) { - unw_word_t val, aligned_addr = *addr & -WSIZE, off = *addr - aligned_addr; + unw_word_t val, aligned_addr = *addr & (~WSIZE + 1), off = *addr - aligned_addr; int ret; if ((off & 0x3) != 0)
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/tdep-arm/libunwind_i.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/tdep-arm/libunwind_i.h
Changed
@@ -256,6 +256,7 @@ #define tdep_init_done UNW_OBJ(init_done) #define tdep_init UNW_OBJ(init) #define arm_find_proc_info UNW_OBJ(find_proc_info) +#define arm_find_proc_info2 UNW_OBJ(find_proc_info2) #define arm_put_unwind_info UNW_OBJ(put_unwind_info) /* Platforms that support UNW_INFO_FORMAT_TABLE need to define tdep_search_unwind_table. */ @@ -297,6 +298,9 @@ extern int arm_find_proc_info (unw_addr_space_t as, unw_word_t ip, unw_proc_info_t *pi, int need_unwind_info, void *arg); +extern int arm_find_proc_info2 (unw_addr_space_t as, unw_word_t ip, + unw_proc_info_t *pi, int need_unwind_info, + void *arg, int methods); extern void arm_put_unwind_info (unw_addr_space_t as, unw_proc_info_t *pi, void *arg); extern int tdep_search_unwind_table (unw_addr_space_t as, unw_word_t ip,
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/tdep-ia64/libunwind_i.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/tdep-ia64/libunwind_i.h
Changed
@@ -152,7 +152,7 @@ unsigned int pi_is_dynamic :1; /* proc_info found via dynamic proc info? */ unw_proc_info_t pi; /* info about current procedure */ - /* In case of stack-discontiguities, such as those introduced by + /* In case of stack discontiguities, such as those introduced by signal-delivery on an alternate signal-stack (see sigaltstack(2)), we use the following data-structure to keep track of the register-backing-store areas across on which the
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/include/tdep-loongarch64
Added
+(directory)
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/include/tdep-loongarch64/dwarf-config.h
Added
@@ -0,0 +1,59 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2012 Tommi Rantala <tt.rantala@gmail.com> + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#ifndef dwarf_config_h +#define dwarf_config_h + +/* This is FIRST_PSEUDO_REGISTER in GCC, since DWARF_FRAME_REGISTERS is not + explicitly defined. + Number of hardware registers. We have: + - 32 integer registers + - 32 floating point registers + - 8 condition code registers + - 2 fake registers: + - ARG_POINTER_REGNUM + - FRAME_POINTER_REGNUM */ +#define DWARF_NUM_PRESERVED_REGS 74 + +#define dwarf_to_unw_regnum(reg) (((reg) < 32) ? (reg) : 0) + +/* Not big-endian. */ +#define dwarf_is_big_endian(addr_space) 0 + +/* Convert a pointer to a dwarf_cursor structure to a pointer to + unw_cursor_t. */ +#define dwarf_to_cursor(c) ((unw_cursor_t *) (c)) + +typedef struct dwarf_loc + { + unw_word_t val; +#ifndef UNW_LOCAL_ONLY + unw_word_t type; /* see DWARF_LOC_TYPE_* macros. */ +#endif + } +dwarf_loc_t; + +#endif /* dwarf_config_h */
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/include/tdep-loongarch64/jmpbuf.h
Added
@@ -0,0 +1,34 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +/* Use glibc's jump-buffer indices; NPTL peeks at SP: */ + +/* https://github.com/loongson/glibc/blob/loongarch_2_33/sysdeps/loongarch/setjmp.S + https://github.com/loongson/glibc/blob/loongarch_2_33/sysdeps/unix/sysv/linux/loongarch/lp64/jmp_buf-macros.h */ + +#define JB_SP 1 +#define JB_RP 0 +#define JB_MASK_SAVED (168>>3) +#define JB_MASK (176>>3)
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/include/tdep-loongarch64/libunwind_i.h
Added
@@ -0,0 +1,250 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#ifndef LOONGARCH64_LIBUNWIND_I_H +#define LOONGARCH64_LIBUNWIND_I_H + +/* Target-dependent definitions that are internal to libunwind but need + to be shared with target-independent code. */ + +#include <stdlib.h> +#include <libunwind.h> +#include "elf64.h" +#include "mempool.h" +#include "dwarf.h" + +typedef struct + { + /* no loongarch64-specific fast trace */ + } +unw_tdep_frame_t; + +struct unw_addr_space + { + struct unw_accessors acc; + + unw_caching_policy_t caching_policy; + _Atomic uint32_t cache_generation; + unw_word_t dyn_generation; /* see dyn-common.h */ + unw_word_t dyn_info_list_addr; /* (cached) dyn_info_list_addr */ + struct dwarf_rs_cache global_cache; + struct unw_debug_frame_list *debug_frames; +}; + +/* LoongArch64 supports only little-endian. */ +#define tdep_big_endian(as) 0 + +struct cursor + { + struct dwarf_cursor dwarf; /* must be first */ + + enum + { + LOONGARCH64_SCF_NONE, + LOONGARCH64_SCF_LINUX_RT_SIGFRAME, + } + sigcontext_format; + unw_word_t sigcontext_addr; + unw_word_t sigcontext_sp; + unw_word_t sigcontext_pc; + int validate; + ucontext_t *uc; + }; + +static inline ucontext_t * +dwarf_get_uc(const struct dwarf_cursor *cursor) +{ + const struct cursor *c = (struct cursor *) cursor->as_arg; + return c->uc; +} + +#define DWARF_GET_LOC(l) ((l).val) + +#ifdef UNW_LOCAL_ONLY +# define DWARF_NULL_LOC DWARF_LOC (0, 0) +# define DWARF_IS_NULL_LOC(l) (DWARF_GET_LOC (l) == 0) +# define DWARF_LOC(r, t) ((dwarf_loc_t) { .val = (r) }) +# define DWARF_IS_REG_LOC(l) 0 +# define DWARF_REG_LOC(c,r) (DWARF_LOC((unw_word_t) (intptr_t) \ + tdep_uc_addr(dwarf_get_uc(c), (r)), 0)) +# define DWARF_MEM_LOC(c,m) DWARF_LOC ((m), 0) +# define DWARF_FPREG_LOC(c,r) (DWARF_LOC((unw_word_t) (intptr_t) \ + tdep_uc_addr(dwarf_get_uc(c), (r)), 0)) + +/* FIXME: Implement these for the LoongArch64 FPU. */ +static inline int +dwarf_getfp (struct dwarf_cursor *c, dwarf_loc_t loc, unw_fpreg_t *val) +{ + return 0; +} + +static inline int +dwarf_putfp (struct dwarf_cursor *c, dwarf_loc_t loc, unw_fpreg_t val) +{ + return 0; +} + +static inline int +dwarf_get (struct dwarf_cursor *c, dwarf_loc_t loc, unw_word_t *val) +{ + if (!DWARF_GET_LOC (loc)) + return -1; + *val = *(unw_word_t *) (intptr_t) DWARF_GET_LOC (loc); + return 0; +} + +static inline int +dwarf_put (struct dwarf_cursor *c, dwarf_loc_t loc, unw_word_t val) +{ + if (!DWARF_GET_LOC (loc)) + return -1; + *(unw_word_t *) (intptr_t) DWARF_GET_LOC (loc) = val; + return 0; +} + +#else /* !UNW_LOCAL_ONLY */ +# define DWARF_LOC_TYPE_FP (1 << 0) +# define DWARF_LOC_TYPE_REG (1 << 1) +# define DWARF_NULL_LOC DWARF_LOC (0, 0) +# define DWARF_IS_NULL_LOC(l) \ + ({ dwarf_loc_t _l = (l); _l.val == 0 && _l.type == 0; }) +# define DWARF_LOC(r, t) ((dwarf_loc_t) { .val = (r), .type = (t) }) +# define DWARF_IS_REG_LOC(l) (((l).type & DWARF_LOC_TYPE_REG) != 0) +# define DWARF_IS_FP_LOC(l) (((l).type & DWARF_LOC_TYPE_FP) != 0) +# define DWARF_REG_LOC(c,r) DWARF_LOC((r), DWARF_LOC_TYPE_REG) +# define DWARF_MEM_LOC(c,m) DWARF_LOC ((m), 0) +# define DWARF_FPREG_LOC(c,r) DWARF_LOC((r), (DWARF_LOC_TYPE_REG \ + | DWARF_LOC_TYPE_FP)) + +/* FIXME: Implement these for the LoongArch64 FPU. */ +static inline int +dwarf_getfp (struct dwarf_cursor *c, dwarf_loc_t loc, unw_fpreg_t *val) +{ + return 0; +} + +static inline int +dwarf_putfp (struct dwarf_cursor *c, dwarf_loc_t loc, unw_fpreg_t val) +{ + return 0; +} + +static inline int +dwarf_get (struct dwarf_cursor *c, dwarf_loc_t loc, unw_word_t *val) +{ + if (DWARF_IS_NULL_LOC (loc)) + return -UNW_EBADREG; + + /* If a code-generator were to save a value of type unw_word_t in a + * floating-point register, we would have to support this case. I + * suppose it could happen with MMX registers, but does it really + * happen? */ + assert (!DWARF_IS_FP_LOC (loc)); + + if (DWARF_IS_REG_LOC (loc)) + return (*c->as->acc.access_reg) (c->as, DWARF_GET_LOC (loc), val, + 0, c->as_arg); + else + return (*c->as->acc.access_mem) (c->as, DWARF_GET_LOC (loc), val, + 0, c->as_arg); +} + +static inline int +dwarf_put (struct dwarf_cursor *c, dwarf_loc_t loc, unw_word_t val) +{ + if (DWARF_IS_NULL_LOC (loc)) + return -UNW_EBADREG; + + /* If a code-generator were to save a value of type unw_word_t in a + * floating-point register, we would have to support this case. I + * suppose it could happen with MMX registers, but does it really + * happen? */ + assert (!DWARF_IS_FP_LOC (loc)); + + if (DWARF_IS_REG_LOC (loc)) + return (*c->as->acc.access_reg) (c->as, DWARF_GET_LOC (loc), &val, + 1, c->as_arg); + else + return (*c->as->acc.access_mem) (c->as, DWARF_GET_LOC (loc), &val, + 1, c->as_arg); +} + +#endif /* !UNW_LOCAL_ONLY */ + +#define tdep_getcontext_trace unw_getcontext +#define tdep_init_done UNW_OBJ(init_done) +#define tdep_init UNW_OBJ(init) +/* Platforms that support UNW_INFO_FORMAT_TABLE need to define + tdep_search_unwind_table. */ +#define tdep_search_unwind_table dwarf_search_unwind_table +#define tdep_find_unwind_table dwarf_find_unwind_table +#define tdep_uc_addr UNW_ARCH_OBJ(uc_addr) +#define tdep_get_elf_image UNW_ARCH_OBJ(get_elf_image) +#define tdep_get_exe_image_path UNW_ARCH_OBJ(get_exe_image_path) +#define tdep_access_reg UNW_OBJ(access_reg) +#define tdep_access_fpreg UNW_OBJ(access_fpreg) +#define tdep_fetch_frame(c,ip,n) do {} while(0) +#define tdep_cache_frame(c) 0 +#define tdep_reuse_frame(c,rs) do {} while(0) +#define tdep_stash_frame(c,rs) do {} while(0) +#define tdep_trace(cur,addr,n) (-UNW_ENOINFO) + +#ifdef UNW_LOCAL_ONLY +# define tdep_find_proc_info(c,ip,n) \ + dwarf_find_proc_info((c)->as, (ip), &(c)->pi, (n), \ + (c)->as_arg) +# define tdep_put_unwind_info(as,pi,arg) \ + dwarf_put_unwind_info((as), (pi), (arg)) +#else +# define tdep_find_proc_info(c,ip,n) \ + (*(c)->as->acc.find_proc_info)((c)->as, (ip), &(c)->pi, (n), \ + (c)->as_arg) +# define tdep_put_unwind_info(as,pi,arg) \ + (*(as)->acc.put_unwind_info)((as), (pi), (arg)) +#endif + +#define tdep_get_as(c) ((c)->dwarf.as) +#define tdep_get_as_arg(c) ((c)->dwarf.as_arg) +#define tdep_get_ip(c) ((c)->dwarf.ip) + +extern atomic_bool tdep_init_done; +#define tdep_init_mem_validate UNW_OBJ(init_mem_validate) + +extern void tdep_init (void); +extern void tdep_init_mem_validate (void); +extern int tdep_search_unwind_table (unw_addr_space_t as, unw_word_t ip, + unw_dyn_info_t *di, unw_proc_info_t *pi, + int need_unwind_info, void *arg); +extern void *tdep_uc_addr (ucontext_t *uc, int reg); +extern int tdep_get_elf_image (struct elf_image *ei, pid_t pid, unw_word_t ip, + unsigned long *segbase, unsigned long *mapoff, + char *path, size_t pathlen); +extern void tdep_get_exe_image_path (char *path); +extern int tdep_access_reg (struct cursor *c, unw_regnum_t reg, + unw_word_t *valp, int write); +extern int tdep_access_fpreg (struct cursor *c, unw_regnum_t reg, + unw_fpreg_t *valp, int write); + +#endif /* LOONGARCH64_LIBUNWIND_I_H */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/tdep-x86/dwarf-config.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/tdep-x86/dwarf-config.h
Changed
@@ -43,9 +43,7 @@ typedef struct dwarf_loc { unw_word_t val; -#ifndef UNW_LOCAL_ONLY unw_word_t type; /* see X86_LOC_TYPE_* macros. */ -#endif } dwarf_loc_t;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/tdep-x86/libunwind_i.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/tdep-x86/libunwind_i.h
Changed
@@ -84,15 +84,26 @@ } #define DWARF_GET_LOC(l) ((l).val) +# define DWARF_LOC_TYPE_MEM (0 << 0) +# define DWARF_LOC_TYPE_FP (1 << 0) +# define DWARF_LOC_TYPE_REG (1 << 1) +# define DWARF_LOC_TYPE_VAL (1 << 2) -#ifdef UNW_LOCAL_ONLY +# define DWARF_IS_REG_LOC(l) (((l).type & DWARF_LOC_TYPE_REG) != 0) +# define DWARF_IS_FP_LOC(l) (((l).type & DWARF_LOC_TYPE_FP) != 0) +# define DWARF_IS_MEM_LOC(l) ((l).type == DWARF_LOC_TYPE_MEM) +# define DWARF_IS_VAL_LOC(l) (((l).type & DWARF_LOC_TYPE_VAL) != 0) + +# define DWARF_LOC(r, t) ((dwarf_loc_t) { .val = (r), .type = (t) }) # define DWARF_NULL_LOC DWARF_LOC (0, 0) -# define DWARF_IS_NULL_LOC(l) (DWARF_GET_LOC (l) == 0) -# define DWARF_LOC(r, t) ((dwarf_loc_t) { .val = (r) }) -# define DWARF_IS_REG_LOC(l) 0 +# define DWARF_IS_NULL_LOC(l) \ + ({ dwarf_loc_t _l = (l); _l.val == 0 && _l.type == 0; }) +# define DWARF_VAL_LOC(c,v) DWARF_LOC ((v), DWARF_LOC_TYPE_VAL) +# define DWARF_MEM_LOC(c,m) DWARF_LOC ((m), DWARF_LOC_TYPE_MEM) + +#ifdef UNW_LOCAL_ONLY # define DWARF_REG_LOC(c,r) (DWARF_LOC((unw_word_t) \ tdep_uc_addr(dwarf_get_uc(c), (r)), 0)) -# define DWARF_MEM_LOC(c,m) DWARF_LOC ((m), 0) # define DWARF_FPREG_LOC(c,r) (DWARF_LOC((unw_word_t) \ tdep_uc_addr(dwarf_get_uc(c), (r)), 0)) @@ -114,35 +125,8 @@ return 0; } -static inline int -dwarf_get (struct dwarf_cursor *c, dwarf_loc_t loc, unw_word_t *val) -{ - if (!DWARF_GET_LOC (loc)) - return -1; - return (*c->as->acc.access_mem) (c->as, DWARF_GET_LOC (loc), val, - 0, c->as_arg); -} - -static inline int -dwarf_put (struct dwarf_cursor *c, dwarf_loc_t loc, unw_word_t val) -{ - if (!DWARF_GET_LOC (loc)) - return -1; - return (*c->as->acc.access_mem) (c->as, DWARF_GET_LOC (loc), &val, - 1, c->as_arg); -} - #else /* !UNW_LOCAL_ONLY */ -# define DWARF_LOC_TYPE_FP (1 << 0) -# define DWARF_LOC_TYPE_REG (1 << 1) -# define DWARF_NULL_LOC DWARF_LOC (0, 0) -# define DWARF_IS_NULL_LOC(l) \ - ({ dwarf_loc_t _l = (l); _l.val == 0 && _l.type == 0; }) -# define DWARF_LOC(r, t) ((dwarf_loc_t) { .val = (r), .type = (t) }) -# define DWARF_IS_REG_LOC(l) (((l).type & DWARF_LOC_TYPE_REG) != 0) -# define DWARF_IS_FP_LOC(l) (((l).type & DWARF_LOC_TYPE_FP) != 0) # define DWARF_REG_LOC(c,r) DWARF_LOC((r), DWARF_LOC_TYPE_REG) -# define DWARF_MEM_LOC(c,m) DWARF_LOC ((m), 0) # define DWARF_FPREG_LOC(c,r) DWARF_LOC((r), (DWARF_LOC_TYPE_REG \ | DWARF_LOC_TYPE_FP)) @@ -192,38 +176,33 @@ 1, c->as_arg); } +#endif /* !UNW_LOCAL_ONLY */ + static inline int dwarf_get (struct dwarf_cursor *c, dwarf_loc_t loc, unw_word_t *val) { if (DWARF_IS_NULL_LOC (loc)) return -UNW_EBADREG; - /* If a code-generator were to save a value of type unw_word_t in a - floating-point register, we would have to support this case. I - suppose it could happen with MMX registers, but does it really - happen? */ - assert (!DWARF_IS_FP_LOC (loc)); - if (DWARF_IS_REG_LOC (loc)) return (*c->as->acc.access_reg) (c->as, DWARF_GET_LOC (loc), val, 0, c->as_arg); - else + if (DWARF_IS_MEM_LOC (loc)) return (*c->as->acc.access_mem) (c->as, DWARF_GET_LOC (loc), val, 0, c->as_arg); + assert(DWARF_IS_VAL_LOC (loc)); + *val = DWARF_GET_LOC (loc); + return 0; } static inline int dwarf_put (struct dwarf_cursor *c, dwarf_loc_t loc, unw_word_t val) { + assert(!DWARF_IS_VAL_LOC (loc)); + if (DWARF_IS_NULL_LOC (loc)) return -UNW_EBADREG; - /* If a code-generator were to save a value of type unw_word_t in a - floating-point register, we would have to support this case. I - suppose it could happen with MMX registers, but does it really - happen? */ - assert (!DWARF_IS_FP_LOC (loc)); - if (DWARF_IS_REG_LOC (loc)) return (*c->as->acc.access_reg) (c->as, DWARF_GET_LOC (loc), &val, 1, c->as_arg); @@ -232,7 +211,9 @@ 1, c->as_arg); } -#endif /* !UNW_LOCAL_ONLY */ +// For historical reasons, the DWARF numbering does not match the libunwind +// numbering, necessitating this override +#define TDEP_DWARF_SP 4 #define tdep_getcontext_trace unw_getcontext #define tdep_init_done UNW_OBJ(init_done)
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/tdep/dwarf-config.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/tdep/dwarf-config.h
Changed
@@ -27,6 +27,8 @@ # include "tdep-tilegx/dwarf-config.h" #elif defined __riscv || defined __riscv__ # include "tdep-riscv/dwarf-config.h" +#elif defined __loongarch64 +# include "tdep-loongarch64/dwarf-config.h" #else # error "Unsupported arch" #endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/tdep/jmpbuf.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/tdep/jmpbuf.h
Changed
@@ -25,6 +25,8 @@ # include "tdep-tilegx/jmpbuf.h" #elif defined __riscv || defined __riscv__ # include "tdep-riscv/jmpbuf.h" +#elif defined __loongarch64 +# include "tdep-loongarch64/jmpbuf.h" #else # error "Unsupported arch" #endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/tdep/libunwind_i.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/tdep/libunwind_i.h
Changed
@@ -29,6 +29,8 @@ # include "tdep-s390x/libunwind_i.h" #elif defined __riscv || defined __riscv__ # include "tdep-riscv/libunwind_i.h" +#elif defined __loongarch64 +# include "tdep-loongarch64/libunwind_i.h" #else # error "Unsupported arch" #endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/include/tdep/libunwind_i.h.in -> _service:tar_scm:libunwind-1.7.2.tar.gz/include/tdep/libunwind_i.h.in
Changed
@@ -29,6 +29,8 @@ # include "tdep-s390x/libunwind_i.h" #elif defined __riscv || defined __riscv__ # include "tdep-riscv/libunwind_i.h" +#elif defined __loongarch64 +# include "tdep-loongarch64/libunwind_i.h" #else # error "Unsupported arch" #endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/m4
Added
+(directory)
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/m4/libtool.m4
Added
@@ -0,0 +1,8388 @@ +# libtool.m4 - Configure libtool for the host system. -*-Autoconf-*- +# +# Copyright (C) 1996-2001, 2003-2015 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) 2014 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 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 this program. If not, see <http://www.gnu.org/licenses/>. +) + +# serial 58 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.62)dnl We use AC_PATH_PROGS_FEATURE_CHECK +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_PREPARE_CC_BASENAME +# ----------------------- +m4_defun(_LT_PREPARE_CC_BASENAME, +# Calculate cc_basename. Skip known compiler wrappers and cross-prefix. +func_cc_basename () +{ + for cc_temp in @S|@*""; do + case $cc_temp in + compile | *\\/compile | ccache | *\\/ccache ) ;; + distcc | *\\/distcc | purify | *\\/purify ) ;; + \-*) ;; + *) break;; + esac + done + func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` +} +)# _LT_PREPARE_CC_BASENAME + + +# _LT_CC_BASENAME(CC) +# ------------------- +# It would be clearer to call AC_REQUIREs from _LT_PREPARE_CC_BASENAME, +# but that macro is also expanded into generated libtool script, which +# arranges for $SED and $ECHO to be set by different means. +m4_defun(_LT_CC_BASENAME, +m4_require(_LT_PREPARE_CC_BASENAME)dnl +AC_REQUIRE(_LT_DECL_SED)dnl +AC_REQUIRE(_LT_PROG_ECHO_BACKSLASH)dnl +func_cc_basename $1 +cc_basename=$func_cc_basename_result +) + + +# _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 +m4_require(_LT_CMD_TRUNCATE)dnl + +_LT_CONFIG_LIBTOOL_INIT( +# See if we are running on zsh, and set the options that 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 set != "${COLLECT_NAMES+set}"; 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: +# +# <var>='`$ECHO "$<var>" | $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\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes + ;; + *) + 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\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes + ;; + *) + 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 0 = "$lt_write_fail" && chmod +x $1dnl +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 <bug-libtool@gnu.org>." + +lt_cl_version="\ +m4_ifset(AC_PACKAGE_NAME, AC_PACKAGE_NAME )config.ltdnl +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 yes = "$silent" && + 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 that 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 +# Generated automatically by $as_me ($PACKAGE) $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. + +# Provide generalized library-building support services. +# Written by Gordon Matzigkeit, 1996 + +_LT_COPYING +_LT_LIBTOOL_TAGS + +# Configured defaults for sys_lib_dlsearch_path munging. +: \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"} + +# ### BEGIN LIBTOOL CONFIG +_LT_LIBTOOL_CONFIG_VARS +_LT_LIBTOOL_TAG_VARS +# ### END LIBTOOL CONFIG + +_LT_EOF + + cat <<'_LT_EOF' >> "$cfgfile" + +# ### BEGIN FUNCTIONS SHARED WITH CONFIGURE + +_LT_PREPARE_MUNGE_PATH_LIST +_LT_PREPARE_CC_BASENAME + +# ### END FUNCTIONS SHARED WITH CONFIGURE + +_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 set != "${COLLECT_NAMES+set}"; 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) + + 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' + 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 AM_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(AM_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(AM_PROG_GCJ, + m4_define(AM_PROG_GCJ, defn(AM_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 0 = "$_lt_result"; 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 0 = "$_lt_result" && $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,*-darwin91*) + _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 yes = "$lt_cv_apple_cc_single_mod"; then + _lt_dar_single_mod='$single_module' + fi + if test yes = "$lt_cv_ld_exported_symbols_list"; 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 no = "$lt_cv_ld_force_load"; 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 yes = "$lt_cv_ld_force_load"; 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*|nagfor*) _lt_dar_can_shared=yes ;; + *) _lt_dar_can_shared=$GCC ;; + esac + if test yes = "$_lt_dar_can_shared"; 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 yes != "$lt_cv_apple_cc_single_mod"; 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 set = "${lt_cv_aix_libpath+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 that will find a shell with a builtin +# printf (that 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, +AS_HELP_STRING(--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 yes = "$GCC"; 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 where 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 no = "$enable_libtool_lock" || 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 what ABI is being produced by ac_compile, and set mode + # options accordingly. + 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 what ABI is being produced by ac_compile, and set linker + # options accordingly. + echo '#line '$LINENO' "configure"' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + if test yes = "$lt_cv_prog_gnu_ld"; 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* + ;; + +mips64*-*linux*) + # Find out what ABI is being produced by ac_compile, and set linker + # options accordingly. + echo '#line '$LINENO' "configure"' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + emul=elf + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + emul="${emul}32" + ;; + *64-bit*) + emul="${emul}64" + ;; + esac + case `/usr/bin/file conftest.$ac_objext` in + *MSB*) + emul="${emul}btsmip" + ;; + *LSB*) + emul="${emul}ltsmip" + ;; + esac + case `/usr/bin/file conftest.$ac_objext` in + *N32*) + emul="${emul}n32" + ;; + esac + LD="${LD-ld} -m $emul" + fi + rm -rf conftest* + ;; + +x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ +s390*-*linux*|s390*-*tpf*|sparc*-*linux*) + # Find out what ABI is being produced by ac_compile, and set linker + # options accordingly. Note that the listed cases only cover the + # situations where additional linker options are needed (such as when + # doing 32-bit compilation for a host where ld defaults to 64-bit, or + # vice versa); the common cases where no linker options are needed do + # not appear in the list. + 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-*linux*) + LD="${LD-ld} -m elf32lppclinux" + ;; + powerpc64-*linux*) + 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-*linux*) + LD="${LD-ld} -m elf64lppc" + ;; + powerpc-*linux*) + 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 yes != "$lt_cv_cc_needs_belf"; then + # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf + CFLAGS=$SAVE_CFLAGS + fi + ;; +*-*solaris*) + # Find out what ABI is being produced by ac_compile, and set linker + # options accordingly. + 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*|x86_64-*-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 0 -eq "$ac_status"; then + # Ensure the archiver fails upon bogus file names. + rm -f conftest.$ac_objext libconftest.a + AC_TRY_EVAL(lt_ar_try) + if test 0 -ne "$ac_status"; then + lt_cv_ar_at_file=@ + fi + fi + rm -f conftest.* libconftest.a + ) + ) + +if test no = "$lt_cv_ar_at_file"; 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 + bitrig* | 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" ## exclude from sc_useless_quotes_in_assignment + # 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 yes = "$$2"; 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 yes = "$$2"; 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; + ;; + + bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*) + # 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 17 != "$i" # 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 yes = "$cross_compiling"; 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 <dlfcn.h> +#endif + +#include <stdio.h> + +#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 -fvisibility=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 yes != "$enable_dlopen"; 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 + ) + ;; + + tpf*) + # Don't try to run any link tests for TPF. We know it's impossible + # because TPF is a cross-compiler, and we know how we open DSOs. + lt_cv_dlopen=dlopen + lt_cv_dlopen_libs= + lt_cv_dlopen_self=no + ;; + + *) + 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 no = "$lt_cv_dlopen"; then + enable_dlopen=no + else + enable_dlopen=yes + fi + + case $lt_cv_dlopen in + dlopen) + save_CPPFLAGS=$CPPFLAGS + test yes = "$ac_cv_header_dlfcn_h" && 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 yes = "$lt_cv_dlopen_self"; 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 no = "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" && test no != "$need_locks"; 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 no = "$hard_links"; 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 where 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 yes = "$_LT_TAGVAR(hardcode_automatic, $1)"; then + + # We can hardcode non-existent directories. + if test no != "$_LT_TAGVAR(hardcode_direct, $1)" && + # 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 no != "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" && + test no != "$_LT_TAGVAR(hardcode_minus_L, $1)"; 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 relink = "$_LT_TAGVAR(hardcode_action, $1)" || + test yes = "$_LT_TAGVAR(inherit_rpath, $1)"; then + # Fast installation is not supported + enable_fast_install=no +elif test yes = "$shlibpath_overrides_runpath" || + test no = "$enable_shared"; 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_PREPARE_MUNGE_PATH_LIST +# --------------------------- +# Make sure func_munge_path_list() is defined correctly. +m4_defun(_LT_PREPARE_MUNGE_PATH_LIST, +# func_munge_path_list VARIABLE PATH +# ----------------------------------- +# VARIABLE is name of variable containing _space_ separated list of +# directories to be munged by the contents of PATH, which is string +# having a format: +# "DIR:DIR:" +# string "DIR DIR" will be prepended to VARIABLE +# ":DIR:DIR" +# string "DIR DIR" will be appended to VARIABLE +# "DIRP:DIRP::DIRA:DIRA" +# string "DIRP DIRP" will be prepended to VARIABLE and string +# "DIRA DIRA" will be appended to VARIABLE +# "DIR:DIR" +# VARIABLE will be replaced by "DIR DIR" +func_munge_path_list () +{ + case x@S|@2 in + x) + ;; + *:) + eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'` \@S|@@S|@1\" + ;; + x:*) + eval @S|@1=\"\@S|@@S|@1 `$ECHO @S|@2 | $SED 's/:/ /g'`\" + ;; + *::*) + eval @S|@1=\"\@S|@@S|@1\ `$ECHO @S|@2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" + eval @S|@1=\"`$ECHO @S|@2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \@S|@@S|@1\" + ;; + *) + eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'`\" + ;; + esac +} +)# _LT_PREPARE_PATH_LIST + + +# _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 +m4_require(_LT_PREPARE_MUNGE_PATH_LIST)dnl +AC_MSG_CHECKING(dynamic linker characteristics) +m4_if($1, + , +if test yes = "$GCC"; 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` + # ...but if some path component already ends with the multilib dir we assume + # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer). + case "$lt_multi_os_dir; $lt_search_path_spec " in + "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*) + lt_multi_os_dir= + ;; + esac + 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" + elif test -n "$lt_multi_os_dir"; then + 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_freqlt_foo++; } + if (lt_freqlt_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 + +AC_ARG_VAR(LT_SYS_LIBRARY_PATH, +User-defined run-time library search path.) + +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' + ;; + +aix4-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 ia64 = "$host_cpu"; 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 + # Using Import Files as archive members, it is possible to support + # filename-based versioning of shared library archives on AIX. While + # this would work for both with and without runtime linking, it will + # prevent static linking of such archives. So we do filename-based + # shared library versioning with .so extension only, which is used + # when both runtime linking and shared linking is enabled. + # Unfortunately, runtime linking may impact performance, so we do + # not want this to be the default eventually. Also, we use the + # versioned .so libs for executables only if there is the -brtl + # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. + # To allow for filename-based versioning support, we need to create + # libNAME.so.V as an archive file, containing: + # *) an Import File, referring to the versioned filename of the + # archive as well as the shared archive member, telling the + # bitwidth (32 or 64) of that shared object, and providing the + # list of exported symbols of that shared object, eventually + # decorated with the 'weak' keyword + # *) the shared object with the F_LOADONLY flag set, to really avoid + # it being seen by the linker. + # At run time we better use the real file rather than another symlink, + # but for link time we create the symlink libNAME.so -> libNAME.so.V + + case $with_aix_soname,$aix_use_runtimelinking in + # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + aix,yes) # traditional libtool + dynamic_linker='AIX unversionable lib.so' + # If using run time linking (on AIX 4.2 or later) use lib<name>.so + # instead of lib<name>.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' + ;; + aix,no) # traditional AIX only + dynamic_linker='AIX lib.a(lib.so.V)' + # 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' + ;; + svr4,*) # full svr4 only + dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o)" + library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' + # We do not specify a path in Import Files, so LIBPATH fires. + shlibpath_overrides_runpath=yes + ;; + *,yes) # both, prefer svr4 + dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o), lib.a(lib.so.V)" + library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' + # unpreferred sharedlib libNAME.a needs extra handling + postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' + postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' + # We do not specify a path in Import Files, so LIBPATH fires. + shlibpath_overrides_runpath=yes + ;; + *,no) # both, prefer aix + dynamic_linker="AIX lib.a(lib.so.V), lib.so.V($shared_archive_member_spec.o)" + library_names_spec='$libname$release.a $libname.a' + soname_spec='$libname$release$shared_ext$major' + # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling + postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' + postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' + ;; + esac + 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%'\''`; $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 + ;; + +bsdi45*) + 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 + freebsd23.*) 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$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + 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=no + 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 32 = "$HPUX_IA64_MODE"; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + sys_lib_dlsearch_path_spec=/usr/lib/hpux32 + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + sys_lib_dlsearch_path_spec=/usr/lib/hpux64 + fi + ;; + 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 + ;; + +interix3-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 yes = "$lt_cv_prog_gnu_ld"; 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 + ;; + +linux*android*) + version_type=none # Android doesn't support versioned libraries. + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext' + soname_spec='$libname$release$shared_ext' + finish_cmds= + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + + # 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 + + dynamic_linker='Android linker' + # Don't embed -rpath directories since the linker doesn't support them. + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + ;; + +# 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 + + # Ideally, we could use ldconfig to report *all* directores which are + # searched for libraries, however this is still not possible. Aside from not + # being certain /sbin/ldconfig is available, command + # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, + # even though it is searched at run-time. Try to do the best guess by + # appending ld.so.conf contents (and includes) 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* | bitrig*) + version_type=sunos + sys_lib_dlsearch_path_spec=/usr/lib + need_lib_prefix=no + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then + need_version=no + else + need_version=yes + fi + 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 + shlibpath_overrides_runpath=yes + ;; + +os2*) + libname_spec='$name' + version_type=windows + shrext_cmds=.dll + need_version=no + need_lib_prefix=no + # OS/2 can only load a DLL with a base name of 8 characters or less. + soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; + v=$($ECHO $release$versuffix | tr -d .-); + n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); + $ECHO $n$v`$shared_ext' + library_names_spec='${libname}_dll.$libext' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=BEGINLIBPATH + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + 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' + ;; + +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 yes = "$with_gnu_ld"; 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=sco + 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 yes = "$with_gnu_ld"; 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 no = "$dynamic_linker" && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test yes = "$GCC"; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then + sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec +fi + +if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then + sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec +fi + +# remember unaugmented sys_lib_dlsearch_path content for libtool script decls... +configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec + +# ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code +func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" + +# to be used as default LT_SYS_LIBRARY_PATH value in generated libtool +configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH + +_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, configure_time_dlsearch_path, 2, + Detected run-time system search path for libraries) +_LT_DECL(, configure_time_lt_sys_library_path, 2, + Explicit LT_SYS_LIBRARY_PATH set during ./configure time) +)# _LT_SYS_DYNAMIC_LINKER + + +# _LT_PATH_TOOL_PREFIX(TOOL) +# -------------------------- +# find a file program that 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 that 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 no = "$withval" || with_gnu_ld=yes, + with_gnu_ld=no)dnl + +ac_prog=ld +if test yes = "$GCC"; 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 yes = "$with_gnu_ld"; 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 </dev/null` in + *GNU* | *'with BFD'*) + test no != "$with_gnu_ld" && break + ;; + *) + test yes != "$with_gnu_ld" && break + ;; + esac + fi + done + IFS=$lt_save_ifs +else + lt_cv_path_LD=$LD # Let the user override the test with a path. +fi) +LD=$lt_cv_path_LD +if test -n "$LD"; then + AC_MSG_RESULT($LD) +else + AC_MSG_RESULT(no) +fi +test -z "$LD" && AC_MSG_ERROR(no acceptable ld found in \$PATH) +_LT_PATH_LD_GNU +AC_SUBST(LD) + +_LT_TAGDECL(, LD, 1, The linker used to build libraries) +)# LT_PATH_LD + +# Old names: +AU_ALIAS(AM_PROG_LD, LT_PATH_LD) +AU_ALIAS(AC_PROG_LD, LT_PATH_LD) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN(AM_PROG_LD, ) +dnl AC_DEFUN(AC_PROG_LD, ) + + +# _LT_PATH_LD_GNU +#- -------------- +m4_defun(_LT_PATH_LD_GNU, +AC_CACHE_CHECK(if the linker ($LD) is GNU ld, lt_cv_prog_gnu_ld, +# I'd rather use --version here, but apparently some GNU lds only accept -v. +case `$LD -v 2>&1 </dev/null` in +*GNU* | *'with BFD'*) + lt_cv_prog_gnu_ld=yes + ;; +*) + lt_cv_prog_gnu_ld=no + ;; +esac) +with_gnu_ld=$lt_cv_prog_gnu_ld +)# _LT_PATH_LD_GNU + + +# _LT_CMD_RELOAD +# -------------- +# find reload flag for linker +# -- PORTME Some linkers may need a different reload flag. +m4_defun(_LT_CMD_RELOAD, +AC_CACHE_CHECK(for $LD option to reload object files, + lt_cv_ld_reload_flag, + lt_cv_ld_reload_flag='-r') +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 yes != "$GCC"; then + reload_cmds=false + fi + ;; + darwin*) + if test yes = "$GCC"; then + reload_cmds='$LTCC $LTCFLAGS -nostdlib $wl-r -o $output$reload_objs' + else + reload_cmds='$LD$reload_flag -o $output$reload_objs' + fi + ;; +esac +_LT_TAGDECL(, reload_flag, 1, How to create reloadable object files)dnl +_LT_TAGDECL(, reload_cmds, 2)dnl +)# _LT_CMD_RELOAD + + +# _LT_PATH_DD +# ----------- +# find a working dd +m4_defun(_LT_PATH_DD, +AC_CACHE_CHECK(for a working dd, ac_cv_path_lt_DD, +printf 0123456789abcdef0123456789abcdef >conftest.i +cat conftest.i conftest.i >conftest2.i +: ${lt_DD:=$DD} +AC_PATH_PROGS_FEATURE_CHECK(lt_DD, dd, +if "$ac_path_lt_DD" bs=32 count=1 <conftest2.i >conftest.out 2>/dev/null; then + cmp -s conftest.i conftest.out \ + && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=: +fi) +rm -f conftest.i conftest2.i conftest.out) +)# _LT_PATH_DD + + +# _LT_CMD_TRUNCATE +# ---------------- +# find command to truncate a binary pipe +m4_defun(_LT_CMD_TRUNCATE, +m4_require(_LT_PATH_DD) +AC_CACHE_CHECK(how to truncate binary pipes, lt_cv_truncate_bin, +printf 0123456789abcdef0123456789abcdef >conftest.i +cat conftest.i conftest.i >conftest2.i +lt_cv_truncate_bin= +if "$ac_cv_path_lt_DD" bs=32 count=1 <conftest2.i >conftest.out 2>/dev/null; then + cmp -s conftest.i conftest.out \ + && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1" +fi +rm -f conftest.i conftest2.i conftest.out +test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q") +_LT_DECL(lt_truncate_bin, lt_cv_truncate_bin, 1, + Command to truncate a binary pipe) +)# _LT_CMD_TRUNCATE + + +# _LT_CHECK_MAGIC_METHOD +# ---------------------- +# how to check for library dependencies +# -- PORTME fill in with the dynamic library characteristics +m4_defun(_LT_CHECK_MAGIC_METHOD, +m4_require(_LT_DECL_EGREP) +m4_require(_LT_DECL_OBJDUMP) +AC_CACHE_CHECK(how to recognize dependent libraries, +lt_cv_deplibs_check_method, +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 +# that 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 +aix4-9*) + lt_cv_deplibs_check_method=pass_all + ;; + +beos*) + lt_cv_deplibs_check_method=pass_all + ;; + +bsdi45*) + lt_cv_deplibs_check_method='file_magic ELF 0-90-9*-bit MLSB (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. + if ( 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)/i3-986 (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 (s0-90-90-9|ELF-0-90-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 (s0-90-90-9|ELF -0-90-9)(-bit)?( LMSB)? 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 (s0-90-90-9|PA-RISC0-9\.0-9) shared library' + lt_cv_file_magic_test_file=/usr/lib/libc.sl + ;; + esac + ;; + +interix3-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-90-9*-bit MLSB (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* | bitrig*) + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; 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-90-9*-bit MLSB (shared object|dynamic lib) M0-90-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-90-9*-bit LMSB (shared object|dynamic lib )' + ;; + sni) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method="file_magic ELF 0-90-9*-bit LMSB 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 + ;; +os2*) + 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 + # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty + case $build_os in + mingw*) lt_bad_file=conftest.nm/nofile ;; + *) lt_bad_file=/dev/null ;; + esac + case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in + *$lt_bad_file* | *'Invalid file or object type'*) + lt_cv_path_NM="$tmp_nm -B" + break 2 + ;; + *) + case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in + */dev/null*) + lt_cv_path_NM="$tmp_nm -p" + break 2 + ;; + *) + 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 no != "$lt_cv_path_NM"; 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 -headers /dev/null 2>&1 | sed '1q'` in + *COFF*) + DUMPBIN="$DUMPBIN -symbols -headers" + ;; + *) + 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 one 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 yes != "$lt_cv_path_mainfest_tool"; then + MANIFEST_TOOL=: +fi +_LT_DECL(, MANIFEST_TOOL, 1, Manifest tool)dnl +)# _LT_PATH_MANIFEST_TOOL + + +# _LT_DLL_DEF_P(FILE) +# --------------------- +# True iff FILE is a Windows DLL '.def' file. +# Keep in sync with func_dll_def_p in the libtool script +AC_DEFUN(_LT_DLL_DEF_P, +dnl + test DEF = "`$SED -n dnl + -e '\''s/^ *//'\'' dnl Strip leading whitespace + -e '\''/^\(;.*\)*$/d'\'' dnl Delete empty lines and comments + -e '\''s/^\(EXPORTS\|LIBRARY\)\( .*\)*$/DEF/p'\'' dnl + -e q dnl Only consider the first "real" line + $1`" dnl +)# _LT_DLL_DEF_P + + +# 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 yes = "$GCC"; 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 ia64 = "$host_cpu"; 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 + +if test "$lt_cv_nm_interface" = "MS dumpbin"; then + # Gets list of data symbols to import. + lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'" + # Adjust the below global symbol transforms to fixup imported variables. + lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'" + lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'" + lt_c_name_lib_hook="\ + -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\ + -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'" +else + # Disable hooks by default. + lt_cv_sys_global_symbol_to_import= + lt_cdecl_hook= + lt_c_name_hook= + lt_c_name_lib_hook= +fi + +# 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"\ +$lt_cdecl_hook\ +" -e 's/^T .* \(.*\)$/extern int \1();/p'"\ +" -e 's/^$symcode$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"\ +$lt_c_name_hook\ +" -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ +" -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'" + +# Transform an extracted symbol line into symbol name with lib prefix and +# symbol address. +lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\ +$lt_c_name_lib_hook\ +" -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ +" -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\ +" -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/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, + # D for any global variable and I for any imported 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 hidei};"\ +" /Section length .*#relocs.*(pick any)/{hidelast_section=1};"\ +" /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn2,2)};"\ +" /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\ +" /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\ +" \$ 0!~/External *\|/{next};"\ +" / 0+ UNDEF /{next}; / UNDEF \(^|\)*()/{next};"\ +" {if(hidesection) next};"\ +" {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\ +" {split(\$ 0,a,/\||\r/); split(a2,s)};"\ +" s1~/^@?/{print f,s1,s1; next};"\ +" s1~prfx {split(s1,t,\"@\"); print f,t1,substr(t1,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 can'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* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$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 yes = "$pipe_works"; 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_import, lt_cv_sys_global_symbol_to_import, 1, + Transform the output of nm into a list of symbols to manually relocate) +_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_interface, lt_cv_nm_interface, 1, + The name lister interface) +_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 yes = "$GXX"; 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 ia64 = "$host_cpu"; then + # AIX 5 now supports IA64 processor + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + + 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') + case $host_os in + os2*) + _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' + ;; + esac + ;; + 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)= + ;; + interix3-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 + aix4-9*) + # All AIX code is PIC. + if test ia64 = "$host_cpu"; 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 ia64 != "$host_cpu"; 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* | bgxlcC* | mpixlcC*) + # 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 yes = "$GCC"; 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 ia64 = "$host_cpu"; then + # AIX 5 now supports IA64 processor + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + + 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') + case $host_os in + os2*) + _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' + ;; + esac + ;; + + 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 + ;; + + interix3-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 ia64 = "$host_cpu"; 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 + ;; + + 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' + case $cc_basename in + 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' + ;; + esac + ;; + + 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') + case $host_os in + os2*) + _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' + ;; + esac + ;; + + 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' + ;; + tcc*) + # Fabrice Bellard et al's Tiny 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)='-static' + ;; + 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 that 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__FID_.*' + case $host_os in + aix4-9*) + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to GNU nm, but means don't demangle to AIX nm. + # Without the "-l" option, or with the "-B" option, AIX nm treats + # weak defined symbols like other global defined symbols, whereas + # GNU nm marks them as "W". + # While the 'weak' keyword is ignored in the Export File, we need + # it in the Import File for the 'aix-soname' feature, so we have + # to replace the "-B" option with "-P" for AIX nm. + 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) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' + else + _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\(^B*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | 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__FID_.*' + # 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 yes != "$GCC"; then + with_gnu_ld=no + fi + ;; + interix*) + # we just hope/assume this is gcc and not c89 (= MSVC++) + with_gnu_ld=yes + ;; + openbsd* | bitrig*) + 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 yes = "$with_gnu_ld"; 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 yes = "$lt_use_gnu_ld_interface"; 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 | $SED -e 's/(^)\+)\s\+//' 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 + aix3-9*) + # On AIX/PPC, the GNU linker is very broken + if test ia64 != "$host_cpu"; 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 <jrb3@best.com> 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, use it as + # is; otherwise, prepend EXPORTS... + _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P($export_symbols); 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 + ;; + + os2*) + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + shrext_cmds=.dll + _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + prefix_cmds="$SED"~ + if test EXPORTS = "`$SED 1q $export_symbols`"; then + prefix_cmds="$prefix_cmds -e 1d"; + fi~ + prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ + cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + ;; + + interix3-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 linux-dietlibc = "$host_os"; 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 no = "$tmp_diet" + 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' ;; + nagfor*) # NAGFOR 5.3 + tmp_sharedflag='-Wl,-shared' ;; + xlcC* | bgxlcC* | mpixlcC*) # 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 yes = "$supports_anon_versioning"; 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 + tcc*) + _LT_TAGVAR(export_dynamic_flag_spec, $1)='-rdynamic' + ;; + 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 yes = "$supports_anon_versioning"; 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.10-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 cannot +*** 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 no = "$_LT_TAGVAR(ld_shlibs, $1)"; 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 yes = "$GCC" && 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 + ;; + + aix4-9*) + if test ia64 = "$host_cpu"; 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 GNU nm, but means don't demangle to AIX nm. + # Without the "-l" option, or with the "-B" option, AIX nm treats + # weak defined symbols like other global defined symbols, whereas + # GNU nm marks them as "W". + # While the 'weak' keyword is ignored in the Export File, we need + # it in the Import File for the 'aix-soname' feature, so we have + # to replace the "-B" option with "-P" for AIX nm. + 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) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' + else + _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\(^B*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | 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 + # have runtime linking enabled, and use it for executables. + # For shared libraries, we enable/disable runtime linking + # depending on the kind of the shared library created - + # when "with_aix_soname,aix_use_runtimelinking" is: + # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables + # "aix,yes" lib.so shared, rtl:yes, for executables + # lib.a static archive + # "both,no" lib.so.V(shr.o) shared, rtl:yes + # lib.a(lib.so.V) shared, rtl:no, for executables + # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables + # lib.a(lib.so.V) shared, rtl:no + # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables + # lib.a static archive + case $host_os in aix4.23|aix4.23.*|aix5-9*) + for ld_flag in $LDFLAGS; do + if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then + aix_use_runtimelinking=yes + break + fi + done + if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then + # With aix-soname=svr4, we create the lib.so.V shared archives only, + # so we don't have lib.a shared libs to link our executables. + # We have to force runtime linking in this case. + aix_use_runtimelinking=yes + LDFLAGS="$LDFLAGS -Wl,-brtl" + fi + ;; + 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,' + case $with_aix_soname,$aix_use_runtimelinking in + aix,*) ;; # traditional, no import file + svr4,* | *,yes) # use import file + # The Import File defines what to hardcode. + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_direct_absolute, $1)=no + ;; + esac + + if test yes = "$GCC"; 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 yes = "$aix_use_runtimelinking"; then + shared_flag="$shared_flag "'$wl-G' + fi + # Need to ensure runtime linking is disabled for the traditional + # shared library, or the linker may eventually find shared libraries + # /with/ Import File - we do not want to mix them. + shared_flag_aix='-shared' + shared_flag_svr4='-shared $wl-G' + else + # not using gcc + if test ia64 = "$host_cpu"; 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 yes = "$aix_use_runtimelinking"; then + shared_flag='$wl-G' + else + shared_flag='$wl-bM:SRE' + fi + shared_flag_aix='$wl-bM:SRE' + shared_flag_svr4='$wl-G' + 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,yes = "$with_aix_soname,$aix_use_runtimelinking"; 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 -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag + else + if test ia64 = "$host_cpu"; 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 yes = "$with_gnu_ld"; 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 + _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' + # -brtl affects multiple linker settings, -berok does not and is overridden later + compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\(, \\)%-berok\\1%g"`' + if test svr4 != "$with_aix_soname"; then + # This is similar to how AIX traditionally builds its shared libraries. + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' + fi + if test aix != "$with_aix_soname"; then + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' + else + # used by -dlpreopen to get the symbols + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' + fi + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' + 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 + ;; + + bsdi45*) + _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,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' + _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P($export_symbols); then + cp "$export_symbols" "$output_objdir/$soname.def"; + echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; + else + $SED -e '\''s/^/-link -EXPORT:/'\'' < $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 yes = "$GCC"; 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 "x$output_objdir/$soname" = "x$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 "x$output_objdir/$soname" = "x$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 yes,no = "$GCC,$with_gnu_ld"; 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 no = "$with_gnu_ld"; 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 yes,no = "$GCC,$with_gnu_ld"; 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 no = "$with_gnu_ld"; 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 yes = "$GCC"; 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 yes = "$lt_cv_irix_exported_symbol"; 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 + _LT_TAGVAR(link_all_deplibs, $1)=no + 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 + ;; + + linux*) + case $cc_basename in + tcc*) + # Fabrice Bellard et al's Tiny C Compiler + _LT_TAGVAR(ld_shlibs, $1)=yes + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + ;; + + 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* | bitrig*) + 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__`"; 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 + _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' + 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 + shrext_cmds=.dll + _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + prefix_cmds="$SED"~ + if test EXPORTS = "`$SED 1q $export_symbols`"; then + prefix_cmds="$prefix_cmds -e 1d"; + fi~ + prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ + cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + ;; + + osf3*) + if test yes = "$GCC"; 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 yes = "$GCC"; 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 yes = "$GCC"; 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 yes = "$GCC"; 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 sequent = "$host_vendor"; 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 yes = "$GCC"; 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 CANNOT 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 yes = "$GCC"; 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 sni = "$host_vendor"; 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 no = "$_LT_TAGVAR(ld_shlibs, $1)" && 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 yes,yes = "$GCC,$enable_shared"; 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 what 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 no = "$can_build_shared" && 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 yes = "$enable_shared" && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + + aix4-9*) + if test ia64 != "$host_cpu"; then + case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in + yes,aix,yes) ;; # shared object as lib.so file only + yes,svr4,*) ;; # shared object as lib.so archive member only + yes,*) enable_static=no ;; # shared object in lib.a archive as well + esac + 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 yes = "$enable_shared" || 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 no != "$CXX" && + ( (test g++ = "$CXX" && `g++ -v >/dev/null 2>&1` ) || + (test g++ != "$CXX"))); 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 yes != "$_lt_caught_CXX_error"; 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 yes = "$GXX"; 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 yes = "$GXX"; 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 yes = "$with_gnu_ld"; 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 + ;; + aix4-9*) + if test ia64 = "$host_cpu"; 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 + # have runtime linking enabled, and use it for executables. + # For shared libraries, we enable/disable runtime linking + # depending on the kind of the shared library created - + # when "with_aix_soname,aix_use_runtimelinking" is: + # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables + # "aix,yes" lib.so shared, rtl:yes, for executables + # lib.a static archive + # "both,no" lib.so.V(shr.o) shared, rtl:yes + # lib.a(lib.so.V) shared, rtl:no, for executables + # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables + # lib.a(lib.so.V) shared, rtl:no + # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables + # lib.a static archive + case $host_os in aix4.23|aix4.23.*|aix5-9*) + for ld_flag in $LDFLAGS; do + case $ld_flag in + *-brtl*) + aix_use_runtimelinking=yes + break + ;; + esac + done + if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then + # With aix-soname=svr4, we create the lib.so.V shared archives only, + # so we don't have lib.a shared libs to link our executables. + # We have to force runtime linking in this case. + aix_use_runtimelinking=yes + LDFLAGS="$LDFLAGS -Wl,-brtl" + fi + ;; + 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,' + case $with_aix_soname,$aix_use_runtimelinking in + aix,*) ;; # no import file + svr4,* | *,yes) # use import file + # The Import File defines what to hardcode. + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_direct_absolute, $1)=no + ;; + esac + + if test yes = "$GXX"; 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 yes = "$aix_use_runtimelinking"; then + shared_flag=$shared_flag' $wl-G' + fi + # Need to ensure runtime linking is disabled for the traditional + # shared library, or the linker may eventually find shared libraries + # /with/ Import File - we do not want to mix them. + shared_flag_aix='-shared' + shared_flag_svr4='-shared $wl-G' + else + # not using gcc + if test ia64 = "$host_cpu"; 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 yes = "$aix_use_runtimelinking"; then + shared_flag='$wl-G' + else + shared_flag='$wl-bM:SRE' + fi + shared_flag_aix='$wl-bM:SRE' + shared_flag_svr4='$wl-G' + 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,yes = "$with_aix_soname,$aix_use_runtimelinking"; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + # The "-G" linker flag allows undefined symbols. + _LT_TAGVAR(no_undefined_flag, $1)='-bernotok' + # 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 -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag + else + if test ia64 = "$host_cpu"; 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 yes = "$with_gnu_ld"; 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 + _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' + # -brtl affects multiple linker settings, -berok does not and is overridden later + compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\(, \\)%-berok\\1%g"`' + if test svr4 != "$with_aix_soname"; then + # This is similar to how AIX traditionally builds its shared + # libraries. Need -bnortl late, we may have -brtl in LDFLAGS. + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' + fi + if test aix != "$with_aix_soname"; then + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' + else + # used by -dlpreopen to get the symbols + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' + fi + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' + fi + fi + ;; + + beos*) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + # Joseph Beckenbach <jrb3@best.com> 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,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' + _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P($export_symbols); then + cp "$export_symbols" "$output_objdir/$soname.def"; + echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; + else + $SED -e '\''s/^/-link -EXPORT:/'\'' < $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, use it as + # is; otherwise, prepend EXPORTS... + _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P($export_symbols); 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) + ;; + + os2*) + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + shrext_cmds=.dll + _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + prefix_cmds="$SED"~ + if test EXPORTS = "`$SED 1q $export_symbols`"; then + prefix_cmds="$prefix_cmds -e 1d"; + fi~ + prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ + cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + ;; + + 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 "x$output_objdir/$soname" = "x$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 yes = "$GXX"; 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 "x$output_objdir/$soname" = "x$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 no = "$with_gnu_ld"; 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 yes = "$GXX"; then + if test no = "$with_gnu_ld"; 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 + ;; + + interix3-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 yes = "$GXX"; then + if test no = "$with_gnu_ld"; 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 yes = "$supports_anon_versioning"; 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 + ;; + + openbsd* | bitrig*) + 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__`"; 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 yes,no = "$GXX,$with_gnu_ld"; 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 yes,no = "$GXX,$with_gnu_ld"; 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 $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 $wl-h $wl$soname -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 $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 $wl-h $wl$soname -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 CANNOT 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 no = "$_LT_TAGVAR(ld_shlibs, $1)" && 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 yes != "$_lt_caught_CXX_error" + +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 @S|@2 in + .*) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%\\\\@S|@2\$%%"`;; + *) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%@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 x-L = "$p" || + test x-R = "$p"; 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 no = "$pre_test_object_deps_done"; 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 no = "$pre_test_object_deps_done"; 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 +interix3-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)= + ;; +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 no = "$F77"; 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 yes != "$_lt_disable_F77"; 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 no = "$can_build_shared" && 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 yes = "$enable_shared" && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + aix4-9*) + if test ia64 != "$host_cpu"; then + case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in + yes,aix,yes) ;; # shared object as lib.so file only + yes,svr4,*) ;; # shared object as lib.so archive member only + yes,*) enable_static=no ;; # shared object in lib.a archive as well + esac + 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 yes = "$enable_shared" || 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 yes != "$_lt_disable_F77" + +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 no = "$FC"; 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 yes != "$_lt_disable_FC"; 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 no = "$can_build_shared" && 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 yes = "$enable_shared" && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + aix4-9*) + if test ia64 != "$host_cpu"; then + case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in + yes,aix,yes) ;; # shared object as lib.so file only + yes,svr4,*) ;; # shared object as lib.so archive member only + yes,*) enable_static=no ;; # shared object in lib.a archive as well + esac + 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 yes = "$enable_shared" || 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 yes != "$_lt_disable_FC" + +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(AM_PROG_GCJ, AM_PROG_GCJ, + AC_CHECK_TOOL(GCJ, gcj,) + test set = "${GCJFLAGS+set}" || 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 10 -lt "$lt_ac_count" && 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, +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_PATH_CONVERSION_FUNCTIONS +# ----------------------------- +# Determine what 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
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/m4/ltoptions.m4
Added
@@ -0,0 +1,437 @@ +# Helper functions for option handling. -*- Autoconf -*- +# +# Copyright (C) 2004-2005, 2007-2009, 2011-2015 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 8 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_UNLESS_OPTIONS(LT_INIT, aix-soname=aix aix-soname=both aix-soname=svr4, + _LT_WITH_AIX_SONAME(aix)) + ) +)# _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_AIX_SONAME(DEFAULT) +# ---------------------------------- +# implement the --with-aix-soname flag, and support the `aix-soname=aix' +# and `aix-soname=both' and `aix-soname=svr4' LT_INIT options. DEFAULT +# is either `aix', `both' or `svr4'. If omitted, it defaults to `aix'. +m4_define(_LT_WITH_AIX_SONAME, +m4_define(_LT_WITH_AIX_SONAME_DEFAULT, m4_if($1, svr4, svr4, m4_if($1, both, both, aix)))dnl +shared_archive_member_spec= +case $host,$enable_shared in +power*-*-aix5-9*,yes) + AC_MSG_CHECKING(which variant of shared library versioning to provide) + AC_ARG_WITH(aix-soname, + AS_HELP_STRING(--with-aix-soname=aix|svr4|both, + shared library versioning (aka "SONAME") variant to provide on AIX, @<:@default=_LT_WITH_AIX_SONAME_DEFAULT@:>@.), + case $withval in + aix|svr4|both) + ;; + *) + AC_MSG_ERROR(Unknown argument to --with-aix-soname) + ;; + esac + lt_cv_with_aix_soname=$with_aix_soname, + AC_CACHE_VAL(lt_cv_with_aix_soname, + lt_cv_with_aix_soname=_LT_WITH_AIX_SONAME_DEFAULT) + with_aix_soname=$lt_cv_with_aix_soname) + AC_MSG_RESULT($with_aix_soname) + if test aix != "$with_aix_soname"; then + # For the AIX way of multilib, we name the shared archive member + # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o', + # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File. + # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag, + # the AIX toolchain works better with OBJECT_MODE set (default 32). + if test 64 = "${OBJECT_MODE-32}"; then + shared_archive_member_spec=shr_64 + else + shared_archive_member_spec=shr + fi + fi + ;; +*) + with_aix_soname=aix + ;; +esac + +_LT_DECL(, shared_archive_member_spec, 0, + Shared archive member basename, for filename based shared library versioning on AIX)dnl +)# _LT_WITH_AIX_SONAME + +LT_OPTION_DEFINE(LT_INIT, aix-soname=aix, _LT_WITH_AIX_SONAME(aix)) +LT_OPTION_DEFINE(LT_INIT, aix-soname=both, _LT_WITH_AIX_SONAME(both)) +LT_OPTION_DEFINE(LT_INIT, aix-soname=svr4, _LT_WITH_AIX_SONAME(svr4)) + + +# _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=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))
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/m4/ltsugar.m4
Added
@@ -0,0 +1,124 @@ +# ltsugar.m4 -- libtool m4 base layer. -*-Autoconf-*- +# +# Copyright (C) 2004-2005, 2007-2008, 2011-2015 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)$3m4_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($3m4_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 +)
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/m4/ltversion.m4
Added
@@ -0,0 +1,23 @@ +# ltversion.m4 -- version numbers -*- Autoconf -*- +# +# Copyright (C) 2004, 2011-2015 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 4179 ltversion.m4 +# This file is part of GNU Libtool + +m4_define(LT_PACKAGE_VERSION, 2.4.6) +m4_define(LT_PACKAGE_REVISION, 2.4.6) + +AC_DEFUN(LTVERSION_VERSION, +macro_version='2.4.6' +macro_revision='2.4.6' +_LT_DECL(, macro_version, 0, Which release of libtool.m4 was used?) +_LT_DECL(, macro_revision, 0) +)
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/m4/lt~obsolete.m4
Added
@@ -0,0 +1,99 @@ +# lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*- +# +# Copyright (C) 2004-2005, 2007, 2009, 2011-2015 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))
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/Makefile.am -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/Makefile.am
Changed
@@ -6,16 +6,67 @@ # COMMON_SO_LDFLAGS = $(LDFLAGS_NOSTARTFILES) -lib_LIBRARIES = +# +# Which libraries to build and install +# +# Order is important here. The names of teh libraries need to end up in reverse +# dependency order for `make install` to do its job properly. +# lib_LTLIBRARIES = if !REMOTE_ONLY -lib_LTLIBRARIES += libunwind.la -if BUILD_PTRACE -lib_LTLIBRARIES += libunwind-ptrace.la + lib_LTLIBRARIES += libunwind.la +endif +if ARCH_AARCH64 + lib_LTLIBRARIES += libunwind-aarch64.la +endif +if ARCH_ARM + lib_LTLIBRARIES += libunwind-arm.la +endif +if ARCH_HPPA + lib_LTLIBRARIES += libunwind-hppa.la +endif +if ARCH_IA64 + lib_LTLIBRARIES += libunwind-ia64.la +endif +if ARCH_LOONGARCH64 + lib_LTLIBRARIES += libunwind-loongarch64.la +endif +if ARCH_MIPS + lib_LTLIBRARIES += libunwind-mips.la +endif +if ARCH_PPC32 + lib_LTLIBRARIES += libunwind-ppc32.la +endif +if ARCH_PPC64 + lib_LTLIBRARIES += libunwind-ppc64.la +endif +if ARCH_RISCV + lib_LTLIBRARIES += libunwind-riscv.la +endif +if ARCH_S390X + lib_LTLIBRARIES += libunwind-s390x.la +endif +if ARCH_SH + lib_LTLIBRARIES += libunwind-sh.la endif +if ARCH_TILEGX + lib_LTLIBRARIES += libunwind-tilegx.la +endif +if ARCH_X86 + lib_LTLIBRARIES += libunwind-x86.la +endif +if ARCH_X86_64 + lib_LTLIBRARIES += libunwind-x86_64.la +endif + if BUILD_COREDUMP -lib_LTLIBRARIES += libunwind-coredump.la + lib_LTLIBRARIES += libunwind-coredump.la +endif +if BUILD_PTRACE + lib_LTLIBRARIES += libunwind-ptrace.la endif +if BUILD_SETJMP + lib_LTLIBRARIES += libunwind-setjmp.la endif noinst_HEADERS = @@ -49,6 +100,7 @@ ptrace/_UPT_find_proc_info.c ptrace/_UPT_get_dyn_info_list_addr.c \ ptrace/_UPT_put_unwind_info.c ptrace/_UPT_get_proc_name.c \ ptrace/_UPT_reg_offset.c ptrace/_UPT_resume.c +libunwind_ptrace_la_LIBADD = libunwind-$(arch).la $(LIBLZMA) noinst_HEADERS += ptrace/_UPT_internal.h ### libunwind-coredump: @@ -61,6 +113,7 @@ coredump/_UCD_find_proc_info.c \ coredump/_UCD_get_proc_name.c \ coredump/_UCD_corefile_elf.c \ + coredump/ucd_file_table.c \ \ coredump/_UPT_elf.c \ coredump/_UPT_access_fpreg.c \ @@ -69,8 +122,10 @@ coredump/_UPT_resume.c libunwind_coredump_la_LDFLAGS = $(COMMON_SO_LDFLAGS) \ -version-info $(COREDUMP_SO_VERSION) -libunwind_coredump_la_LIBADD = $(LIBLZMA) $(LIBZ) -noinst_HEADERS += coredump/_UCD_internal.h coredump/_UCD_lib.h +libunwind_coredump_la_LIBADD = libunwind-$(arch).la $(LIBLZMA) $(LIBZ) +noinst_HEADERS += coredump/_UCD_internal.h \ + coredump/_UCD_lib.h \ + coredump/ucd_file_table.h ### libunwind-setjmp: libunwind_setjmp_la_LDFLAGS = $(COMMON_SO_LDFLAGS) \ @@ -107,6 +162,7 @@ mi/Gdyn-extract.c mi/Gdyn-remote.c mi/Gfind_dynamic_proc_info.c \ mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ + mi/Gget_proc_info_in_range.c \ mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ mi/Gget_reg.c mi/Gset_reg.c \ mi/Gget_fpreg.c mi/Gset_fpreg.c \ @@ -136,6 +192,7 @@ mi/Ldyn-extract.c mi/Lfind_dynamic_proc_info.c \ mi/Lget_accessors.c \ mi/Lget_proc_info_by_ip.c mi/Lget_proc_name.c \ + mi/Lget_proc_info_in_range.c \ mi/Lput_dynamic_unwind_info.c mi/Ldestroy_addr_space.c \ mi/Lget_reg.c mi/Lset_reg.c \ mi/Lget_fpreg.c mi/Lset_fpreg.c \ @@ -360,6 +417,31 @@ riscv/Gglobal.c riscv/Ginit.c riscv/Ginit_local.c riscv/Ginit_remote.c \ riscv/Gis_signal_frame.c riscv/Gregs.c riscv/Gresume.c riscv/Gstep.c +# The list of files that go info libunwind and libunwind-loongarch64: +noinst_HEADERS += loongarch64/init.h loongarch64/offsets.h loongarch64/unwind_i.h +libunwind_la_SOURCES_loongarch64_common = $(libunwind_la_SOURCES_common) \ + loongarch64/is_fpreg.c loongarch64/regname.c + +# The list of files that go into libunwind: +libunwind_la_SOURCES_loongarch64 = $(libunwind_la_SOURCES_loongarch64_common) \ + $(libunwind_la_SOURCES_local) \ + loongarch64/getcontext.S \ + loongarch64/Lapply_reg_state.c loongarch64/Lreg_states_iterate.c \ + loongarch64/Lcreate_addr_space.c loongarch64/Lget_proc_info.c \ + loongarch64/Lget_save_loc.c loongarch64/Lglobal.c loongarch64/Linit.c \ + loongarch64/Linit_local.c loongarch64/Linit_remote.c \ + loongarch64/Lis_signal_frame.c loongarch64/Lregs.c \ + loongarch64/Lresume.c loongarch64/Lstep.c + +libunwind_loongarch64_la_SOURCES_loongarch64 = $(libunwind_la_SOURCES_loongarch64_common) \ + $(libunwind_la_SOURCES_generic) \ + loongarch64/Gapply_reg_state.c loongarch64/Greg_states_iterate.c \ + loongarch64/Gcreate_addr_space.c loongarch64/Gget_proc_info.c \ + loongarch64/Gget_save_loc.c loongarch64/Gglobal.c loongarch64/Ginit.c \ + loongarch64/Ginit_local.c loongarch64/Ginit_remote.c \ + loongarch64/Gis_signal_frame.c loongarch64/Gregs.c \ + loongarch64/Gresume.c loongarch64/Gstep.c + # The list of files that go both into libunwind and libunwind-x86: noinst_HEADERS += x86/init.h x86/offsets.h x86/unwind_i.h libunwind_la_SOURCES_x86_common = $(libunwind_la_SOURCES_common) \ @@ -581,7 +663,6 @@ endif if ARCH_AARCH64 - lib_LTLIBRARIES += libunwind-aarch64.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_aarch64) libunwind_aarch64_la_SOURCES = $(libunwind_aarch64_la_SOURCES_aarch64) libunwind_aarch64_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -593,7 +674,6 @@ libunwind_setjmp_la_SOURCES += aarch64/siglongjmp.S else if ARCH_ARM - lib_LTLIBRARIES += libunwind-arm.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_arm) libunwind_arm_la_SOURCES = $(libunwind_arm_la_SOURCES_arm) libunwind_arm_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -615,7 +695,6 @@ Lcursor_i.h: mk_Lcursor_i.s "$(srcdir)/ia64/mk_cursor_i" mk_Lcursor_i.s > Lcursor_i.h - lib_LTLIBRARIES += libunwind-ia64.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_ia64) libunwind_ia64_la_SOURCES = $(libunwind_ia64_la_SOURCES_ia64) libunwind_ia64_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -627,7 +706,6 @@ ia64/longjmp.S ia64/siglongjmp.S else if ARCH_HPPA - lib_LTLIBRARIES += libunwind-hppa.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_hppa) libunwind_hppa_la_SOURCES = $(libunwind_hppa_la_SOURCES_hppa) libunwind_hppa_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -639,7 +717,6 @@ libunwind_setjmp_la_SOURCES += hppa/siglongjmp.S else if ARCH_MIPS - lib_LTLIBRARIES += libunwind-mips.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_mips) libunwind_mips_la_SOURCES = $(libunwind_mips_la_SOURCES_mips) libunwind_mips_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -651,7 +728,6 @@ libunwind_setjmp_la_SOURCES += mips/siglongjmp.S else if ARCH_TILEGX - lib_LTLIBRARIES += libunwind-tilegx.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_tilegx) libunwind_tilegx_la_SOURCES = $(libunwind_tilegx_la_SOURCES_tilegx) libunwind_tilegx_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -663,7 +739,6 @@ libunwind_setjmp_la_SOURCES += tilegx/siglongjmp.S else if ARCH_RISCV - lib_LTLIBRARIES += libunwind-riscv.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_riscv) libunwind_riscv_la_SOURCES = $(libunwind_riscv_la_SOURCES_riscv) libunwind_riscv_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -674,8 +749,18 @@ endif libunwind_setjmp_la_SOURCES += riscv/siglongjmp.S else +if ARCH_LOONGARCH64 + libunwind_la_SOURCES = $(libunwind_la_SOURCES_loongarch64) + libunwind_loongarch64_la_SOURCES = $(libunwind_loongarch64_la_SOURCES_loongarch64) + libunwind_loongarch64_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) + libunwind_loongarch64_la_LIBADD = libunwind-dwarf-generic.la + libunwind_loongarch64_la_LIBADD += libunwind-elf64.la +if !REMOTE_ONLY + libunwind_loongarch64_la_LIBADD += libunwind.la -lc +endif + libunwind_setjmp_la_SOURCES += loongarch64/siglongjmp.S +else if ARCH_X86 - lib_LTLIBRARIES += libunwind-x86.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_x86) $(libunwind_x86_la_SOURCES_os) libunwind_x86_la_SOURCES = $(libunwind_x86_la_SOURCES_x86) libunwind_x86_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -687,7 +772,6 @@ libunwind_setjmp_la_SOURCES += x86/longjmp.S x86/siglongjmp.S else if ARCH_X86_64 - lib_LTLIBRARIES += libunwind-x86_64.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_x86_64) libunwind_x86_64_la_SOURCES = $(libunwind_x86_64_la_SOURCES_x86_64) libunwind_x86_64_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -699,7 +783,6 @@ libunwind_setjmp_la_SOURCES += x86_64/longjmp.S x86_64/siglongjmp.S else if ARCH_PPC32 - lib_LTLIBRARIES += libunwind-ppc32.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_ppc32) libunwind_ppc32_la_SOURCES = $(libunwind_ppc32_la_SOURCES_ppc32) libunwind_ppc32_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -711,7 +794,6 @@ libunwind_setjmp_la_SOURCES += ppc/longjmp.S ppc/siglongjmp.S else if ARCH_PPC64 - lib_LTLIBRARIES += libunwind-ppc64.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_ppc64) libunwind_ppc64_la_SOURCES = $(libunwind_ppc64_la_SOURCES_ppc64) libunwind_ppc64_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -723,7 +805,6 @@ libunwind_setjmp_la_SOURCES += ppc/longjmp.S ppc/siglongjmp.S else if ARCH_SH - lib_LTLIBRARIES += libunwind-sh.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_sh) libunwind_sh_la_SOURCES = $(libunwind_sh_la_SOURCES_sh) libunwind_sh_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -735,7 +816,6 @@ libunwind_setjmp_la_SOURCES += sh/siglongjmp.S else if ARCH_S390X - lib_LTLIBRARIES += libunwind-s390x.la libunwind_la_SOURCES = $(libunwind_la_SOURCES_s390x) libunwind_s390x_la_SOURCES = $(libunwind_s390x_la_SOURCES_s390x) libunwind_s390x_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @@ -751,6 +831,7 @@ endif # ARCH_PPC32 endif # ARCH_X86_64 endif # ARCH_X86 +endif # ARCH_LOONGARCH64 endif # ARCH_RISCV endif # ARCH_TILEGX endif # ARCH_MIPS @@ -759,11 +840,6 @@ endif # ARCH_ARM endif # ARCH_AARCH64 -# libunwind-setjmp depends on libunwind-$(arch). Therefore must be added -# at the end. -if BUILD_SETJMP -lib_LTLIBRARIES += libunwind-setjmp.la -endif # # Don't link with standard libraries, because those may mention
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/Makefile.in -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/Makefile.in
Changed
@@ -1,7 +1,7 @@ -# Makefile.in generated by automake 1.16.4 from Makefile.am. +# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ -# Copyright (C) 1994-2021 Free Software Foundation, Inc. +# 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, @@ -16,7 +16,6 @@ - VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ @@ -93,68 +92,70 @@ host_triplet = @host@ target_triplet = @target@ @REMOTE_ONLY_FALSE@am__append_1 = libunwind.la -@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@am__append_2 = libunwind-ptrace.la -@BUILD_COREDUMP_TRUE@@REMOTE_ONLY_FALSE@am__append_3 = libunwind-coredump.la -@REMOTE_ONLY_FALSE@am__append_4 = unwind/libunwind.pc -@BUILD_PTRACE_TRUE@am__append_5 = ptrace/libunwind-ptrace.pc -@BUILD_SETJMP_TRUE@am__append_6 = setjmp/libunwind-setjmp.pc -@BUILD_COREDUMP_TRUE@am__append_7 = coredump/libunwind-coredump.pc -@USE_DWARF_TRUE@am__append_8 = libunwind-dwarf-common.la libunwind-dwarf-generic.la -@REMOTE_ONLY_FALSE@@USE_DWARF_TRUE@am__append_9 = libunwind-dwarf-local.la -@USE_DWARF_TRUE@am__append_10 = libunwind-dwarf-local.la -@OS_LINUX_TRUE@am__append_11 = coredump/_UCD_access_reg_linux.c \ +@ARCH_AARCH64_TRUE@am__append_2 = libunwind-aarch64.la +@ARCH_ARM_TRUE@am__append_3 = libunwind-arm.la +@ARCH_HPPA_TRUE@am__append_4 = libunwind-hppa.la +@ARCH_IA64_TRUE@am__append_5 = libunwind-ia64.la +@ARCH_LOONGARCH64_TRUE@am__append_6 = libunwind-loongarch64.la +@ARCH_MIPS_TRUE@am__append_7 = libunwind-mips.la +@ARCH_PPC32_TRUE@am__append_8 = libunwind-ppc32.la +@ARCH_PPC64_TRUE@am__append_9 = libunwind-ppc64.la +@ARCH_RISCV_TRUE@am__append_10 = libunwind-riscv.la +@ARCH_S390X_TRUE@am__append_11 = libunwind-s390x.la +@ARCH_SH_TRUE@am__append_12 = libunwind-sh.la +@ARCH_TILEGX_TRUE@am__append_13 = libunwind-tilegx.la +@ARCH_X86_TRUE@am__append_14 = libunwind-x86.la +@ARCH_X86_64_TRUE@am__append_15 = libunwind-x86_64.la +@BUILD_COREDUMP_TRUE@am__append_16 = libunwind-coredump.la +@BUILD_PTRACE_TRUE@am__append_17 = libunwind-ptrace.la +@BUILD_SETJMP_TRUE@am__append_18 = libunwind-setjmp.la +@REMOTE_ONLY_FALSE@am__append_19 = unwind/libunwind.pc +@BUILD_PTRACE_TRUE@am__append_20 = ptrace/libunwind-ptrace.pc +@BUILD_SETJMP_TRUE@am__append_21 = setjmp/libunwind-setjmp.pc +@BUILD_COREDUMP_TRUE@am__append_22 = coredump/libunwind-coredump.pc +@USE_DWARF_TRUE@am__append_23 = libunwind-dwarf-common.la libunwind-dwarf-generic.la +@REMOTE_ONLY_FALSE@@USE_DWARF_TRUE@am__append_24 = libunwind-dwarf-local.la +@USE_DWARF_TRUE@am__append_25 = libunwind-dwarf-local.la +@OS_LINUX_TRUE@am__append_26 = coredump/_UCD_access_reg_linux.c \ @OS_LINUX_TRUE@ coredump/_UCD_get_threadinfo_prstatus.c \ @OS_LINUX_TRUE@ coredump/_UCD_get_mapinfo_linux.c -@OS_FREEBSD_TRUE@am__append_12 = coredump/_UCD_access_reg_freebsd.c \ +@OS_FREEBSD_TRUE@am__append_27 = coredump/_UCD_access_reg_freebsd.c \ @OS_FREEBSD_TRUE@ coredump/_UCD_get_threadinfo_prstatus.c \ @OS_FREEBSD_TRUE@ coredump/_UCD_get_mapinfo_generic.c -@ARCH_AARCH64_TRUE@am__append_13 = libunwind-aarch64.la -@ARCH_AARCH64_TRUE@@REMOTE_ONLY_FALSE@am__append_14 = libunwind.la -lc -@ARCH_AARCH64_TRUE@am__append_15 = aarch64/siglongjmp.S -@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@am__append_16 = libunwind-arm.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@@REMOTE_ONLY_FALSE@am__append_17 = libunwind.la -lc -@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@am__append_18 = arm/siglongjmp.S -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@am__append_19 = libunwind-ia64.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@am__append_20 = libunwind.la -lc -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@am__append_21 = ia64/setjmp.S ia64/sigsetjmp.S \ +@ARCH_AARCH64_TRUE@@REMOTE_ONLY_FALSE@am__append_28 = libunwind.la -lc +@ARCH_AARCH64_TRUE@am__append_29 = aarch64/siglongjmp.S +@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@@REMOTE_ONLY_FALSE@am__append_30 = libunwind.la -lc +@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@am__append_31 = arm/siglongjmp.S +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@am__append_32 = libunwind.la -lc +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@am__append_33 = ia64/setjmp.S ia64/sigsetjmp.S \ @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@ ia64/longjmp.S ia64/siglongjmp.S -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@am__append_22 = libunwind-hppa.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@@REMOTE_ONLY_FALSE@am__append_23 = libunwind.la -lc -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@am__append_24 = hppa/siglongjmp.S -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@am__append_25 = libunwind-mips.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@@REMOTE_ONLY_FALSE@am__append_26 = libunwind.la -lc -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@am__append_27 = mips/siglongjmp.S -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@am__append_28 = libunwind-tilegx.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@@REMOTE_ONLY_FALSE@am__append_29 = libunwind.la -lc -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@am__append_30 = tilegx/siglongjmp.S -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@am__append_31 = libunwind-riscv.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@@REMOTE_ONLY_FALSE@am__append_32 = libunwind.la -lc -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@am__append_33 = riscv/siglongjmp.S -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@am__append_34 = libunwind-x86.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@@REMOTE_ONLY_FALSE@am__append_35 = libunwind.la -lc -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@am__append_36 = x86/longjmp.S x86/siglongjmp.S -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@am__append_37 = libunwind-x86_64.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__append_38 = libunwind.la -lc -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@am__append_39 = x86_64/longjmp.S x86_64/siglongjmp.S -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__append_40 = libunwind-ppc32.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__append_41 = libunwind.la -lc -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__append_42 = ppc/longjmp.S ppc/siglongjmp.S -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__append_43 = libunwind-ppc64.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__append_44 = libunwind.la -lc -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__append_45 = ppc/longjmp.S ppc/siglongjmp.S -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__append_46 = libunwind-sh.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__append_47 = libunwind.la -lc -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__append_48 = sh/siglongjmp.S -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__append_49 = libunwind-s390x.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__append_50 = libunwind.la -lc - -# libunwind-setjmp depends on libunwind-$(arch). Therefore must be added -# at the end. -@BUILD_SETJMP_TRUE@am__append_51 = libunwind-setjmp.la +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@@REMOTE_ONLY_FALSE@am__append_34 = libunwind.la -lc +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@am__append_35 = hppa/siglongjmp.S +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@@REMOTE_ONLY_FALSE@am__append_36 = libunwind.la -lc +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@am__append_37 = mips/siglongjmp.S +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@@REMOTE_ONLY_FALSE@am__append_38 = libunwind.la -lc +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@am__append_39 = tilegx/siglongjmp.S +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@@REMOTE_ONLY_FALSE@am__append_40 = libunwind.la -lc +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@am__append_41 = riscv/siglongjmp.S +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@REMOTE_ONLY_FALSE@am__append_42 = libunwind.la -lc +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@am__append_43 = loongarch64/siglongjmp.S +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@@REMOTE_ONLY_FALSE@am__append_44 = libunwind.la -lc +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@am__append_45 = x86/longjmp.S x86/siglongjmp.S +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__append_46 = libunwind.la -lc +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@am__append_47 = x86_64/longjmp.S x86_64/siglongjmp.S +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__append_48 = libunwind.la -lc +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__append_49 = ppc/longjmp.S ppc/siglongjmp.S +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__append_50 = libunwind.la -lc +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__append_51 = ppc/longjmp.S ppc/siglongjmp.S +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__append_52 = libunwind.la -lc +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__append_53 = sh/siglongjmp.S +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__append_54 = libunwind.la -lc subdir = src ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/acinclude.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)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) @@ -191,9 +192,7 @@ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } -am__installdirs = "$(DESTDIR)$(libdir)" "$(DESTDIR)$(libdir)" \ - "$(DESTDIR)$(pkgconfigdir)" -LIBRARIES = $(lib_LIBRARIES) +am__installdirs = "$(DESTDIR)$(libdir)" "$(DESTDIR)$(pkgconfigdir)" LTLIBRARIES = $(lib_LTLIBRARIES) $(noinst_LTLIBRARIES) @ARCH_AARCH64_TRUE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_1 = \ @ARCH_AARCH64_TRUE@@REMOTE_ONLY_FALSE@ libunwind.la @@ -206,15 +205,16 @@ aarch64/regname.c mi/Gdyn-extract.c mi/Gdyn-remote.c \ mi/Gfind_dynamic_proc_info.c mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ - mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ - mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ - mi/Gset_caching_policy.c mi/Gset_cache_size.c \ - aarch64/Gapply_reg_state.c aarch64/Greg_states_iterate.c \ - aarch64/Gcreate_addr_space.c aarch64/Gget_proc_info.c \ - aarch64/Gget_save_loc.c aarch64/Gglobal.c aarch64/Ginit.c \ - aarch64/Ginit_local.c aarch64/Ginit_remote.c \ - aarch64/Gis_signal_frame.c aarch64/Gregs.c aarch64/Gresume.c \ - aarch64/Gstash_frame.c aarch64/Gstep.c aarch64/Gtrace.c + mi/Gget_proc_info_in_range.c mi/Gput_dynamic_unwind_info.c \ + mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ + mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ + mi/Gset_cache_size.c aarch64/Gapply_reg_state.c \ + aarch64/Greg_states_iterate.c aarch64/Gcreate_addr_space.c \ + aarch64/Gget_proc_info.c aarch64/Gget_save_loc.c \ + aarch64/Gglobal.c aarch64/Ginit.c aarch64/Ginit_local.c \ + aarch64/Ginit_remote.c aarch64/Gis_signal_frame.c \ + aarch64/Gregs.c aarch64/Gresume.c aarch64/Gstash_frame.c \ + aarch64/Gstep.c aarch64/Gtrace.c am__objects_1 = os-freebsd.lo am__objects_2 = os-hpux.lo am__objects_3 = os-linux.lo dl-iterate-phdr.lo @@ -233,9 +233,9 @@ am__objects_9 = mi/Gdyn-extract.lo mi/Gdyn-remote.lo \ mi/Gfind_dynamic_proc_info.lo mi/Gget_accessors.lo \ mi/Gget_proc_info_by_ip.lo mi/Gget_proc_name.lo \ - mi/Gput_dynamic_unwind_info.lo mi/Gdestroy_addr_space.lo \ - mi/Gget_reg.lo mi/Gset_reg.lo mi/Gget_fpreg.lo \ - mi/Gset_fpreg.lo mi/Gset_caching_policy.lo \ + mi/Gget_proc_info_in_range.lo mi/Gput_dynamic_unwind_info.lo \ + mi/Gdestroy_addr_space.lo mi/Gget_reg.lo mi/Gset_reg.lo \ + mi/Gget_fpreg.lo mi/Gset_fpreg.lo mi/Gset_caching_policy.lo \ mi/Gset_cache_size.lo am__objects_10 = $(am__objects_8) $(am__objects_9) \ aarch64/Gapply_reg_state.lo aarch64/Greg_states_iterate.lo \ @@ -269,14 +269,15 @@ arm/Gos-other.c mi/Gdyn-extract.c mi/Gdyn-remote.c \ mi/Gfind_dynamic_proc_info.c mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ - mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ - mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ - mi/Gset_caching_policy.c mi/Gset_cache_size.c \ - arm/Gapply_reg_state.c arm/Greg_states_iterate.c \ - arm/Gcreate_addr_space.c arm/Gget_proc_info.c \ - arm/Gget_save_loc.c arm/Gglobal.c arm/Ginit.c \ - arm/Ginit_local.c arm/Ginit_remote.c arm/Gregs.c arm/Gresume.c \ - arm/Gstep.c arm/Gex_tables.c arm/Gstash_frame.c arm/Gtrace.c + mi/Gget_proc_info_in_range.c mi/Gput_dynamic_unwind_info.c \ + mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ + mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ + mi/Gset_cache_size.c arm/Gapply_reg_state.c \ + arm/Greg_states_iterate.c arm/Gcreate_addr_space.c \ + arm/Gget_proc_info.c arm/Gget_save_loc.c arm/Gglobal.c \ + arm/Ginit.c arm/Ginit_local.c arm/Ginit_remote.c arm/Gregs.c \ + arm/Gresume.c arm/Gstep.c arm/Gex_tables.c arm/Gstash_frame.c \ + arm/Gtrace.c am__objects_11 = $(am__objects_7) arm/is_fpreg.lo arm/regname.lo @OS_FREEBSD_FALSE@@OS_LINUX_FALSE@@OS_QNX_TRUE@am__objects_12 = arm/Gos-other.lo @OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_12 = arm/Gos-linux.lo @@ -295,17 +296,16 @@ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_arm_la_LDFLAGS) $(LDFLAGS) \ -o $@ -@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@am_libunwind_arm_la_rpath = -rpath \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@ $(libdir) +@ARCH_ARM_TRUE@am_libunwind_arm_la_rpath = -rpath $(libdir) am__DEPENDENCIES_3 = -libunwind_coredump_la_DEPENDENCIES = $(am__DEPENDENCIES_3) \ - $(am__DEPENDENCIES_3) +libunwind_coredump_la_DEPENDENCIES = libunwind-$(arch).la \ + $(am__DEPENDENCIES_3) $(am__DEPENDENCIES_3) am__libunwind_coredump_la_SOURCES_DIST = coredump/_UCD_accessors.c \ coredump/_UCD_create.c coredump/_UCD_destroy.c \ coredump/_UCD_access_mem.c coredump/_UCD_elf_map_image.c \ coredump/_UCD_find_proc_info.c coredump/_UCD_get_proc_name.c \ - coredump/_UCD_corefile_elf.c coredump/_UPT_elf.c \ - coredump/_UPT_access_fpreg.c \ + coredump/_UCD_corefile_elf.c coredump/ucd_file_table.c \ + coredump/_UPT_elf.c coredump/_UPT_access_fpreg.c \ coredump/_UPT_get_dyn_info_list_addr.c \ coredump/_UPT_put_unwind_info.c coredump/_UPT_resume.c \ coredump/_UCD_access_reg_linux.c \ @@ -323,8 +323,8 @@ coredump/_UCD_create.lo coredump/_UCD_destroy.lo \ coredump/_UCD_access_mem.lo coredump/_UCD_elf_map_image.lo \ coredump/_UCD_find_proc_info.lo coredump/_UCD_get_proc_name.lo \ - coredump/_UCD_corefile_elf.lo coredump/_UPT_elf.lo \ - coredump/_UPT_access_fpreg.lo \ + coredump/_UCD_corefile_elf.lo coredump/ucd_file_table.lo \ + coredump/_UPT_elf.lo coredump/_UPT_access_fpreg.lo \ coredump/_UPT_get_dyn_info_list_addr.lo \ coredump/_UPT_put_unwind_info.lo coredump/_UPT_resume.lo \ $(am__objects_14) $(am__objects_15) @@ -333,8 +333,7 @@ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_coredump_la_LDFLAGS) \ $(LDFLAGS) -o $@ -@BUILD_COREDUMP_TRUE@@REMOTE_ONLY_FALSE@am_libunwind_coredump_la_rpath = \ -@BUILD_COREDUMP_TRUE@@REMOTE_ONLY_FALSE@ -rpath $(libdir) +@BUILD_COREDUMP_TRUE@am_libunwind_coredump_la_rpath = -rpath $(libdir) libunwind_dwarf_common_la_LIBADD = am_libunwind_dwarf_common_la_OBJECTS = dwarf/global.lo libunwind_dwarf_common_la_OBJECTS = \ @@ -379,14 +378,14 @@ mi/Gdyn-extract.c mi/Gdyn-remote.c \ mi/Gfind_dynamic_proc_info.c mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ - mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ - mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ - mi/Gset_caching_policy.c mi/Gset_cache_size.c \ - hppa/Gapply_reg_state.c hppa/Greg_states_iterate.c \ - hppa/Gcreate_addr_space.c hppa/Gget_save_loc.c hppa/Gglobal.c \ - hppa/Ginit.c hppa/Ginit_local.c hppa/Ginit_remote.c \ - hppa/Gis_signal_frame.c hppa/Gget_proc_info.c hppa/Gregs.c \ - hppa/Gresume.c hppa/Gstep.c + mi/Gget_proc_info_in_range.c mi/Gput_dynamic_unwind_info.c \ + mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ + mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ + mi/Gset_cache_size.c hppa/Gapply_reg_state.c \ + hppa/Greg_states_iterate.c hppa/Gcreate_addr_space.c \ + hppa/Gget_save_loc.c hppa/Gglobal.c hppa/Ginit.c \ + hppa/Ginit_local.c hppa/Ginit_remote.c hppa/Gis_signal_frame.c \ + hppa/Gget_proc_info.c hppa/Gregs.c hppa/Gresume.c hppa/Gstep.c am__objects_16 = $(am__objects_7) hppa/regname.lo am__objects_17 = $(am__objects_16) $(am__objects_9) \ hppa/Gapply_reg_state.lo hppa/Greg_states_iterate.lo \ @@ -401,8 +400,7 @@ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_hppa_la_LDFLAGS) $(LDFLAGS) \ -o $@ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@am_libunwind_hppa_la_rpath = -rpath \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@ $(libdir) +@ARCH_HPPA_TRUE@am_libunwind_hppa_la_rpath = -rpath $(libdir) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_5 = libunwind.la @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@libunwind_ia64_la_DEPENDENCIES = libunwind-elf64.la \ @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@ $(am__DEPENDENCIES_5) @@ -412,16 +410,16 @@ mi/Gdyn-extract.c mi/Gdyn-remote.c \ mi/Gfind_dynamic_proc_info.c mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ - mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ - mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ - mi/Gset_caching_policy.c mi/Gset_cache_size.c \ - ia64/Gapply_reg_state.c ia64/Greg_states_iterate.c \ - ia64/Gcreate_addr_space.c ia64/Gget_proc_info.c \ - ia64/Gget_save_loc.c ia64/Gglobal.c ia64/Ginit.c \ - ia64/Ginit_local.c ia64/Ginit_remote.c ia64/Ginstall_cursor.S \ - ia64/Gis_signal_frame.c ia64/Gparser.c ia64/Grbs.c \ - ia64/Gregs.c ia64/Gresume.c ia64/Gscript.c ia64/Gstep.c \ - ia64/Gtables.c ia64/Gfind_unwind_table.c + mi/Gget_proc_info_in_range.c mi/Gput_dynamic_unwind_info.c \ + mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ + mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ + mi/Gset_cache_size.c ia64/Gapply_reg_state.c \ + ia64/Greg_states_iterate.c ia64/Gcreate_addr_space.c \ + ia64/Gget_proc_info.c ia64/Gget_save_loc.c ia64/Gglobal.c \ + ia64/Ginit.c ia64/Ginit_local.c ia64/Ginit_remote.c \ + ia64/Ginstall_cursor.S ia64/Gis_signal_frame.c ia64/Gparser.c \ + ia64/Grbs.c ia64/Gregs.c ia64/Gresume.c ia64/Gscript.c \ + ia64/Gstep.c ia64/Gtables.c ia64/Gfind_unwind_table.c am__objects_18 = $(am__objects_7) ia64/regname.lo am__objects_19 = $(am__objects_18) $(am__objects_9) \ ia64/Gapply_reg_state.lo ia64/Greg_states_iterate.lo \ @@ -438,110 +436,150 @@ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_ia64_la_LDFLAGS) $(LDFLAGS) \ -o $@ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@am_libunwind_ia64_la_rpath = \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@ -rpath \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@ $(libdir) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_6 = libunwind.la +@ARCH_IA64_TRUE@am_libunwind_ia64_la_rpath = -rpath $(libdir) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_6 = libunwind.la +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@libunwind_loongarch64_la_DEPENDENCIES = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@ libunwind-elf64.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@ $(am__DEPENDENCIES_6) +am__libunwind_loongarch64_la_SOURCES_DIST = os-freebsd.c os-hpux.c \ + os-linux.c dl-iterate-phdr.c os-qnx.c os-solaris.c mi/init.c \ + mi/flush_cache.c mi/mempool.c mi/strerror.c \ + loongarch64/is_fpreg.c loongarch64/regname.c mi/Gdyn-extract.c \ + mi/Gdyn-remote.c mi/Gfind_dynamic_proc_info.c \ + mi/Gget_accessors.c mi/Gget_proc_info_by_ip.c \ + mi/Gget_proc_name.c mi/Gget_proc_info_in_range.c \ + mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ + mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ + mi/Gset_caching_policy.c mi/Gset_cache_size.c \ + loongarch64/Gapply_reg_state.c \ + loongarch64/Greg_states_iterate.c \ + loongarch64/Gcreate_addr_space.c loongarch64/Gget_proc_info.c \ + loongarch64/Gget_save_loc.c loongarch64/Gglobal.c \ + loongarch64/Ginit.c loongarch64/Ginit_local.c \ + loongarch64/Ginit_remote.c loongarch64/Gis_signal_frame.c \ + loongarch64/Gregs.c loongarch64/Gresume.c loongarch64/Gstep.c +am__objects_20 = $(am__objects_7) loongarch64/is_fpreg.lo \ + loongarch64/regname.lo +am__objects_21 = $(am__objects_20) $(am__objects_9) \ + loongarch64/Gapply_reg_state.lo \ + loongarch64/Greg_states_iterate.lo \ + loongarch64/Gcreate_addr_space.lo \ + loongarch64/Gget_proc_info.lo loongarch64/Gget_save_loc.lo \ + loongarch64/Gglobal.lo loongarch64/Ginit.lo \ + loongarch64/Ginit_local.lo loongarch64/Ginit_remote.lo \ + loongarch64/Gis_signal_frame.lo loongarch64/Gregs.lo \ + loongarch64/Gresume.lo loongarch64/Gstep.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@am_libunwind_loongarch64_la_OBJECTS = $(am__objects_21) +libunwind_loongarch64_la_OBJECTS = \ + $(am_libunwind_loongarch64_la_OBJECTS) +libunwind_loongarch64_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ + $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ + $(AM_CFLAGS) $(CFLAGS) $(libunwind_loongarch64_la_LDFLAGS) \ + $(LDFLAGS) -o $@ +@ARCH_LOONGARCH64_TRUE@am_libunwind_loongarch64_la_rpath = -rpath \ +@ARCH_LOONGARCH64_TRUE@ $(libdir) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_7 = libunwind.la @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@libunwind_mips_la_DEPENDENCIES = libunwind-dwarf-generic.la \ @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@ libunwind-elfxx.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@ $(am__DEPENDENCIES_6) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@ $(am__DEPENDENCIES_7) am__libunwind_mips_la_SOURCES_DIST = os-freebsd.c os-hpux.c os-linux.c \ dl-iterate-phdr.c os-qnx.c os-solaris.c mi/init.c \ mi/flush_cache.c mi/mempool.c mi/strerror.c mips/is_fpreg.c \ mips/regname.c mi/Gdyn-extract.c mi/Gdyn-remote.c \ mi/Gfind_dynamic_proc_info.c mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ - mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ - mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ - mi/Gset_caching_policy.c mi/Gset_cache_size.c \ - mips/Gapply_reg_state.c mips/Greg_states_iterate.c \ - mips/Gcreate_addr_space.c mips/Gget_proc_info.c \ - mips/Gget_save_loc.c mips/Gglobal.c mips/Ginit.c \ - mips/Ginit_local.c mips/Ginit_remote.c mips/Gis_signal_frame.c \ - mips/Gregs.c mips/Gresume.c mips/Gstep.c -am__objects_20 = $(am__objects_7) mips/is_fpreg.lo mips/regname.lo -am__objects_21 = $(am__objects_20) $(am__objects_9) \ + mi/Gget_proc_info_in_range.c mi/Gput_dynamic_unwind_info.c \ + mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ + mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ + mi/Gset_cache_size.c mips/Gapply_reg_state.c \ + mips/Greg_states_iterate.c mips/Gcreate_addr_space.c \ + mips/Gget_proc_info.c mips/Gget_save_loc.c mips/Gglobal.c \ + mips/Ginit.c mips/Ginit_local.c mips/Ginit_remote.c \ + mips/Gis_signal_frame.c mips/Gregs.c mips/Gresume.c \ + mips/Gstep.c +am__objects_22 = $(am__objects_7) mips/is_fpreg.lo mips/regname.lo +am__objects_23 = $(am__objects_22) $(am__objects_9) \ mips/Gapply_reg_state.lo mips/Greg_states_iterate.lo \ mips/Gcreate_addr_space.lo mips/Gget_proc_info.lo \ mips/Gget_save_loc.lo mips/Gglobal.lo mips/Ginit.lo \ mips/Ginit_local.lo mips/Ginit_remote.lo \ mips/Gis_signal_frame.lo mips/Gregs.lo mips/Gresume.lo \ mips/Gstep.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@am_libunwind_mips_la_OBJECTS = $(am__objects_21) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@am_libunwind_mips_la_OBJECTS = $(am__objects_23) libunwind_mips_la_OBJECTS = $(am_libunwind_mips_la_OBJECTS) libunwind_mips_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_mips_la_LDFLAGS) $(LDFLAGS) \ -o $@ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@am_libunwind_mips_la_rpath = -rpath \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@ $(libdir) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_7 = libunwind.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc32_la_DEPENDENCIES = libunwind-dwarf-generic.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf32.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__DEPENDENCIES_7) +@ARCH_MIPS_TRUE@am_libunwind_mips_la_rpath = -rpath $(libdir) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_8 = libunwind.la +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc32_la_DEPENDENCIES = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf32.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__DEPENDENCIES_8) am__libunwind_ppc32_la_SOURCES_DIST = os-freebsd.c os-hpux.c \ os-linux.c dl-iterate-phdr.c os-qnx.c os-solaris.c mi/init.c \ mi/flush_cache.c mi/mempool.c mi/strerror.c ppc32/is_fpreg.c \ ppc32/regname.c ppc32/get_func_addr.c mi/Gdyn-extract.c \ mi/Gdyn-remote.c mi/Gfind_dynamic_proc_info.c \ mi/Gget_accessors.c mi/Gget_proc_info_by_ip.c \ - mi/Gget_proc_name.c mi/Gput_dynamic_unwind_info.c \ - mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ - mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ - mi/Gset_cache_size.c ppc/Gget_proc_info.c ppc/Gget_save_loc.c \ - ppc/Ginit_local.c ppc/Ginit_remote.c ppc/Gis_signal_frame.c \ + mi/Gget_proc_name.c mi/Gget_proc_info_in_range.c \ + mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ + mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ + mi/Gset_caching_policy.c mi/Gset_cache_size.c \ + ppc/Gget_proc_info.c ppc/Gget_save_loc.c ppc/Ginit_local.c \ + ppc/Ginit_remote.c ppc/Gis_signal_frame.c \ ppc32/Gapply_reg_state.c ppc32/Greg_states_iterate.c \ ppc32/Gcreate_addr_space.c ppc32/Gglobal.c ppc32/Ginit.c \ ppc32/Gregs.c ppc32/Gresume.c ppc32/Gstep.c -am__objects_22 = $(am__objects_7) ppc32/is_fpreg.lo ppc32/regname.lo \ +am__objects_24 = $(am__objects_7) ppc32/is_fpreg.lo ppc32/regname.lo \ ppc32/get_func_addr.lo -am__objects_23 = ppc/Gget_proc_info.lo ppc/Gget_save_loc.lo \ +am__objects_25 = ppc/Gget_proc_info.lo ppc/Gget_save_loc.lo \ ppc/Ginit_local.lo ppc/Ginit_remote.lo ppc/Gis_signal_frame.lo -am__objects_24 = $(am__objects_22) $(am__objects_9) $(am__objects_23) \ +am__objects_26 = $(am__objects_24) $(am__objects_9) $(am__objects_25) \ ppc32/Gapply_reg_state.lo ppc32/Greg_states_iterate.lo \ ppc32/Gcreate_addr_space.lo ppc32/Gglobal.lo ppc32/Ginit.lo \ ppc32/Gregs.lo ppc32/Gresume.lo ppc32/Gstep.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_ppc32_la_OBJECTS = $(am__objects_24) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_ppc32_la_OBJECTS = $(am__objects_26) libunwind_ppc32_la_OBJECTS = $(am_libunwind_ppc32_la_OBJECTS) libunwind_ppc32_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_ppc32_la_LDFLAGS) \ $(LDFLAGS) -o $@ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_ppc32_la_rpath = -rpath \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(libdir) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_8 = libunwind.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc64_la_DEPENDENCIES = libunwind-dwarf-generic.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf64.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__DEPENDENCIES_8) +@ARCH_PPC32_TRUE@am_libunwind_ppc32_la_rpath = -rpath $(libdir) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_9 = libunwind.la +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc64_la_DEPENDENCIES = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf64.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__DEPENDENCIES_9) am__libunwind_ppc64_la_SOURCES_DIST = os-freebsd.c os-hpux.c \ os-linux.c dl-iterate-phdr.c os-qnx.c os-solaris.c mi/init.c \ mi/flush_cache.c mi/mempool.c mi/strerror.c ppc64/is_fpreg.c \ ppc64/regname.c ppc64/get_func_addr.c mi/Gdyn-extract.c \ mi/Gdyn-remote.c mi/Gfind_dynamic_proc_info.c \ mi/Gget_accessors.c mi/Gget_proc_info_by_ip.c \ - mi/Gget_proc_name.c mi/Gput_dynamic_unwind_info.c \ - mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ - mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ - mi/Gset_cache_size.c ppc/Gget_proc_info.c ppc/Gget_save_loc.c \ - ppc/Ginit_local.c ppc/Ginit_remote.c ppc/Gis_signal_frame.c \ + mi/Gget_proc_name.c mi/Gget_proc_info_in_range.c \ + mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ + mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ + mi/Gset_caching_policy.c mi/Gset_cache_size.c \ + ppc/Gget_proc_info.c ppc/Gget_save_loc.c ppc/Ginit_local.c \ + ppc/Ginit_remote.c ppc/Gis_signal_frame.c \ ppc64/Gapply_reg_state.c ppc64/Greg_states_iterate.c \ ppc64/Gcreate_addr_space.c ppc64/Gglobal.c ppc64/Ginit.c \ ppc64/Gregs.c ppc64/Gresume.c ppc64/Gstep.c -am__objects_25 = $(am__objects_7) ppc64/is_fpreg.lo ppc64/regname.lo \ +am__objects_27 = $(am__objects_7) ppc64/is_fpreg.lo ppc64/regname.lo \ ppc64/get_func_addr.lo -am__objects_26 = $(am__objects_25) $(am__objects_9) $(am__objects_23) \ +am__objects_28 = $(am__objects_27) $(am__objects_9) $(am__objects_25) \ ppc64/Gapply_reg_state.lo ppc64/Greg_states_iterate.lo \ ppc64/Gcreate_addr_space.lo ppc64/Gglobal.lo ppc64/Ginit.lo \ ppc64/Gregs.lo ppc64/Gresume.lo ppc64/Gstep.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_ppc64_la_OBJECTS = $(am__objects_26) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_ppc64_la_OBJECTS = $(am__objects_28) libunwind_ppc64_la_OBJECTS = $(am_libunwind_ppc64_la_OBJECTS) libunwind_ppc64_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_ppc64_la_LDFLAGS) \ $(LDFLAGS) -o $@ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_ppc64_la_rpath = -rpath \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(libdir) -libunwind_ptrace_la_LIBADD = +@ARCH_PPC64_TRUE@am_libunwind_ppc64_la_rpath = -rpath $(libdir) +libunwind_ptrace_la_DEPENDENCIES = libunwind-$(arch).la \ + $(am__DEPENDENCIES_3) am_libunwind_ptrace_la_OBJECTS = ptrace/_UPT_elf.lo \ ptrace/_UPT_accessors.lo ptrace/_UPT_access_fpreg.lo \ ptrace/_UPT_access_mem.lo ptrace/_UPT_access_reg.lo \ @@ -551,187 +589,186 @@ ptrace/_UPT_put_unwind_info.lo ptrace/_UPT_get_proc_name.lo \ ptrace/_UPT_reg_offset.lo ptrace/_UPT_resume.lo libunwind_ptrace_la_OBJECTS = $(am_libunwind_ptrace_la_OBJECTS) -@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@am_libunwind_ptrace_la_rpath = \ -@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@ -rpath $(libdir) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_9 = libunwind.la +@BUILD_PTRACE_TRUE@am_libunwind_ptrace_la_rpath = -rpath $(libdir) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_10 = libunwind.la @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@libunwind_riscv_la_DEPENDENCIES = libunwind-dwarf-generic.la \ @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@ libunwind-elf64.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@ $(am__DEPENDENCIES_9) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@ $(am__DEPENDENCIES_10) am__libunwind_riscv_la_SOURCES_DIST = os-freebsd.c os-hpux.c \ os-linux.c dl-iterate-phdr.c os-qnx.c os-solaris.c mi/init.c \ mi/flush_cache.c mi/mempool.c mi/strerror.c riscv/is_fpreg.c \ riscv/regname.c mi/Gdyn-extract.c mi/Gdyn-remote.c \ mi/Gfind_dynamic_proc_info.c mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ - mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ - mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ - mi/Gset_caching_policy.c mi/Gset_cache_size.c \ - riscv/Gapply_reg_state.c riscv/Greg_states_iterate.c \ - riscv/Gcreate_addr_space.c riscv/Gget_proc_info.c \ - riscv/Gget_save_loc.c riscv/Gglobal.c riscv/Ginit.c \ - riscv/Ginit_local.c riscv/Ginit_remote.c \ + mi/Gget_proc_info_in_range.c mi/Gput_dynamic_unwind_info.c \ + mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ + mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ + mi/Gset_cache_size.c riscv/Gapply_reg_state.c \ + riscv/Greg_states_iterate.c riscv/Gcreate_addr_space.c \ + riscv/Gget_proc_info.c riscv/Gget_save_loc.c riscv/Gglobal.c \ + riscv/Ginit.c riscv/Ginit_local.c riscv/Ginit_remote.c \ riscv/Gis_signal_frame.c riscv/Gregs.c riscv/Gresume.c \ riscv/Gstep.c -am__objects_27 = $(am__objects_7) riscv/is_fpreg.lo riscv/regname.lo -am__objects_28 = $(am__objects_27) $(am__objects_9) \ +am__objects_29 = $(am__objects_7) riscv/is_fpreg.lo riscv/regname.lo +am__objects_30 = $(am__objects_29) $(am__objects_9) \ riscv/Gapply_reg_state.lo riscv/Greg_states_iterate.lo \ riscv/Gcreate_addr_space.lo riscv/Gget_proc_info.lo \ riscv/Gget_save_loc.lo riscv/Gglobal.lo riscv/Ginit.lo \ riscv/Ginit_local.lo riscv/Ginit_remote.lo \ riscv/Gis_signal_frame.lo riscv/Gregs.lo riscv/Gresume.lo \ riscv/Gstep.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@am_libunwind_riscv_la_OBJECTS = $(am__objects_28) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@am_libunwind_riscv_la_OBJECTS = $(am__objects_30) libunwind_riscv_la_OBJECTS = $(am_libunwind_riscv_la_OBJECTS) libunwind_riscv_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_riscv_la_LDFLAGS) \ $(LDFLAGS) -o $@ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@am_libunwind_riscv_la_rpath = -rpath \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@ $(libdir) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_10 = libunwind.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_s390x_la_DEPENDENCIES = libunwind-dwarf-generic.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf64.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__DEPENDENCIES_10) +@ARCH_RISCV_TRUE@am_libunwind_riscv_la_rpath = -rpath $(libdir) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_11 = libunwind.la +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_s390x_la_DEPENDENCIES = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf64.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__DEPENDENCIES_11) am__libunwind_s390x_la_SOURCES_DIST = os-freebsd.c os-hpux.c \ os-linux.c dl-iterate-phdr.c os-qnx.c os-solaris.c mi/init.c \ mi/flush_cache.c mi/mempool.c mi/strerror.c s390x/is_fpreg.c \ s390x/regname.c mi/Gdyn-extract.c mi/Gdyn-remote.c \ mi/Gfind_dynamic_proc_info.c mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ - mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ - mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ - mi/Gset_caching_policy.c mi/Gset_cache_size.c \ - s390x/Gapply_reg_state.c s390x/Greg_states_iterate.c \ - s390x/Gcreate_addr_space.c s390x/Gget_save_loc.c \ - s390x/Gglobal.c s390x/Ginit.c s390x/Ginit_local.c \ - s390x/Ginit_remote.c s390x/Gget_proc_info.c s390x/Gregs.c \ - s390x/Gresume.c s390x/Gis_signal_frame.c s390x/Gstep.c -am__objects_29 = $(am__objects_7) s390x/is_fpreg.lo s390x/regname.lo -am__objects_30 = $(am__objects_29) $(am__objects_9) \ + mi/Gget_proc_info_in_range.c mi/Gput_dynamic_unwind_info.c \ + mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ + mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ + mi/Gset_cache_size.c s390x/Gapply_reg_state.c \ + s390x/Greg_states_iterate.c s390x/Gcreate_addr_space.c \ + s390x/Gget_save_loc.c s390x/Gglobal.c s390x/Ginit.c \ + s390x/Ginit_local.c s390x/Ginit_remote.c \ + s390x/Gget_proc_info.c s390x/Gregs.c s390x/Gresume.c \ + s390x/Gis_signal_frame.c s390x/Gstep.c +am__objects_31 = $(am__objects_7) s390x/is_fpreg.lo s390x/regname.lo +am__objects_32 = $(am__objects_31) $(am__objects_9) \ s390x/Gapply_reg_state.lo s390x/Greg_states_iterate.lo \ s390x/Gcreate_addr_space.lo s390x/Gget_save_loc.lo \ s390x/Gglobal.lo s390x/Ginit.lo s390x/Ginit_local.lo \ s390x/Ginit_remote.lo s390x/Gget_proc_info.lo s390x/Gregs.lo \ s390x/Gresume.lo s390x/Gis_signal_frame.lo s390x/Gstep.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_s390x_la_OBJECTS = $(am__objects_30) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_s390x_la_OBJECTS = $(am__objects_32) libunwind_s390x_la_OBJECTS = $(am_libunwind_s390x_la_OBJECTS) libunwind_s390x_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_s390x_la_LDFLAGS) \ $(LDFLAGS) -o $@ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_s390x_la_rpath = -rpath \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(libdir) +@ARCH_S390X_TRUE@am_libunwind_s390x_la_rpath = -rpath $(libdir) libunwind_setjmp_la_DEPENDENCIES = $(LIBUNWIND_ELF) \ libunwind-$(arch).la libunwind.la am__libunwind_setjmp_la_SOURCES_DIST = setjmp/longjmp.c \ setjmp/siglongjmp.c aarch64/siglongjmp.S arm/siglongjmp.S \ ia64/setjmp.S ia64/sigsetjmp.S ia64/longjmp.S \ ia64/siglongjmp.S hppa/siglongjmp.S mips/siglongjmp.S \ - tilegx/siglongjmp.S riscv/siglongjmp.S x86/longjmp.S \ - x86/siglongjmp.S x86_64/longjmp.S x86_64/siglongjmp.S \ - ppc/longjmp.S ppc/siglongjmp.S sh/siglongjmp.S -@ARCH_AARCH64_TRUE@am__objects_31 = aarch64/siglongjmp.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@am__objects_32 = arm/siglongjmp.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@am__objects_33 = ia64/setjmp.lo \ + tilegx/siglongjmp.S riscv/siglongjmp.S \ + loongarch64/siglongjmp.S x86/longjmp.S x86/siglongjmp.S \ + x86_64/longjmp.S x86_64/siglongjmp.S ppc/longjmp.S \ + ppc/siglongjmp.S sh/siglongjmp.S +@ARCH_AARCH64_TRUE@am__objects_33 = aarch64/siglongjmp.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@am__objects_34 = arm/siglongjmp.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@am__objects_35 = ia64/setjmp.lo \ @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@ ia64/sigsetjmp.lo \ @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@ ia64/longjmp.lo \ @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@ ia64/siglongjmp.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@am__objects_34 = hppa/siglongjmp.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@am__objects_35 = mips/siglongjmp.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@am__objects_36 = tilegx/siglongjmp.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@am__objects_37 = riscv/siglongjmp.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@am__objects_38 = x86/longjmp.lo \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ x86/siglongjmp.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@am__objects_39 = x86_64/longjmp.lo \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@ x86_64/siglongjmp.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__objects_40 = ppc/longjmp.lo \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ ppc/siglongjmp.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__objects_41 = ppc/longjmp.lo \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ ppc/siglongjmp.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__objects_42 = sh/siglongjmp.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@am__objects_36 = hppa/siglongjmp.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@am__objects_37 = mips/siglongjmp.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@am__objects_38 = tilegx/siglongjmp.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@am__objects_39 = riscv/siglongjmp.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@am__objects_40 = loongarch64/siglongjmp.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@am__objects_41 = x86/longjmp.lo \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ x86/siglongjmp.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@am__objects_42 = x86_64/longjmp.lo \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@ x86_64/siglongjmp.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__objects_43 = ppc/longjmp.lo \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ ppc/siglongjmp.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__objects_44 = ppc/longjmp.lo \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ ppc/siglongjmp.lo +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am__objects_45 = sh/siglongjmp.lo am_libunwind_setjmp_la_OBJECTS = setjmp/longjmp.lo \ - setjmp/siglongjmp.lo $(am__objects_31) $(am__objects_32) \ - $(am__objects_33) $(am__objects_34) $(am__objects_35) \ - $(am__objects_36) $(am__objects_37) $(am__objects_38) \ - $(am__objects_39) $(am__objects_40) $(am__objects_41) \ - $(am__objects_42) + setjmp/siglongjmp.lo $(am__objects_33) $(am__objects_34) \ + $(am__objects_35) $(am__objects_36) $(am__objects_37) \ + $(am__objects_38) $(am__objects_39) $(am__objects_40) \ + $(am__objects_41) $(am__objects_42) $(am__objects_43) \ + $(am__objects_44) $(am__objects_45) libunwind_setjmp_la_OBJECTS = $(am_libunwind_setjmp_la_OBJECTS) libunwind_setjmp_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_setjmp_la_LDFLAGS) \ $(LDFLAGS) -o $@ @BUILD_SETJMP_TRUE@am_libunwind_setjmp_la_rpath = -rpath $(libdir) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_11 = libunwind.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_sh_la_DEPENDENCIES = libunwind-dwarf-generic.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf32.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__DEPENDENCIES_11) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_12 = libunwind.la +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_sh_la_DEPENDENCIES = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf32.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__DEPENDENCIES_12) am__libunwind_sh_la_SOURCES_DIST = os-freebsd.c os-hpux.c os-linux.c \ dl-iterate-phdr.c os-qnx.c os-solaris.c mi/init.c \ mi/flush_cache.c mi/mempool.c mi/strerror.c sh/is_fpreg.c \ sh/regname.c mi/Gdyn-extract.c mi/Gdyn-remote.c \ mi/Gfind_dynamic_proc_info.c mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ - mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ - mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ - mi/Gset_caching_policy.c mi/Gset_cache_size.c \ - sh/Gapply_reg_state.c sh/Greg_states_iterate.c \ - sh/Gcreate_addr_space.c sh/Gget_proc_info.c sh/Gget_save_loc.c \ - sh/Gglobal.c sh/Ginit.c sh/Ginit_local.c sh/Ginit_remote.c \ - sh/Gis_signal_frame.c sh/Gregs.c sh/Gresume.c sh/Gstep.c -am__objects_43 = $(am__objects_7) sh/is_fpreg.lo sh/regname.lo -am__objects_44 = $(am__objects_43) $(am__objects_9) \ + mi/Gget_proc_info_in_range.c mi/Gput_dynamic_unwind_info.c \ + mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ + mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ + mi/Gset_cache_size.c sh/Gapply_reg_state.c \ + sh/Greg_states_iterate.c sh/Gcreate_addr_space.c \ + sh/Gget_proc_info.c sh/Gget_save_loc.c sh/Gglobal.c sh/Ginit.c \ + sh/Ginit_local.c sh/Ginit_remote.c sh/Gis_signal_frame.c \ + sh/Gregs.c sh/Gresume.c sh/Gstep.c +am__objects_46 = $(am__objects_7) sh/is_fpreg.lo sh/regname.lo +am__objects_47 = $(am__objects_46) $(am__objects_9) \ sh/Gapply_reg_state.lo sh/Greg_states_iterate.lo \ sh/Gcreate_addr_space.lo sh/Gget_proc_info.lo \ sh/Gget_save_loc.lo sh/Gglobal.lo sh/Ginit.lo \ sh/Ginit_local.lo sh/Ginit_remote.lo sh/Gis_signal_frame.lo \ sh/Gregs.lo sh/Gresume.lo sh/Gstep.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_sh_la_OBJECTS = $(am__objects_44) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_sh_la_OBJECTS = $(am__objects_47) libunwind_sh_la_OBJECTS = $(am_libunwind_sh_la_OBJECTS) libunwind_sh_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_sh_la_LDFLAGS) $(LDFLAGS) \ -o $@ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_sh_la_rpath = -rpath \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(libdir) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_12 = libunwind.la +@ARCH_SH_TRUE@am_libunwind_sh_la_rpath = -rpath $(libdir) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_13 = libunwind.la @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@libunwind_tilegx_la_DEPENDENCIES = libunwind-dwarf-generic.la \ @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@ libunwind-elfxx.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@ $(am__DEPENDENCIES_12) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@ $(am__DEPENDENCIES_13) am__libunwind_tilegx_la_SOURCES_DIST = os-freebsd.c os-hpux.c \ os-linux.c dl-iterate-phdr.c os-qnx.c os-solaris.c mi/init.c \ mi/flush_cache.c mi/mempool.c mi/strerror.c tilegx/is_fpreg.c \ tilegx/regname.c mi/Gdyn-extract.c mi/Gdyn-remote.c \ mi/Gfind_dynamic_proc_info.c mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ - mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ - mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ - mi/Gset_caching_policy.c mi/Gset_cache_size.c \ - tilegx/Gapply_reg_state.c tilegx/Greg_states_iterate.c \ - tilegx/Gcreate_addr_space.c tilegx/Gget_proc_info.c \ - tilegx/Gget_save_loc.c tilegx/Gglobal.c tilegx/Ginit.c \ - tilegx/Ginit_local.c tilegx/Ginit_remote.c \ - tilegx/Gis_signal_frame.c tilegx/Gregs.c tilegx/Gresume.c \ - tilegx/Gstep.c -am__objects_45 = $(am__objects_7) tilegx/is_fpreg.lo tilegx/regname.lo -am__objects_46 = $(am__objects_45) $(am__objects_9) \ + mi/Gget_proc_info_in_range.c mi/Gput_dynamic_unwind_info.c \ + mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ + mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ + mi/Gset_cache_size.c tilegx/Gapply_reg_state.c \ + tilegx/Greg_states_iterate.c tilegx/Gcreate_addr_space.c \ + tilegx/Gget_proc_info.c tilegx/Gget_save_loc.c \ + tilegx/Gglobal.c tilegx/Ginit.c tilegx/Ginit_local.c \ + tilegx/Ginit_remote.c tilegx/Gis_signal_frame.c tilegx/Gregs.c \ + tilegx/Gresume.c tilegx/Gstep.c +am__objects_48 = $(am__objects_7) tilegx/is_fpreg.lo tilegx/regname.lo +am__objects_49 = $(am__objects_48) $(am__objects_9) \ tilegx/Gapply_reg_state.lo tilegx/Greg_states_iterate.lo \ tilegx/Gcreate_addr_space.lo tilegx/Gget_proc_info.lo \ tilegx/Gget_save_loc.lo tilegx/Gglobal.lo tilegx/Ginit.lo \ tilegx/Ginit_local.lo tilegx/Ginit_remote.lo \ tilegx/Gis_signal_frame.lo tilegx/Gregs.lo tilegx/Gresume.lo \ tilegx/Gstep.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@am_libunwind_tilegx_la_OBJECTS = $(am__objects_46) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@am_libunwind_tilegx_la_OBJECTS = $(am__objects_49) libunwind_tilegx_la_OBJECTS = $(am_libunwind_tilegx_la_OBJECTS) libunwind_tilegx_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_tilegx_la_LDFLAGS) \ $(LDFLAGS) -o $@ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@am_libunwind_tilegx_la_rpath = -rpath \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@ $(libdir) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_13 = libunwind.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@libunwind_x86_la_DEPENDENCIES = libunwind-dwarf-generic.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ libunwind-elf32.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ $(am__DEPENDENCIES_13) +@ARCH_TILEGX_TRUE@am_libunwind_tilegx_la_rpath = -rpath $(libdir) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_14 = libunwind.la +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@libunwind_x86_la_DEPENDENCIES = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ libunwind-elf32.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ $(am__DEPENDENCIES_14) am__libunwind_x86_la_SOURCES_DIST = os-freebsd.c os-hpux.c os-linux.c \ dl-iterate-phdr.c os-qnx.c os-solaris.c mi/init.c \ mi/flush_cache.c mi/mempool.c mi/strerror.c x86/is_fpreg.c \ @@ -739,33 +776,33 @@ mi/Gdyn-extract.c mi/Gdyn-remote.c \ mi/Gfind_dynamic_proc_info.c mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ - mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ - mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ - mi/Gset_caching_policy.c mi/Gset_cache_size.c \ - x86/Gapply_reg_state.c x86/Greg_states_iterate.c \ - x86/Gcreate_addr_space.c x86/Gget_save_loc.c x86/Gglobal.c \ - x86/Ginit.c x86/Ginit_local.c x86/Ginit_remote.c \ - x86/Gget_proc_info.c x86/Gregs.c x86/Gresume.c x86/Gstep.c -am__objects_47 = $(am__objects_7) x86/is_fpreg.lo x86/regname.lo -@OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_48 = x86/Gos-linux.lo -@OS_FREEBSD_TRUE@am__objects_48 = x86/Gos-freebsd.lo -am__objects_49 = $(am__objects_47) $(am__objects_48) $(am__objects_9) \ + mi/Gget_proc_info_in_range.c mi/Gput_dynamic_unwind_info.c \ + mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ + mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ + mi/Gset_cache_size.c x86/Gapply_reg_state.c \ + x86/Greg_states_iterate.c x86/Gcreate_addr_space.c \ + x86/Gget_save_loc.c x86/Gglobal.c x86/Ginit.c \ + x86/Ginit_local.c x86/Ginit_remote.c x86/Gget_proc_info.c \ + x86/Gregs.c x86/Gresume.c x86/Gstep.c +am__objects_50 = $(am__objects_7) x86/is_fpreg.lo x86/regname.lo +@OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_51 = x86/Gos-linux.lo +@OS_FREEBSD_TRUE@am__objects_51 = x86/Gos-freebsd.lo +am__objects_52 = $(am__objects_50) $(am__objects_51) $(am__objects_9) \ x86/Gapply_reg_state.lo x86/Greg_states_iterate.lo \ x86/Gcreate_addr_space.lo x86/Gget_save_loc.lo x86/Gglobal.lo \ x86/Ginit.lo x86/Ginit_local.lo x86/Ginit_remote.lo \ x86/Gget_proc_info.lo x86/Gregs.lo x86/Gresume.lo x86/Gstep.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@am_libunwind_x86_la_OBJECTS = $(am__objects_49) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@am_libunwind_x86_la_OBJECTS = $(am__objects_52) libunwind_x86_la_OBJECTS = $(am_libunwind_x86_la_OBJECTS) libunwind_x86_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_x86_la_LDFLAGS) $(LDFLAGS) \ -o $@ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@am_libunwind_x86_la_rpath = -rpath \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ $(libdir) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_14 = libunwind.la -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@libunwind_x86_64_la_DEPENDENCIES = libunwind-dwarf-generic.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@ libunwind-elf64.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@ $(am__DEPENDENCIES_14) +@ARCH_X86_TRUE@am_libunwind_x86_la_rpath = -rpath $(libdir) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@@REMOTE_ONLY_FALSE@am__DEPENDENCIES_15 = libunwind.la +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@libunwind_x86_64_la_DEPENDENCIES = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@ libunwind-elf64.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@ $(am__DEPENDENCIES_15) am__libunwind_x86_64_la_SOURCES_DIST = os-freebsd.c os-hpux.c \ os-linux.c dl-iterate-phdr.c os-qnx.c os-solaris.c mi/init.c \ mi/flush_cache.c mi/mempool.c mi/strerror.c x86_64/is_fpreg.c \ @@ -773,35 +810,34 @@ x86_64/Gos-solaris.c mi/Gdyn-extract.c mi/Gdyn-remote.c \ mi/Gfind_dynamic_proc_info.c mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ - mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ - mi/Gget_reg.c mi/Gset_reg.c mi/Gget_fpreg.c mi/Gset_fpreg.c \ - mi/Gset_caching_policy.c mi/Gset_cache_size.c \ - x86_64/Gapply_reg_state.c x86_64/Greg_states_iterate.c \ - x86_64/Gcreate_addr_space.c x86_64/Gget_save_loc.c \ - x86_64/Gglobal.c x86_64/Ginit.c x86_64/Ginit_local.c \ - x86_64/Ginit_remote.c x86_64/Gget_proc_info.c x86_64/Gregs.c \ - x86_64/Gresume.c x86_64/Gstash_frame.c x86_64/Gstep.c \ - x86_64/Gtrace.c -am__objects_50 = $(am__objects_7) x86_64/is_fpreg.lo x86_64/regname.lo -@OS_FREEBSD_FALSE@@OS_LINUX_FALSE@@OS_SOLARIS_TRUE@am__objects_51 = x86_64/Gos-solaris.lo -@OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_51 = x86_64/Gos-linux.lo -@OS_FREEBSD_TRUE@am__objects_51 = x86_64/Gos-freebsd.lo -am__objects_52 = $(am__objects_50) $(am__objects_51) $(am__objects_9) \ + mi/Gget_proc_info_in_range.c mi/Gput_dynamic_unwind_info.c \ + mi/Gdestroy_addr_space.c mi/Gget_reg.c mi/Gset_reg.c \ + mi/Gget_fpreg.c mi/Gset_fpreg.c mi/Gset_caching_policy.c \ + mi/Gset_cache_size.c x86_64/Gapply_reg_state.c \ + x86_64/Greg_states_iterate.c x86_64/Gcreate_addr_space.c \ + x86_64/Gget_save_loc.c x86_64/Gglobal.c x86_64/Ginit.c \ + x86_64/Ginit_local.c x86_64/Ginit_remote.c \ + x86_64/Gget_proc_info.c x86_64/Gregs.c x86_64/Gresume.c \ + x86_64/Gstash_frame.c x86_64/Gstep.c x86_64/Gtrace.c +am__objects_53 = $(am__objects_7) x86_64/is_fpreg.lo x86_64/regname.lo +@OS_FREEBSD_FALSE@@OS_LINUX_FALSE@@OS_SOLARIS_TRUE@am__objects_54 = x86_64/Gos-solaris.lo +@OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_54 = x86_64/Gos-linux.lo +@OS_FREEBSD_TRUE@am__objects_54 = x86_64/Gos-freebsd.lo +am__objects_55 = $(am__objects_53) $(am__objects_54) $(am__objects_9) \ x86_64/Gapply_reg_state.lo x86_64/Greg_states_iterate.lo \ x86_64/Gcreate_addr_space.lo x86_64/Gget_save_loc.lo \ x86_64/Gglobal.lo x86_64/Ginit.lo x86_64/Ginit_local.lo \ x86_64/Ginit_remote.lo x86_64/Gget_proc_info.lo \ x86_64/Gregs.lo x86_64/Gresume.lo x86_64/Gstash_frame.lo \ x86_64/Gstep.lo x86_64/Gtrace.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@am_libunwind_x86_64_la_OBJECTS = $(am__objects_52) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@am_libunwind_x86_64_la_OBJECTS = $(am__objects_55) libunwind_x86_64_la_OBJECTS = $(am_libunwind_x86_64_la_OBJECTS) libunwind_x86_64_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libunwind_x86_64_la_LDFLAGS) \ $(LDFLAGS) -o $@ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@am_libunwind_x86_64_la_rpath = -rpath \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@ $(libdir) -libunwind_la_DEPENDENCIES = $(am__append_10) $(LIBUNWIND_ELF) \ +@ARCH_X86_64_TRUE@am_libunwind_x86_64_la_rpath = -rpath $(libdir) +libunwind_la_DEPENDENCIES = $(am__append_25) $(LIBUNWIND_ELF) \ $(am__DEPENDENCIES_3) $(am__DEPENDENCIES_3) \ $(am__DEPENDENCIES_3) am__libunwind_la_SOURCES_DIST = os-freebsd.c os-hpux.c os-linux.c \ @@ -811,17 +847,18 @@ mi/dyn-cancel.c mi/dyn-info-list.c mi/dyn-register.c \ mi/Ldyn-extract.c mi/Lfind_dynamic_proc_info.c \ mi/Lget_accessors.c mi/Lget_proc_info_by_ip.c \ - mi/Lget_proc_name.c mi/Lput_dynamic_unwind_info.c \ - mi/Ldestroy_addr_space.c mi/Lget_reg.c mi/Lset_reg.c \ - mi/Lget_fpreg.c mi/Lset_fpreg.c mi/Lset_caching_policy.c \ - mi/Lset_cache_size.c unwind/Backtrace.c \ - unwind/DeleteException.c unwind/FindEnclosingFunction.c \ - unwind/ForcedUnwind.c unwind/GetBSP.c unwind/GetCFA.c \ - unwind/GetDataRelBase.c unwind/GetGR.c unwind/GetIP.c \ - unwind/GetLanguageSpecificData.c unwind/GetRegionStart.c \ - unwind/GetTextRelBase.c unwind/RaiseException.c \ - unwind/Resume.c unwind/Resume_or_Rethrow.c unwind/SetGR.c \ - unwind/SetIP.c unwind/GetIPInfo.c s390x/Lapply_reg_state.c \ + mi/Lget_proc_name.c mi/Lget_proc_info_in_range.c \ + mi/Lput_dynamic_unwind_info.c mi/Ldestroy_addr_space.c \ + mi/Lget_reg.c mi/Lset_reg.c mi/Lget_fpreg.c mi/Lset_fpreg.c \ + mi/Lset_caching_policy.c mi/Lset_cache_size.c \ + unwind/Backtrace.c unwind/DeleteException.c \ + unwind/FindEnclosingFunction.c unwind/ForcedUnwind.c \ + unwind/GetBSP.c unwind/GetCFA.c unwind/GetDataRelBase.c \ + unwind/GetGR.c unwind/GetIP.c unwind/GetLanguageSpecificData.c \ + unwind/GetRegionStart.c unwind/GetTextRelBase.c \ + unwind/RaiseException.c unwind/Resume.c \ + unwind/Resume_or_Rethrow.c unwind/SetGR.c unwind/SetIP.c \ + unwind/GetIPInfo.c s390x/Lapply_reg_state.c \ s390x/Lreg_states_iterate.c s390x/Lcreate_addr_space.c \ s390x/Lget_save_loc.c s390x/Lglobal.c s390x/Linit.c \ s390x/Linit_local.c s390x/Linit_remote.c \ @@ -855,8 +892,17 @@ x86/Lget_save_loc.c x86/Lglobal.c x86/Linit.c \ x86/Linit_local.c x86/Linit_remote.c x86/Lget_proc_info.c \ x86/Lregs.c x86/Lresume.c x86/Lstep.c x86/getcontext-freebsd.S \ - x86/getcontext-linux.S riscv/is_fpreg.c riscv/regname.c \ - riscv/getcontext.S riscv/setcontext.S riscv/Lapply_reg_state.c \ + x86/getcontext-linux.S loongarch64/is_fpreg.c \ + loongarch64/regname.c loongarch64/getcontext.S \ + loongarch64/Lapply_reg_state.c \ + loongarch64/Lreg_states_iterate.c \ + loongarch64/Lcreate_addr_space.c loongarch64/Lget_proc_info.c \ + loongarch64/Lget_save_loc.c loongarch64/Lglobal.c \ + loongarch64/Linit.c loongarch64/Linit_local.c \ + loongarch64/Linit_remote.c loongarch64/Lis_signal_frame.c \ + loongarch64/Lregs.c loongarch64/Lresume.c loongarch64/Lstep.c \ + riscv/is_fpreg.c riscv/regname.c riscv/getcontext.S \ + riscv/setcontext.S riscv/Lapply_reg_state.c \ riscv/Lreg_states_iterate.c riscv/Lcreate_addr_space.c \ riscv/Lget_proc_info.c riscv/Lget_save_loc.c riscv/Lglobal.c \ riscv/Linit.c riscv/Linit_local.c riscv/Linit_remote.c \ @@ -901,18 +947,18 @@ aarch64/Lis_signal_frame.c aarch64/Lregs.c aarch64/Lresume.c \ aarch64/Lstash_frame.c aarch64/Lstep.c aarch64/Ltrace.c \ aarch64/getcontext.S -@SUPPORT_CXX_EXCEPTIONS_TRUE@am__objects_53 = mi/_ReadULEB.lo \ +@SUPPORT_CXX_EXCEPTIONS_TRUE@am__objects_56 = mi/_ReadULEB.lo \ @SUPPORT_CXX_EXCEPTIONS_TRUE@ mi/_ReadSLEB.lo -@OS_LINUX_TRUE@am__objects_54 = $(am__objects_53) -am__objects_55 = $(am__objects_54) mi/backtrace.lo mi/dyn-cancel.lo \ +@OS_LINUX_TRUE@am__objects_57 = $(am__objects_56) +am__objects_58 = $(am__objects_57) mi/backtrace.lo mi/dyn-cancel.lo \ mi/dyn-info-list.lo mi/dyn-register.lo mi/Ldyn-extract.lo \ mi/Lfind_dynamic_proc_info.lo mi/Lget_accessors.lo \ mi/Lget_proc_info_by_ip.lo mi/Lget_proc_name.lo \ - mi/Lput_dynamic_unwind_info.lo mi/Ldestroy_addr_space.lo \ - mi/Lget_reg.lo mi/Lset_reg.lo mi/Lget_fpreg.lo \ - mi/Lset_fpreg.lo mi/Lset_caching_policy.lo \ + mi/Lget_proc_info_in_range.lo mi/Lput_dynamic_unwind_info.lo \ + mi/Ldestroy_addr_space.lo mi/Lget_reg.lo mi/Lset_reg.lo \ + mi/Lget_fpreg.lo mi/Lset_fpreg.lo mi/Lset_caching_policy.lo \ mi/Lset_cache_size.lo -@SUPPORT_CXX_EXCEPTIONS_TRUE@am__objects_56 = unwind/Backtrace.lo \ +@SUPPORT_CXX_EXCEPTIONS_TRUE@am__objects_59 = unwind/Backtrace.lo \ @SUPPORT_CXX_EXCEPTIONS_TRUE@ unwind/DeleteException.lo \ @SUPPORT_CXX_EXCEPTIONS_TRUE@ unwind/FindEnclosingFunction.lo \ @SUPPORT_CXX_EXCEPTIONS_TRUE@ unwind/ForcedUnwind.lo \ @@ -927,34 +973,34 @@ @SUPPORT_CXX_EXCEPTIONS_TRUE@ unwind/Resume_or_Rethrow.lo \ @SUPPORT_CXX_EXCEPTIONS_TRUE@ unwind/SetGR.lo unwind/SetIP.lo \ @SUPPORT_CXX_EXCEPTIONS_TRUE@ unwind/GetIPInfo.lo -am__objects_57 = $(am__objects_55) $(am__objects_56) -am__objects_58 = $(am__objects_29) $(am__objects_57) \ +am__objects_60 = $(am__objects_58) $(am__objects_59) +am__objects_61 = $(am__objects_31) $(am__objects_60) \ s390x/Lapply_reg_state.lo s390x/Lreg_states_iterate.lo \ s390x/Lcreate_addr_space.lo s390x/Lget_save_loc.lo \ s390x/Lglobal.lo s390x/Linit.lo s390x/Linit_local.lo \ s390x/Linit_remote.lo s390x/Lget_proc_info.lo s390x/Lregs.lo \ s390x/Lresume.lo s390x/Lis_signal_frame.lo s390x/Lstep.lo \ s390x/getcontext.lo s390x/setcontext.lo -am__objects_59 = $(am__objects_43) $(am__objects_57) \ +am__objects_62 = $(am__objects_46) $(am__objects_60) \ sh/Lapply_reg_state.lo sh/Lreg_states_iterate.lo \ sh/Lcreate_addr_space.lo sh/Lget_proc_info.lo \ sh/Lget_save_loc.lo sh/Lglobal.lo sh/Linit.lo \ sh/Linit_local.lo sh/Linit_remote.lo sh/Lis_signal_frame.lo \ sh/Lregs.lo sh/Lresume.lo sh/Lstep.lo -am__objects_60 = ppc/Lget_proc_info.lo ppc/Lget_save_loc.lo \ +am__objects_63 = ppc/Lget_proc_info.lo ppc/Lget_save_loc.lo \ ppc/Linit_local.lo ppc/Linit_remote.lo ppc/Lis_signal_frame.lo -am__objects_61 = $(am__objects_25) $(am__objects_57) $(am__objects_60) \ +am__objects_64 = $(am__objects_27) $(am__objects_60) $(am__objects_63) \ ppc64/Lapply_reg_state.lo ppc64/Lreg_states_iterate.lo \ ppc64/Lcreate_addr_space.lo ppc64/Lglobal.lo ppc64/Linit.lo \ ppc64/Lregs.lo ppc64/Lresume.lo ppc64/Lstep.lo -am__objects_62 = $(am__objects_22) $(am__objects_57) $(am__objects_60) \ +am__objects_65 = $(am__objects_24) $(am__objects_60) $(am__objects_63) \ ppc32/Lapply_reg_state.lo ppc32/Lreg_states_iterate.lo \ ppc32/Lcreate_addr_space.lo ppc32/Lglobal.lo ppc32/Linit.lo \ ppc32/Lregs.lo ppc32/Lresume.lo ppc32/Lstep.lo -@OS_FREEBSD_FALSE@@OS_LINUX_FALSE@@OS_SOLARIS_TRUE@am__objects_63 = x86_64/Los-solaris.lo -@OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_63 = x86_64/Los-linux.lo -@OS_FREEBSD_TRUE@am__objects_63 = x86_64/Los-freebsd.lo -am__objects_64 = $(am__objects_50) $(am__objects_63) $(am__objects_57) \ +@OS_FREEBSD_FALSE@@OS_LINUX_FALSE@@OS_SOLARIS_TRUE@am__objects_66 = x86_64/Los-solaris.lo +@OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_66 = x86_64/Los-linux.lo +@OS_FREEBSD_TRUE@am__objects_66 = x86_64/Los-freebsd.lo +am__objects_67 = $(am__objects_53) $(am__objects_66) $(am__objects_60) \ x86_64/setcontext.lo x86_64/Lapply_reg_state.lo \ x86_64/Lreg_states_iterate.lo x86_64/Lcreate_addr_space.lo \ x86_64/Lget_save_loc.lo x86_64/Lglobal.lo x86_64/Linit.lo \ @@ -962,17 +1008,26 @@ x86_64/Lget_proc_info.lo x86_64/Lregs.lo x86_64/Lresume.lo \ x86_64/Lstash_frame.lo x86_64/Lstep.lo x86_64/Ltrace.lo \ x86_64/getcontext.lo -@OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_65 = x86/Los-linux.lo -@OS_FREEBSD_TRUE@am__objects_65 = x86/Los-freebsd.lo -am__objects_66 = $(am__objects_47) $(am__objects_65) $(am__objects_57) \ +@OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_68 = x86/Los-linux.lo +@OS_FREEBSD_TRUE@am__objects_68 = x86/Los-freebsd.lo +am__objects_69 = $(am__objects_50) $(am__objects_68) $(am__objects_60) \ x86/Lapply_reg_state.lo x86/Lreg_states_iterate.lo \ x86/Lcreate_addr_space.lo x86/Lget_save_loc.lo x86/Lglobal.lo \ x86/Linit.lo x86/Linit_local.lo x86/Linit_remote.lo \ x86/Lget_proc_info.lo x86/Lregs.lo x86/Lresume.lo x86/Lstep.lo -@OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_67 = \ +@OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_70 = \ @OS_FREEBSD_FALSE@@OS_LINUX_TRUE@ x86/getcontext-linux.lo -@OS_FREEBSD_TRUE@am__objects_67 = x86/getcontext-freebsd.lo -am__objects_68 = $(am__objects_27) $(am__objects_57) \ +@OS_FREEBSD_TRUE@am__objects_70 = x86/getcontext-freebsd.lo +am__objects_71 = $(am__objects_20) $(am__objects_60) \ + loongarch64/getcontext.lo loongarch64/Lapply_reg_state.lo \ + loongarch64/Lreg_states_iterate.lo \ + loongarch64/Lcreate_addr_space.lo \ + loongarch64/Lget_proc_info.lo loongarch64/Lget_save_loc.lo \ + loongarch64/Lglobal.lo loongarch64/Linit.lo \ + loongarch64/Linit_local.lo loongarch64/Linit_remote.lo \ + loongarch64/Lis_signal_frame.lo loongarch64/Lregs.lo \ + loongarch64/Lresume.lo loongarch64/Lstep.lo +am__objects_72 = $(am__objects_29) $(am__objects_60) \ riscv/getcontext.lo riscv/setcontext.lo \ riscv/Lapply_reg_state.lo riscv/Lreg_states_iterate.lo \ riscv/Lcreate_addr_space.lo riscv/Lget_proc_info.lo \ @@ -980,28 +1035,28 @@ riscv/Linit_local.lo riscv/Linit_remote.lo \ riscv/Lis_signal_frame.lo riscv/Lregs.lo riscv/Lresume.lo \ riscv/Lstep.lo -am__objects_69 = $(am__objects_45) $(am__objects_57) \ +am__objects_73 = $(am__objects_48) $(am__objects_60) \ tilegx/getcontext.lo tilegx/Lapply_reg_state.lo \ tilegx/Lreg_states_iterate.lo tilegx/Lcreate_addr_space.lo \ tilegx/Lget_proc_info.lo tilegx/Lget_save_loc.lo \ tilegx/Lglobal.lo tilegx/Linit.lo tilegx/Linit_local.lo \ tilegx/Linit_remote.lo tilegx/Lis_signal_frame.lo \ tilegx/Lregs.lo tilegx/Lresume.lo tilegx/Lstep.lo -am__objects_70 = $(am__objects_20) $(am__objects_57) \ +am__objects_74 = $(am__objects_22) $(am__objects_60) \ mips/getcontext.lo mips/Lapply_reg_state.lo \ mips/Lreg_states_iterate.lo mips/Lcreate_addr_space.lo \ mips/Lget_proc_info.lo mips/Lget_save_loc.lo mips/Lglobal.lo \ mips/Linit.lo mips/Linit_local.lo mips/Linit_remote.lo \ mips/Lis_signal_frame.lo mips/Lregs.lo mips/Lresume.lo \ mips/Lstep.lo -am__objects_71 = $(am__objects_16) $(am__objects_57) \ +am__objects_75 = $(am__objects_16) $(am__objects_60) \ hppa/getcontext.lo hppa/setcontext.lo hppa/Lapply_reg_state.lo \ hppa/Lreg_states_iterate.lo hppa/Lcreate_addr_space.lo \ hppa/Lget_save_loc.lo hppa/Lglobal.lo hppa/Linit.lo \ hppa/Linit_local.lo hppa/Linit_remote.lo \ hppa/Lis_signal_frame.lo hppa/Lget_proc_info.lo hppa/Lregs.lo \ hppa/Lresume.lo hppa/Lstep.lo -am__objects_72 = $(am__objects_18) $(am__objects_57) \ +am__objects_76 = $(am__objects_18) $(am__objects_60) \ ia64/dyn_info_list.lo ia64/getcontext.lo \ ia64/Lapply_reg_state.lo ia64/Lreg_states_iterate.lo \ ia64/Lcreate_addr_space.lo ia64/Lget_proc_info.lo \ @@ -1011,17 +1066,17 @@ ia64/Lparser.lo ia64/Lrbs.lo ia64/Lregs.lo ia64/Lresume.lo \ ia64/Lscript.lo ia64/Lstep.lo ia64/Ltables.lo \ ia64/Lfind_unwind_table.lo -@OS_FREEBSD_FALSE@@OS_LINUX_FALSE@@OS_QNX_TRUE@am__objects_73 = arm/Los-other.lo -@OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_73 = arm/Los-linux.lo -@OS_FREEBSD_TRUE@am__objects_73 = arm/Los-freebsd.lo -am__objects_74 = $(am__objects_11) $(am__objects_73) $(am__objects_57) \ +@OS_FREEBSD_FALSE@@OS_LINUX_FALSE@@OS_QNX_TRUE@am__objects_77 = arm/Los-other.lo +@OS_FREEBSD_FALSE@@OS_LINUX_TRUE@am__objects_77 = arm/Los-linux.lo +@OS_FREEBSD_TRUE@am__objects_77 = arm/Los-freebsd.lo +am__objects_78 = $(am__objects_11) $(am__objects_77) $(am__objects_60) \ arm/getcontext.lo arm/Lapply_reg_state.lo \ arm/Lreg_states_iterate.lo arm/Lcreate_addr_space.lo \ arm/Lget_proc_info.lo arm/Lget_save_loc.lo arm/Lglobal.lo \ arm/Linit.lo arm/Linit_local.lo arm/Linit_remote.lo \ arm/Lregs.lo arm/Lresume.lo arm/Lstep.lo arm/Lex_tables.lo \ arm/Lstash_frame.lo arm/Ltrace.lo -am__objects_75 = $(am__objects_8) $(am__objects_57) \ +am__objects_79 = $(am__objects_8) $(am__objects_60) \ aarch64/Lapply_reg_state.lo aarch64/Lreg_states_iterate.lo \ aarch64/Lcreate_addr_space.lo aarch64/Lget_proc_info.lo \ aarch64/Lget_save_loc.lo aarch64/Lglobal.lo aarch64/Linit.lo \ @@ -1029,21 +1084,22 @@ aarch64/Lis_signal_frame.lo aarch64/Lregs.lo \ aarch64/Lresume.lo aarch64/Lstash_frame.lo aarch64/Lstep.lo \ aarch64/Ltrace.lo aarch64/getcontext.lo -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_la_OBJECTS = $(am__objects_58) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_la_OBJECTS = $(am__objects_59) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_la_OBJECTS = $(am__objects_61) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_la_OBJECTS = $(am__objects_62) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@am_libunwind_la_OBJECTS = $(am__objects_64) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@am_libunwind_la_OBJECTS = $(am__objects_66) \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ $(am__objects_67) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@am_libunwind_la_OBJECTS = $(am__objects_68) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@am_libunwind_la_OBJECTS = $(am__objects_69) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@am_libunwind_la_OBJECTS = $(am__objects_70) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@am_libunwind_la_OBJECTS = $(am__objects_71) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@am_libunwind_la_OBJECTS = $(am__objects_72) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_la_OBJECTS = $(am__objects_61) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_la_OBJECTS = $(am__objects_62) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_la_OBJECTS = $(am__objects_64) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@am_libunwind_la_OBJECTS = $(am__objects_65) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@am_libunwind_la_OBJECTS = $(am__objects_67) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@am_libunwind_la_OBJECTS = $(am__objects_69) \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ $(am__objects_70) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@am_libunwind_la_OBJECTS = $(am__objects_71) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@am_libunwind_la_OBJECTS = $(am__objects_72) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@am_libunwind_la_OBJECTS = $(am__objects_73) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@am_libunwind_la_OBJECTS = $(am__objects_74) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@am_libunwind_la_OBJECTS = $(am__objects_75) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@am_libunwind_la_OBJECTS = $(am__objects_76) @ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@am_libunwind_la_OBJECTS = \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@ $(am__objects_74) -@ARCH_AARCH64_TRUE@am_libunwind_la_OBJECTS = $(am__objects_75) +@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@ $(am__objects_78) +@ARCH_AARCH64_TRUE@am_libunwind_la_OBJECTS = $(am__objects_79) libunwind_la_OBJECTS = $(am_libunwind_la_OBJECTS) libunwind_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ @@ -1063,381 +1119,11 @@ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)/include depcomp = $(SHELL) $(top_srcdir)/config/depcomp -am__maybe_remake_depfiles = depfiles -am__depfiles_remade = ./$(DEPDIR)/dl-iterate-phdr.Plo \ - ./$(DEPDIR)/elf32.Plo ./$(DEPDIR)/elf64.Plo \ - ./$(DEPDIR)/elfxx.Plo ./$(DEPDIR)/os-freebsd.Plo \ - ./$(DEPDIR)/os-hpux.Plo ./$(DEPDIR)/os-linux.Plo \ - ./$(DEPDIR)/os-qnx.Plo ./$(DEPDIR)/os-solaris.Plo \ - aarch64/$(DEPDIR)/Gapply_reg_state.Plo \ - aarch64/$(DEPDIR)/Gcreate_addr_space.Plo \ - aarch64/$(DEPDIR)/Gget_proc_info.Plo \ - aarch64/$(DEPDIR)/Gget_save_loc.Plo \ - aarch64/$(DEPDIR)/Gglobal.Plo aarch64/$(DEPDIR)/Ginit.Plo \ - aarch64/$(DEPDIR)/Ginit_local.Plo \ - aarch64/$(DEPDIR)/Ginit_remote.Plo \ - aarch64/$(DEPDIR)/Gis_signal_frame.Plo \ - aarch64/$(DEPDIR)/Greg_states_iterate.Plo \ - aarch64/$(DEPDIR)/Gregs.Plo aarch64/$(DEPDIR)/Gresume.Plo \ - aarch64/$(DEPDIR)/Gstash_frame.Plo aarch64/$(DEPDIR)/Gstep.Plo \ - aarch64/$(DEPDIR)/Gtrace.Plo \ - aarch64/$(DEPDIR)/Lapply_reg_state.Plo \ - aarch64/$(DEPDIR)/Lcreate_addr_space.Plo \ - aarch64/$(DEPDIR)/Lget_proc_info.Plo \ - aarch64/$(DEPDIR)/Lget_save_loc.Plo \ - aarch64/$(DEPDIR)/Lglobal.Plo aarch64/$(DEPDIR)/Linit.Plo \ - aarch64/$(DEPDIR)/Linit_local.Plo \ - aarch64/$(DEPDIR)/Linit_remote.Plo \ - aarch64/$(DEPDIR)/Lis_signal_frame.Plo \ - aarch64/$(DEPDIR)/Lreg_states_iterate.Plo \ - aarch64/$(DEPDIR)/Lregs.Plo aarch64/$(DEPDIR)/Lresume.Plo \ - aarch64/$(DEPDIR)/Lstash_frame.Plo aarch64/$(DEPDIR)/Lstep.Plo \ - aarch64/$(DEPDIR)/Ltrace.Plo aarch64/$(DEPDIR)/getcontext.Plo \ - aarch64/$(DEPDIR)/is_fpreg.Plo aarch64/$(DEPDIR)/regname.Plo \ - aarch64/$(DEPDIR)/siglongjmp.Plo \ - arm/$(DEPDIR)/Gapply_reg_state.Plo \ - arm/$(DEPDIR)/Gcreate_addr_space.Plo \ - arm/$(DEPDIR)/Gex_tables.Plo arm/$(DEPDIR)/Gget_proc_info.Plo \ - arm/$(DEPDIR)/Gget_save_loc.Plo arm/$(DEPDIR)/Gglobal.Plo \ - arm/$(DEPDIR)/Ginit.Plo arm/$(DEPDIR)/Ginit_local.Plo \ - arm/$(DEPDIR)/Ginit_remote.Plo arm/$(DEPDIR)/Gos-freebsd.Plo \ - arm/$(DEPDIR)/Gos-linux.Plo arm/$(DEPDIR)/Gos-other.Plo \ - arm/$(DEPDIR)/Greg_states_iterate.Plo arm/$(DEPDIR)/Gregs.Plo \ - arm/$(DEPDIR)/Gresume.Plo arm/$(DEPDIR)/Gstash_frame.Plo \ - arm/$(DEPDIR)/Gstep.Plo arm/$(DEPDIR)/Gtrace.Plo \ - arm/$(DEPDIR)/Lapply_reg_state.Plo \ - arm/$(DEPDIR)/Lcreate_addr_space.Plo \ - arm/$(DEPDIR)/Lex_tables.Plo arm/$(DEPDIR)/Lget_proc_info.Plo \ - arm/$(DEPDIR)/Lget_save_loc.Plo arm/$(DEPDIR)/Lglobal.Plo \ - arm/$(DEPDIR)/Linit.Plo arm/$(DEPDIR)/Linit_local.Plo \ - arm/$(DEPDIR)/Linit_remote.Plo arm/$(DEPDIR)/Los-freebsd.Plo \ - arm/$(DEPDIR)/Los-linux.Plo arm/$(DEPDIR)/Los-other.Plo \ - arm/$(DEPDIR)/Lreg_states_iterate.Plo arm/$(DEPDIR)/Lregs.Plo \ - arm/$(DEPDIR)/Lresume.Plo arm/$(DEPDIR)/Lstash_frame.Plo \ - arm/$(DEPDIR)/Lstep.Plo arm/$(DEPDIR)/Ltrace.Plo \ - arm/$(DEPDIR)/getcontext.Plo arm/$(DEPDIR)/is_fpreg.Plo \ - arm/$(DEPDIR)/regname.Plo arm/$(DEPDIR)/siglongjmp.Plo \ - coredump/$(DEPDIR)/_UCD_access_mem.Plo \ - coredump/$(DEPDIR)/_UCD_access_reg_freebsd.Plo \ - coredump/$(DEPDIR)/_UCD_access_reg_linux.Plo \ - coredump/$(DEPDIR)/_UCD_accessors.Plo \ - coredump/$(DEPDIR)/_UCD_corefile_elf.Plo \ - coredump/$(DEPDIR)/_UCD_create.Plo \ - coredump/$(DEPDIR)/_UCD_destroy.Plo \ - coredump/$(DEPDIR)/_UCD_elf_map_image.Plo \ - coredump/$(DEPDIR)/_UCD_find_proc_info.Plo \ - coredump/$(DEPDIR)/_UCD_get_mapinfo_generic.Plo \ - coredump/$(DEPDIR)/_UCD_get_mapinfo_linux.Plo \ - coredump/$(DEPDIR)/_UCD_get_proc_name.Plo \ - coredump/$(DEPDIR)/_UCD_get_threadinfo_prstatus.Plo \ - coredump/$(DEPDIR)/_UPT_access_fpreg.Plo \ - coredump/$(DEPDIR)/_UPT_elf.Plo \ - coredump/$(DEPDIR)/_UPT_get_dyn_info_list_addr.Plo \ - coredump/$(DEPDIR)/_UPT_put_unwind_info.Plo \ - coredump/$(DEPDIR)/_UPT_resume.Plo dwarf/$(DEPDIR)/Gexpr.Plo \ - dwarf/$(DEPDIR)/Gfde.Plo \ - dwarf/$(DEPDIR)/Gfind_proc_info-lsb.Plo \ - dwarf/$(DEPDIR)/Gfind_unwind_table.Plo \ - dwarf/$(DEPDIR)/Gparser.Plo dwarf/$(DEPDIR)/Gpe.Plo \ - dwarf/$(DEPDIR)/Lexpr.Plo dwarf/$(DEPDIR)/Lfde.Plo \ - dwarf/$(DEPDIR)/Lfind_proc_info-lsb.Plo \ - dwarf/$(DEPDIR)/Lfind_unwind_table.Plo \ - dwarf/$(DEPDIR)/Lparser.Plo dwarf/$(DEPDIR)/Lpe.Plo \ - dwarf/$(DEPDIR)/global.Plo hppa/$(DEPDIR)/Gapply_reg_state.Plo \ - hppa/$(DEPDIR)/Gcreate_addr_space.Plo \ - hppa/$(DEPDIR)/Gget_proc_info.Plo \ - hppa/$(DEPDIR)/Gget_save_loc.Plo hppa/$(DEPDIR)/Gglobal.Plo \ - hppa/$(DEPDIR)/Ginit.Plo hppa/$(DEPDIR)/Ginit_local.Plo \ - hppa/$(DEPDIR)/Ginit_remote.Plo \ - hppa/$(DEPDIR)/Gis_signal_frame.Plo \ - hppa/$(DEPDIR)/Greg_states_iterate.Plo \ - hppa/$(DEPDIR)/Gregs.Plo hppa/$(DEPDIR)/Gresume.Plo \ - hppa/$(DEPDIR)/Gstep.Plo hppa/$(DEPDIR)/Lapply_reg_state.Plo \ - hppa/$(DEPDIR)/Lcreate_addr_space.Plo \ - hppa/$(DEPDIR)/Lget_proc_info.Plo \ - hppa/$(DEPDIR)/Lget_save_loc.Plo hppa/$(DEPDIR)/Lglobal.Plo \ - hppa/$(DEPDIR)/Linit.Plo hppa/$(DEPDIR)/Linit_local.Plo \ - hppa/$(DEPDIR)/Linit_remote.Plo \ - hppa/$(DEPDIR)/Lis_signal_frame.Plo \ - hppa/$(DEPDIR)/Lreg_states_iterate.Plo \ - hppa/$(DEPDIR)/Lregs.Plo hppa/$(DEPDIR)/Lresume.Plo \ - hppa/$(DEPDIR)/Lstep.Plo hppa/$(DEPDIR)/getcontext.Plo \ - hppa/$(DEPDIR)/regname.Plo hppa/$(DEPDIR)/setcontext.Plo \ - hppa/$(DEPDIR)/siglongjmp.Plo \ - ia64/$(DEPDIR)/Gapply_reg_state.Plo \ - ia64/$(DEPDIR)/Gcreate_addr_space.Plo \ - ia64/$(DEPDIR)/Gfind_unwind_table.Plo \ - ia64/$(DEPDIR)/Gget_proc_info.Plo \ - ia64/$(DEPDIR)/Gget_save_loc.Plo ia64/$(DEPDIR)/Gglobal.Plo \ - ia64/$(DEPDIR)/Ginit.Plo ia64/$(DEPDIR)/Ginit_local.Plo \ - ia64/$(DEPDIR)/Ginit_remote.Plo \ - ia64/$(DEPDIR)/Ginstall_cursor.Plo \ - ia64/$(DEPDIR)/Gis_signal_frame.Plo ia64/$(DEPDIR)/Gparser.Plo \ - ia64/$(DEPDIR)/Grbs.Plo ia64/$(DEPDIR)/Greg_states_iterate.Plo \ - ia64/$(DEPDIR)/Gregs.Plo ia64/$(DEPDIR)/Gresume.Plo \ - ia64/$(DEPDIR)/Gscript.Plo ia64/$(DEPDIR)/Gstep.Plo \ - ia64/$(DEPDIR)/Gtables.Plo ia64/$(DEPDIR)/Lapply_reg_state.Plo \ - ia64/$(DEPDIR)/Lcreate_addr_space.Plo \ - ia64/$(DEPDIR)/Lfind_unwind_table.Plo \ - ia64/$(DEPDIR)/Lget_proc_info.Plo \ - ia64/$(DEPDIR)/Lget_save_loc.Plo ia64/$(DEPDIR)/Lglobal.Plo \ - ia64/$(DEPDIR)/Linit.Plo ia64/$(DEPDIR)/Linit_local.Plo \ - ia64/$(DEPDIR)/Linit_remote.Plo \ - ia64/$(DEPDIR)/Linstall_cursor.Plo \ - ia64/$(DEPDIR)/Lis_signal_frame.Plo ia64/$(DEPDIR)/Lparser.Plo \ - ia64/$(DEPDIR)/Lrbs.Plo ia64/$(DEPDIR)/Lreg_states_iterate.Plo \ - ia64/$(DEPDIR)/Lregs.Plo ia64/$(DEPDIR)/Lresume.Plo \ - ia64/$(DEPDIR)/Lscript.Plo ia64/$(DEPDIR)/Lstep.Plo \ - ia64/$(DEPDIR)/Ltables.Plo ia64/$(DEPDIR)/dyn_info_list.Plo \ - ia64/$(DEPDIR)/getcontext.Plo ia64/$(DEPDIR)/longjmp.Plo \ - ia64/$(DEPDIR)/regname.Plo ia64/$(DEPDIR)/setjmp.Plo \ - ia64/$(DEPDIR)/siglongjmp.Plo ia64/$(DEPDIR)/sigsetjmp.Plo \ - mi/$(DEPDIR)/Gdestroy_addr_space.Plo \ - mi/$(DEPDIR)/Gdyn-extract.Plo mi/$(DEPDIR)/Gdyn-remote.Plo \ - mi/$(DEPDIR)/Gfind_dynamic_proc_info.Plo \ - mi/$(DEPDIR)/Gget_accessors.Plo mi/$(DEPDIR)/Gget_fpreg.Plo \ - mi/$(DEPDIR)/Gget_proc_info_by_ip.Plo \ - mi/$(DEPDIR)/Gget_proc_name.Plo mi/$(DEPDIR)/Gget_reg.Plo \ - mi/$(DEPDIR)/Gput_dynamic_unwind_info.Plo \ - mi/$(DEPDIR)/Gset_cache_size.Plo \ - mi/$(DEPDIR)/Gset_caching_policy.Plo \ - mi/$(DEPDIR)/Gset_fpreg.Plo mi/$(DEPDIR)/Gset_reg.Plo \ - mi/$(DEPDIR)/Ldestroy_addr_space.Plo \ - mi/$(DEPDIR)/Ldyn-extract.Plo \ - mi/$(DEPDIR)/Lfind_dynamic_proc_info.Plo \ - mi/$(DEPDIR)/Lget_accessors.Plo mi/$(DEPDIR)/Lget_fpreg.Plo \ - mi/$(DEPDIR)/Lget_proc_info_by_ip.Plo \ - mi/$(DEPDIR)/Lget_proc_name.Plo mi/$(DEPDIR)/Lget_reg.Plo \ - mi/$(DEPDIR)/Lput_dynamic_unwind_info.Plo \ - mi/$(DEPDIR)/Lset_cache_size.Plo \ - mi/$(DEPDIR)/Lset_caching_policy.Plo \ - mi/$(DEPDIR)/Lset_fpreg.Plo mi/$(DEPDIR)/Lset_reg.Plo \ - mi/$(DEPDIR)/_ReadSLEB.Plo mi/$(DEPDIR)/_ReadULEB.Plo \ - mi/$(DEPDIR)/backtrace.Plo mi/$(DEPDIR)/dyn-cancel.Plo \ - mi/$(DEPDIR)/dyn-info-list.Plo mi/$(DEPDIR)/dyn-register.Plo \ - mi/$(DEPDIR)/flush_cache.Plo mi/$(DEPDIR)/init.Plo \ - mi/$(DEPDIR)/mempool.Plo mi/$(DEPDIR)/strerror.Plo \ - mips/$(DEPDIR)/Gapply_reg_state.Plo \ - mips/$(DEPDIR)/Gcreate_addr_space.Plo \ - mips/$(DEPDIR)/Gget_proc_info.Plo \ - mips/$(DEPDIR)/Gget_save_loc.Plo mips/$(DEPDIR)/Gglobal.Plo \ - mips/$(DEPDIR)/Ginit.Plo mips/$(DEPDIR)/Ginit_local.Plo \ - mips/$(DEPDIR)/Ginit_remote.Plo \ - mips/$(DEPDIR)/Gis_signal_frame.Plo \ - mips/$(DEPDIR)/Greg_states_iterate.Plo \ - mips/$(DEPDIR)/Gregs.Plo mips/$(DEPDIR)/Gresume.Plo \ - mips/$(DEPDIR)/Gstep.Plo mips/$(DEPDIR)/Lapply_reg_state.Plo \ - mips/$(DEPDIR)/Lcreate_addr_space.Plo \ - mips/$(DEPDIR)/Lget_proc_info.Plo \ - mips/$(DEPDIR)/Lget_save_loc.Plo mips/$(DEPDIR)/Lglobal.Plo \ - mips/$(DEPDIR)/Linit.Plo mips/$(DEPDIR)/Linit_local.Plo \ - mips/$(DEPDIR)/Linit_remote.Plo \ - mips/$(DEPDIR)/Lis_signal_frame.Plo \ - mips/$(DEPDIR)/Lreg_states_iterate.Plo \ - mips/$(DEPDIR)/Lregs.Plo mips/$(DEPDIR)/Lresume.Plo \ - mips/$(DEPDIR)/Lstep.Plo mips/$(DEPDIR)/getcontext.Plo \ - mips/$(DEPDIR)/is_fpreg.Plo mips/$(DEPDIR)/regname.Plo \ - mips/$(DEPDIR)/siglongjmp.Plo ppc/$(DEPDIR)/Gget_proc_info.Plo \ - ppc/$(DEPDIR)/Gget_save_loc.Plo ppc/$(DEPDIR)/Ginit_local.Plo \ - ppc/$(DEPDIR)/Ginit_remote.Plo \ - ppc/$(DEPDIR)/Gis_signal_frame.Plo \ - ppc/$(DEPDIR)/Lget_proc_info.Plo \ - ppc/$(DEPDIR)/Lget_save_loc.Plo ppc/$(DEPDIR)/Linit_local.Plo \ - ppc/$(DEPDIR)/Linit_remote.Plo \ - ppc/$(DEPDIR)/Lis_signal_frame.Plo ppc/$(DEPDIR)/longjmp.Plo \ - ppc/$(DEPDIR)/siglongjmp.Plo \ - ppc32/$(DEPDIR)/Gapply_reg_state.Plo \ - ppc32/$(DEPDIR)/Gcreate_addr_space.Plo \ - ppc32/$(DEPDIR)/Gglobal.Plo ppc32/$(DEPDIR)/Ginit.Plo \ - ppc32/$(DEPDIR)/Greg_states_iterate.Plo \ - ppc32/$(DEPDIR)/Gregs.Plo ppc32/$(DEPDIR)/Gresume.Plo \ - ppc32/$(DEPDIR)/Gstep.Plo ppc32/$(DEPDIR)/Lapply_reg_state.Plo \ - ppc32/$(DEPDIR)/Lcreate_addr_space.Plo \ - ppc32/$(DEPDIR)/Lglobal.Plo ppc32/$(DEPDIR)/Linit.Plo \ - ppc32/$(DEPDIR)/Lreg_states_iterate.Plo \ - ppc32/$(DEPDIR)/Lregs.Plo ppc32/$(DEPDIR)/Lresume.Plo \ - ppc32/$(DEPDIR)/Lstep.Plo ppc32/$(DEPDIR)/get_func_addr.Plo \ - ppc32/$(DEPDIR)/is_fpreg.Plo ppc32/$(DEPDIR)/regname.Plo \ - ppc64/$(DEPDIR)/Gapply_reg_state.Plo \ - ppc64/$(DEPDIR)/Gcreate_addr_space.Plo \ - ppc64/$(DEPDIR)/Gglobal.Plo ppc64/$(DEPDIR)/Ginit.Plo \ - ppc64/$(DEPDIR)/Greg_states_iterate.Plo \ - ppc64/$(DEPDIR)/Gregs.Plo ppc64/$(DEPDIR)/Gresume.Plo \ - ppc64/$(DEPDIR)/Gstep.Plo ppc64/$(DEPDIR)/Lapply_reg_state.Plo \ - ppc64/$(DEPDIR)/Lcreate_addr_space.Plo \ - ppc64/$(DEPDIR)/Lglobal.Plo ppc64/$(DEPDIR)/Linit.Plo \ - ppc64/$(DEPDIR)/Lreg_states_iterate.Plo \ - ppc64/$(DEPDIR)/Lregs.Plo ppc64/$(DEPDIR)/Lresume.Plo \ - ppc64/$(DEPDIR)/Lstep.Plo ppc64/$(DEPDIR)/get_func_addr.Plo \ - ppc64/$(DEPDIR)/is_fpreg.Plo ppc64/$(DEPDIR)/regname.Plo \ - ptrace/$(DEPDIR)/_UPT_access_fpreg.Plo \ - ptrace/$(DEPDIR)/_UPT_access_mem.Plo \ - ptrace/$(DEPDIR)/_UPT_access_reg.Plo \ - ptrace/$(DEPDIR)/_UPT_accessors.Plo \ - ptrace/$(DEPDIR)/_UPT_create.Plo \ - ptrace/$(DEPDIR)/_UPT_destroy.Plo \ - ptrace/$(DEPDIR)/_UPT_elf.Plo \ - ptrace/$(DEPDIR)/_UPT_find_proc_info.Plo \ - ptrace/$(DEPDIR)/_UPT_get_dyn_info_list_addr.Plo \ - ptrace/$(DEPDIR)/_UPT_get_proc_name.Plo \ - ptrace/$(DEPDIR)/_UPT_put_unwind_info.Plo \ - ptrace/$(DEPDIR)/_UPT_reg_offset.Plo \ - ptrace/$(DEPDIR)/_UPT_resume.Plo \ - riscv/$(DEPDIR)/Gapply_reg_state.Plo \ - riscv/$(DEPDIR)/Gcreate_addr_space.Plo \ - riscv/$(DEPDIR)/Gget_proc_info.Plo \ - riscv/$(DEPDIR)/Gget_save_loc.Plo riscv/$(DEPDIR)/Gglobal.Plo \ - riscv/$(DEPDIR)/Ginit.Plo riscv/$(DEPDIR)/Ginit_local.Plo \ - riscv/$(DEPDIR)/Ginit_remote.Plo \ - riscv/$(DEPDIR)/Gis_signal_frame.Plo \ - riscv/$(DEPDIR)/Greg_states_iterate.Plo \ - riscv/$(DEPDIR)/Gregs.Plo riscv/$(DEPDIR)/Gresume.Plo \ - riscv/$(DEPDIR)/Gstep.Plo riscv/$(DEPDIR)/Lapply_reg_state.Plo \ - riscv/$(DEPDIR)/Lcreate_addr_space.Plo \ - riscv/$(DEPDIR)/Lget_proc_info.Plo \ - riscv/$(DEPDIR)/Lget_save_loc.Plo riscv/$(DEPDIR)/Lglobal.Plo \ - riscv/$(DEPDIR)/Linit.Plo riscv/$(DEPDIR)/Linit_local.Plo \ - riscv/$(DEPDIR)/Linit_remote.Plo \ - riscv/$(DEPDIR)/Lis_signal_frame.Plo \ - riscv/$(DEPDIR)/Lreg_states_iterate.Plo \ - riscv/$(DEPDIR)/Lregs.Plo riscv/$(DEPDIR)/Lresume.Plo \ - riscv/$(DEPDIR)/Lstep.Plo riscv/$(DEPDIR)/getcontext.Plo \ - riscv/$(DEPDIR)/is_fpreg.Plo riscv/$(DEPDIR)/regname.Plo \ - riscv/$(DEPDIR)/setcontext.Plo riscv/$(DEPDIR)/siglongjmp.Plo \ - s390x/$(DEPDIR)/Gapply_reg_state.Plo \ - s390x/$(DEPDIR)/Gcreate_addr_space.Plo \ - s390x/$(DEPDIR)/Gget_proc_info.Plo \ - s390x/$(DEPDIR)/Gget_save_loc.Plo s390x/$(DEPDIR)/Gglobal.Plo \ - s390x/$(DEPDIR)/Ginit.Plo s390x/$(DEPDIR)/Ginit_local.Plo \ - s390x/$(DEPDIR)/Ginit_remote.Plo \ - s390x/$(DEPDIR)/Gis_signal_frame.Plo \ - s390x/$(DEPDIR)/Greg_states_iterate.Plo \ - s390x/$(DEPDIR)/Gregs.Plo s390x/$(DEPDIR)/Gresume.Plo \ - s390x/$(DEPDIR)/Gstep.Plo s390x/$(DEPDIR)/Lapply_reg_state.Plo \ - s390x/$(DEPDIR)/Lcreate_addr_space.Plo \ - s390x/$(DEPDIR)/Lget_proc_info.Plo \ - s390x/$(DEPDIR)/Lget_save_loc.Plo s390x/$(DEPDIR)/Lglobal.Plo \ - s390x/$(DEPDIR)/Linit.Plo s390x/$(DEPDIR)/Linit_local.Plo \ - s390x/$(DEPDIR)/Linit_remote.Plo \ - s390x/$(DEPDIR)/Lis_signal_frame.Plo \ - s390x/$(DEPDIR)/Lreg_states_iterate.Plo \ - s390x/$(DEPDIR)/Lregs.Plo s390x/$(DEPDIR)/Lresume.Plo \ - s390x/$(DEPDIR)/Lstep.Plo s390x/$(DEPDIR)/getcontext.Plo \ - s390x/$(DEPDIR)/is_fpreg.Plo s390x/$(DEPDIR)/regname.Plo \ - s390x/$(DEPDIR)/setcontext.Plo setjmp/$(DEPDIR)/longjmp.Plo \ - setjmp/$(DEPDIR)/siglongjmp.Plo \ - sh/$(DEPDIR)/Gapply_reg_state.Plo \ - sh/$(DEPDIR)/Gcreate_addr_space.Plo \ - sh/$(DEPDIR)/Gget_proc_info.Plo sh/$(DEPDIR)/Gget_save_loc.Plo \ - sh/$(DEPDIR)/Gglobal.Plo sh/$(DEPDIR)/Ginit.Plo \ - sh/$(DEPDIR)/Ginit_local.Plo sh/$(DEPDIR)/Ginit_remote.Plo \ - sh/$(DEPDIR)/Gis_signal_frame.Plo \ - sh/$(DEPDIR)/Greg_states_iterate.Plo sh/$(DEPDIR)/Gregs.Plo \ - sh/$(DEPDIR)/Gresume.Plo sh/$(DEPDIR)/Gstep.Plo \ - sh/$(DEPDIR)/Lapply_reg_state.Plo \ - sh/$(DEPDIR)/Lcreate_addr_space.Plo \ - sh/$(DEPDIR)/Lget_proc_info.Plo sh/$(DEPDIR)/Lget_save_loc.Plo \ - sh/$(DEPDIR)/Lglobal.Plo sh/$(DEPDIR)/Linit.Plo \ - sh/$(DEPDIR)/Linit_local.Plo sh/$(DEPDIR)/Linit_remote.Plo \ - sh/$(DEPDIR)/Lis_signal_frame.Plo \ - sh/$(DEPDIR)/Lreg_states_iterate.Plo sh/$(DEPDIR)/Lregs.Plo \ - sh/$(DEPDIR)/Lresume.Plo sh/$(DEPDIR)/Lstep.Plo \ - sh/$(DEPDIR)/is_fpreg.Plo sh/$(DEPDIR)/regname.Plo \ - sh/$(DEPDIR)/siglongjmp.Plo \ - tilegx/$(DEPDIR)/Gapply_reg_state.Plo \ - tilegx/$(DEPDIR)/Gcreate_addr_space.Plo \ - tilegx/$(DEPDIR)/Gget_proc_info.Plo \ - tilegx/$(DEPDIR)/Gget_save_loc.Plo \ - tilegx/$(DEPDIR)/Gglobal.Plo tilegx/$(DEPDIR)/Ginit.Plo \ - tilegx/$(DEPDIR)/Ginit_local.Plo \ - tilegx/$(DEPDIR)/Ginit_remote.Plo \ - tilegx/$(DEPDIR)/Gis_signal_frame.Plo \ - tilegx/$(DEPDIR)/Greg_states_iterate.Plo \ - tilegx/$(DEPDIR)/Gregs.Plo tilegx/$(DEPDIR)/Gresume.Plo \ - tilegx/$(DEPDIR)/Gstep.Plo \ - tilegx/$(DEPDIR)/Lapply_reg_state.Plo \ - tilegx/$(DEPDIR)/Lcreate_addr_space.Plo \ - tilegx/$(DEPDIR)/Lget_proc_info.Plo \ - tilegx/$(DEPDIR)/Lget_save_loc.Plo \ - tilegx/$(DEPDIR)/Lglobal.Plo tilegx/$(DEPDIR)/Linit.Plo \ - tilegx/$(DEPDIR)/Linit_local.Plo \ - tilegx/$(DEPDIR)/Linit_remote.Plo \ - tilegx/$(DEPDIR)/Lis_signal_frame.Plo \ - tilegx/$(DEPDIR)/Lreg_states_iterate.Plo \ - tilegx/$(DEPDIR)/Lregs.Plo tilegx/$(DEPDIR)/Lresume.Plo \ - tilegx/$(DEPDIR)/Lstep.Plo tilegx/$(DEPDIR)/getcontext.Plo \ - tilegx/$(DEPDIR)/is_fpreg.Plo tilegx/$(DEPDIR)/regname.Plo \ - tilegx/$(DEPDIR)/siglongjmp.Plo unwind/$(DEPDIR)/Backtrace.Plo \ - unwind/$(DEPDIR)/DeleteException.Plo \ - unwind/$(DEPDIR)/FindEnclosingFunction.Plo \ - unwind/$(DEPDIR)/ForcedUnwind.Plo unwind/$(DEPDIR)/GetBSP.Plo \ - unwind/$(DEPDIR)/GetCFA.Plo \ - unwind/$(DEPDIR)/GetDataRelBase.Plo unwind/$(DEPDIR)/GetGR.Plo \ - unwind/$(DEPDIR)/GetIP.Plo unwind/$(DEPDIR)/GetIPInfo.Plo \ - unwind/$(DEPDIR)/GetLanguageSpecificData.Plo \ - unwind/$(DEPDIR)/GetRegionStart.Plo \ - unwind/$(DEPDIR)/GetTextRelBase.Plo \ - unwind/$(DEPDIR)/RaiseException.Plo \ - unwind/$(DEPDIR)/Resume.Plo \ - unwind/$(DEPDIR)/Resume_or_Rethrow.Plo \ - unwind/$(DEPDIR)/SetGR.Plo unwind/$(DEPDIR)/SetIP.Plo \ - x86/$(DEPDIR)/Gapply_reg_state.Plo \ - x86/$(DEPDIR)/Gcreate_addr_space.Plo \ - x86/$(DEPDIR)/Gget_proc_info.Plo \ - x86/$(DEPDIR)/Gget_save_loc.Plo x86/$(DEPDIR)/Gglobal.Plo \ - x86/$(DEPDIR)/Ginit.Plo x86/$(DEPDIR)/Ginit_local.Plo \ - x86/$(DEPDIR)/Ginit_remote.Plo x86/$(DEPDIR)/Gos-freebsd.Plo \ - x86/$(DEPDIR)/Gos-linux.Plo \ - x86/$(DEPDIR)/Greg_states_iterate.Plo x86/$(DEPDIR)/Gregs.Plo \ - x86/$(DEPDIR)/Gresume.Plo x86/$(DEPDIR)/Gstep.Plo \ - x86/$(DEPDIR)/Lapply_reg_state.Plo \ - x86/$(DEPDIR)/Lcreate_addr_space.Plo \ - x86/$(DEPDIR)/Lget_proc_info.Plo \ - x86/$(DEPDIR)/Lget_save_loc.Plo x86/$(DEPDIR)/Lglobal.Plo \ - x86/$(DEPDIR)/Linit.Plo x86/$(DEPDIR)/Linit_local.Plo \ - x86/$(DEPDIR)/Linit_remote.Plo x86/$(DEPDIR)/Los-freebsd.Plo \ - x86/$(DEPDIR)/Los-linux.Plo \ - x86/$(DEPDIR)/Lreg_states_iterate.Plo x86/$(DEPDIR)/Lregs.Plo \ - x86/$(DEPDIR)/Lresume.Plo x86/$(DEPDIR)/Lstep.Plo \ - x86/$(DEPDIR)/getcontext-freebsd.Plo \ - x86/$(DEPDIR)/getcontext-linux.Plo x86/$(DEPDIR)/is_fpreg.Plo \ - x86/$(DEPDIR)/longjmp.Plo x86/$(DEPDIR)/regname.Plo \ - x86/$(DEPDIR)/siglongjmp.Plo \ - x86_64/$(DEPDIR)/Gapply_reg_state.Plo \ - x86_64/$(DEPDIR)/Gcreate_addr_space.Plo \ - x86_64/$(DEPDIR)/Gget_proc_info.Plo \ - x86_64/$(DEPDIR)/Gget_save_loc.Plo \ - x86_64/$(DEPDIR)/Gglobal.Plo x86_64/$(DEPDIR)/Ginit.Plo \ - x86_64/$(DEPDIR)/Ginit_local.Plo \ - x86_64/$(DEPDIR)/Ginit_remote.Plo \ - x86_64/$(DEPDIR)/Gos-freebsd.Plo \ - x86_64/$(DEPDIR)/Gos-linux.Plo \ - x86_64/$(DEPDIR)/Gos-solaris.Plo \ - x86_64/$(DEPDIR)/Greg_states_iterate.Plo \ - x86_64/$(DEPDIR)/Gregs.Plo x86_64/$(DEPDIR)/Gresume.Plo \ - x86_64/$(DEPDIR)/Gstash_frame.Plo x86_64/$(DEPDIR)/Gstep.Plo \ - x86_64/$(DEPDIR)/Gtrace.Plo \ - x86_64/$(DEPDIR)/Lapply_reg_state.Plo \ - x86_64/$(DEPDIR)/Lcreate_addr_space.Plo \ - x86_64/$(DEPDIR)/Lget_proc_info.Plo \ - x86_64/$(DEPDIR)/Lget_save_loc.Plo \ - x86_64/$(DEPDIR)/Lglobal.Plo x86_64/$(DEPDIR)/Linit.Plo \ - x86_64/$(DEPDIR)/Linit_local.Plo \ - x86_64/$(DEPDIR)/Linit_remote.Plo \ - x86_64/$(DEPDIR)/Los-freebsd.Plo \ - x86_64/$(DEPDIR)/Los-linux.Plo \ - x86_64/$(DEPDIR)/Los-solaris.Plo \ - x86_64/$(DEPDIR)/Lreg_states_iterate.Plo \ - x86_64/$(DEPDIR)/Lregs.Plo x86_64/$(DEPDIR)/Lresume.Plo \ - x86_64/$(DEPDIR)/Lstash_frame.Plo x86_64/$(DEPDIR)/Lstep.Plo \ - x86_64/$(DEPDIR)/Ltrace.Plo x86_64/$(DEPDIR)/getcontext.Plo \ - x86_64/$(DEPDIR)/is_fpreg.Plo x86_64/$(DEPDIR)/longjmp.Plo \ - x86_64/$(DEPDIR)/regname.Plo x86_64/$(DEPDIR)/setcontext.Plo \ - x86_64/$(DEPDIR)/siglongjmp.Plo +am__depfiles_maybe = depfiles am__mv = mv -f CPPASCOMPILE = $(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CCASFLAGS) $(CCASFLAGS) -LTCPPASCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ +LTCPPASCOMPILE = $(LIBTOOL) $(AM_V_lt) $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CCAS) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CCASFLAGS) $(CCASFLAGS) @@ -1470,13 +1156,14 @@ $(libunwind_dwarf_local_la_SOURCES) \ $(libunwind_elf32_la_SOURCES) $(libunwind_elf64_la_SOURCES) \ $(libunwind_elfxx_la_SOURCES) $(libunwind_hppa_la_SOURCES) \ - $(libunwind_ia64_la_SOURCES) $(libunwind_mips_la_SOURCES) \ - $(libunwind_ppc32_la_SOURCES) $(libunwind_ppc64_la_SOURCES) \ - $(libunwind_ptrace_la_SOURCES) $(libunwind_riscv_la_SOURCES) \ - $(libunwind_s390x_la_SOURCES) $(libunwind_setjmp_la_SOURCES) \ - $(libunwind_sh_la_SOURCES) $(libunwind_tilegx_la_SOURCES) \ - $(libunwind_x86_la_SOURCES) $(libunwind_x86_64_la_SOURCES) \ - $(libunwind_la_SOURCES) + $(libunwind_ia64_la_SOURCES) \ + $(libunwind_loongarch64_la_SOURCES) \ + $(libunwind_mips_la_SOURCES) $(libunwind_ppc32_la_SOURCES) \ + $(libunwind_ppc64_la_SOURCES) $(libunwind_ptrace_la_SOURCES) \ + $(libunwind_riscv_la_SOURCES) $(libunwind_s390x_la_SOURCES) \ + $(libunwind_setjmp_la_SOURCES) $(libunwind_sh_la_SOURCES) \ + $(libunwind_tilegx_la_SOURCES) $(libunwind_x86_la_SOURCES) \ + $(libunwind_x86_64_la_SOURCES) $(libunwind_la_SOURCES) DIST_SOURCES = $(am__libunwind_aarch64_la_SOURCES_DIST) \ $(am__libunwind_arm_la_SOURCES_DIST) \ $(am__libunwind_coredump_la_SOURCES_DIST) \ @@ -1487,6 +1174,7 @@ $(libunwind_elfxx_la_SOURCES) \ $(am__libunwind_hppa_la_SOURCES_DIST) \ $(am__libunwind_ia64_la_SOURCES_DIST) \ + $(am__libunwind_loongarch64_la_SOURCES_DIST) \ $(am__libunwind_mips_la_SOURCES_DIST) \ $(am__libunwind_ppc32_la_SOURCES_DIST) \ $(am__libunwind_ppc64_la_SOURCES_DIST) \ @@ -1523,6 +1211,8 @@ 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)/libunwind-generic.pc.in $(top_srcdir)/config/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) @@ -1544,8 +1234,6 @@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ -CSCOPE = @CSCOPE@ -CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ @@ -1561,7 +1249,6 @@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ -ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ @@ -1612,6 +1299,7 @@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ +UNW_TESTDRIVER = @UNW_TESTDRIVER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ @@ -1682,13 +1370,19 @@ # Don't link with start-files since we don't use any constructors/destructors: # COMMON_SO_LDFLAGS = $(LDFLAGS_NOSTARTFILES) -lib_LIBRARIES = + +# +# Which libraries to build and install +# +# Order is important here. The names of teh libraries need to end up in reverse +# dependency order for `make install` to do its job properly. +# lib_LTLIBRARIES = $(am__append_1) $(am__append_2) $(am__append_3) \ - $(am__append_13) $(am__append_16) $(am__append_19) \ - $(am__append_22) $(am__append_25) $(am__append_28) \ - $(am__append_31) $(am__append_34) $(am__append_37) \ - $(am__append_40) $(am__append_43) $(am__append_46) \ - $(am__append_49) $(am__append_51) + $(am__append_4) $(am__append_5) $(am__append_6) \ + $(am__append_7) $(am__append_8) $(am__append_9) \ + $(am__append_10) $(am__append_11) $(am__append_12) \ + $(am__append_13) $(am__append_14) $(am__append_15) \ + $(am__append_16) $(am__append_17) $(am__append_18) # The list of files that go into libunwind and libunwind-aarch64: @@ -1704,6 +1398,8 @@ # The list of files that go info libunwind and libunwind-riscv: +# The list of files that go info libunwind and libunwind-loongarch64: + # The list of files that go both into libunwind and libunwind-x86: # The list of files that go both into libunwind and libunwind-x86_64: @@ -1716,25 +1412,27 @@ # The list of files that go both into libunwind and libunwind-s390x: noinst_HEADERS = ptrace/_UPT_internal.h coredump/_UCD_internal.h \ - coredump/_UCD_lib.h setjmp/setjmp_i.h os-linux.h elf32.h \ - elf64.h elfxx.h aarch64/init.h aarch64/offsets.h \ - aarch64/unwind_i.h arm/init.h arm/offsets.h arm/unwind_i.h \ - ia64/init.h ia64/offsets.h ia64/regs.h ia64/ucontext_i.h \ - ia64/unwind_decoder.h ia64/unwind_i.h hppa/init.h \ - hppa/offsets.h hppa/unwind_i.h mips/init.h mips/offsets.h \ - mips/unwind_i.h tilegx/init.h tilegx/offsets.h \ - tilegx/unwind_i.h riscv/init.h riscv/offsets.h \ - riscv/unwind_i.h riscv/asm.h x86/init.h x86/offsets.h \ - x86/unwind_i.h x86_64/offsets.h x86_64/init.h \ - x86_64/unwind_i.h x86_64/ucontext_i.h ppc32/init.h \ - ppc32/unwind_i.h ppc32/ucontext_i.h ppc64/init.h \ - ppc64/unwind_i.h ppc64/ucontext_i.h sh/init.h sh/offsets.h \ - sh/unwind_i.h s390x/init.h s390x/unwind_i.h \ - unwind/unwind-internal.h -noinst_LTLIBRARIES = $(am__append_8) $(am__append_9) $(LIBUNWIND_ELF) + coredump/_UCD_lib.h coredump/ucd_file_table.h \ + setjmp/setjmp_i.h os-linux.h elf32.h elf64.h elfxx.h \ + aarch64/init.h aarch64/offsets.h aarch64/unwind_i.h arm/init.h \ + arm/offsets.h arm/unwind_i.h ia64/init.h ia64/offsets.h \ + ia64/regs.h ia64/ucontext_i.h ia64/unwind_decoder.h \ + ia64/unwind_i.h hppa/init.h hppa/offsets.h hppa/unwind_i.h \ + mips/init.h mips/offsets.h mips/unwind_i.h tilegx/init.h \ + tilegx/offsets.h tilegx/unwind_i.h riscv/init.h \ + riscv/offsets.h riscv/unwind_i.h riscv/asm.h \ + loongarch64/init.h loongarch64/offsets.h \ + loongarch64/unwind_i.h x86/init.h x86/offsets.h x86/unwind_i.h \ + x86_64/offsets.h x86_64/init.h x86_64/unwind_i.h \ + x86_64/ucontext_i.h ppc32/init.h ppc32/unwind_i.h \ + ppc32/ucontext_i.h ppc64/init.h ppc64/unwind_i.h \ + ppc64/ucontext_i.h sh/init.h sh/offsets.h sh/unwind_i.h \ + s390x/init.h s390x/unwind_i.h unwind/unwind-internal.h +noinst_LTLIBRARIES = $(am__append_23) $(am__append_24) \ + $(LIBUNWIND_ELF) pkgconfigdir = $(libdir)/pkgconfig -pkgconfig_DATA = libunwind-generic.pc $(am__append_4) $(am__append_5) \ - $(am__append_6) $(am__append_7) +pkgconfig_DATA = libunwind-generic.pc $(am__append_19) \ + $(am__append_20) $(am__append_21) $(am__append_22) ### libunwind-ptrace: libunwind_ptrace_la_SOURCES = \ @@ -1746,21 +1444,22 @@ ptrace/_UPT_put_unwind_info.c ptrace/_UPT_get_proc_name.c \ ptrace/_UPT_reg_offset.c ptrace/_UPT_resume.c +libunwind_ptrace_la_LIBADD = libunwind-$(arch).la $(LIBLZMA) ### libunwind-coredump: libunwind_coredump_la_SOURCES = coredump/_UCD_accessors.c \ coredump/_UCD_create.c coredump/_UCD_destroy.c \ coredump/_UCD_access_mem.c coredump/_UCD_elf_map_image.c \ coredump/_UCD_find_proc_info.c coredump/_UCD_get_proc_name.c \ - coredump/_UCD_corefile_elf.c coredump/_UPT_elf.c \ - coredump/_UPT_access_fpreg.c \ + coredump/_UCD_corefile_elf.c coredump/ucd_file_table.c \ + coredump/_UPT_elf.c coredump/_UPT_access_fpreg.c \ coredump/_UPT_get_dyn_info_list_addr.c \ coredump/_UPT_put_unwind_info.c coredump/_UPT_resume.c \ - $(am__append_11) $(am__append_12) + $(am__append_26) $(am__append_27) libunwind_coredump_la_LDFLAGS = $(COMMON_SO_LDFLAGS) \ -version-info $(COREDUMP_SO_VERSION) -libunwind_coredump_la_LIBADD = $(LIBLZMA) $(LIBZ) +libunwind_coredump_la_LIBADD = libunwind-$(arch).la $(LIBLZMA) $(LIBZ) ### libunwind-setjmp: libunwind_setjmp_la_LDFLAGS = $(COMMON_SO_LDFLAGS) \ @@ -1774,13 +1473,14 @@ libunwind.la -lc libunwind_setjmp_la_SOURCES = setjmp/longjmp.c setjmp/siglongjmp.c \ - $(am__append_15) $(am__append_18) $(am__append_21) \ - $(am__append_24) $(am__append_27) $(am__append_30) \ - $(am__append_33) $(am__append_36) $(am__append_39) \ - $(am__append_42) $(am__append_45) $(am__append_48) + $(am__append_29) $(am__append_31) $(am__append_33) \ + $(am__append_35) $(am__append_37) $(am__append_39) \ + $(am__append_41) $(am__append_43) $(am__append_45) \ + $(am__append_47) $(am__append_49) $(am__append_51) \ + $(am__append_53) ### libunwind: -libunwind_la_LIBADD = $(am__append_10) $(LIBUNWIND_ELF) -lc $(LIBCRTS) \ +libunwind_la_LIBADD = $(am__append_25) $(LIBUNWIND_ELF) -lc $(LIBCRTS) \ $(LIBLZMA) $(LIBZ) # List of arch-independent files needed by both local-only and generic @@ -1795,6 +1495,7 @@ mi/Gdyn-extract.c mi/Gdyn-remote.c mi/Gfind_dynamic_proc_info.c \ mi/Gget_accessors.c \ mi/Gget_proc_info_by_ip.c mi/Gget_proc_name.c \ + mi/Gget_proc_info_in_range.c \ mi/Gput_dynamic_unwind_info.c mi/Gdestroy_addr_space.c \ mi/Gget_reg.c mi/Gset_reg.c \ mi/Gget_fpreg.c mi/Gset_fpreg.c \ @@ -1823,6 +1524,7 @@ mi/Ldyn-extract.c mi/Lfind_dynamic_proc_info.c \ mi/Lget_accessors.c \ mi/Lget_proc_info_by_ip.c mi/Lget_proc_name.c \ + mi/Lget_proc_info_in_range.c \ mi/Lput_dynamic_unwind_info.c mi/Ldestroy_addr_space.c \ mi/Lget_reg.c mi/Lset_reg.c \ mi/Lget_fpreg.c mi/Lset_fpreg.c \ @@ -2022,6 +1724,30 @@ riscv/Gglobal.c riscv/Ginit.c riscv/Ginit_local.c riscv/Ginit_remote.c \ riscv/Gis_signal_frame.c riscv/Gregs.c riscv/Gresume.c riscv/Gstep.c +libunwind_la_SOURCES_loongarch64_common = $(libunwind_la_SOURCES_common) \ + loongarch64/is_fpreg.c loongarch64/regname.c + + +# The list of files that go into libunwind: +libunwind_la_SOURCES_loongarch64 = $(libunwind_la_SOURCES_loongarch64_common) \ + $(libunwind_la_SOURCES_local) \ + loongarch64/getcontext.S \ + loongarch64/Lapply_reg_state.c loongarch64/Lreg_states_iterate.c \ + loongarch64/Lcreate_addr_space.c loongarch64/Lget_proc_info.c \ + loongarch64/Lget_save_loc.c loongarch64/Lglobal.c loongarch64/Linit.c \ + loongarch64/Linit_local.c loongarch64/Linit_remote.c \ + loongarch64/Lis_signal_frame.c loongarch64/Lregs.c \ + loongarch64/Lresume.c loongarch64/Lstep.c + +libunwind_loongarch64_la_SOURCES_loongarch64 = $(libunwind_la_SOURCES_loongarch64_common) \ + $(libunwind_la_SOURCES_generic) \ + loongarch64/Gapply_reg_state.c loongarch64/Greg_states_iterate.c \ + loongarch64/Gcreate_addr_space.c loongarch64/Gget_proc_info.c \ + loongarch64/Gget_save_loc.c loongarch64/Gglobal.c loongarch64/Ginit.c \ + loongarch64/Ginit_local.c loongarch64/Ginit_remote.c \ + loongarch64/Gis_signal_frame.c loongarch64/Gregs.c \ + loongarch64/Gresume.c loongarch64/Gstep.c + libunwind_la_SOURCES_x86_common = $(libunwind_la_SOURCES_common) \ x86/is_fpreg.c x86/regname.c @@ -2201,12 +1927,13 @@ @OS_FREEBSD_TRUE@libunwind_la_SOURCES_arm_os_local = arm/Los-freebsd.c @OS_LINUX_TRUE@libunwind_la_SOURCES_arm_os_local = arm/Los-linux.c @OS_QNX_TRUE@libunwind_la_SOURCES_arm_os_local = arm/Los-other.c -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_s390x) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_sh) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_ppc64) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_ppc32) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_x86_64) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_x86) $(libunwind_x86_la_SOURCES_os) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_s390x) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_sh) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_ppc64) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_ppc32) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_x86_64) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_x86) $(libunwind_x86_la_SOURCES_os) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_loongarch64) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_riscv) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_tilegx) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@libunwind_la_SOURCES = $(libunwind_la_SOURCES_mips) @@ -2218,68 +1945,73 @@ @ARCH_AARCH64_TRUE@libunwind_aarch64_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @ARCH_AARCH64_TRUE@libunwind_aarch64_la_LIBADD = \ @ARCH_AARCH64_TRUE@ libunwind-dwarf-generic.la \ -@ARCH_AARCH64_TRUE@ libunwind-elf64.la $(am__append_14) +@ARCH_AARCH64_TRUE@ libunwind-elf64.la $(am__append_28) @ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@libunwind_arm_la_SOURCES = $(libunwind_arm_la_SOURCES_arm) @ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@libunwind_arm_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@libunwind_arm_la_LIBADD = \ @ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@ libunwind-dwarf-generic.la \ @ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@ libunwind-elf32.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@ $(am__append_17) +@ARCH_AARCH64_FALSE@@ARCH_ARM_TRUE@ $(am__append_30) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@BUILT_SOURCES = Gcursor_i.h Lcursor_i.h @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@libunwind_ia64_la_SOURCES = $(libunwind_ia64_la_SOURCES_ia64) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@libunwind_ia64_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@libunwind_ia64_la_LIBADD = libunwind-elf64.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@ $(am__append_20) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_IA64_TRUE@ $(am__append_32) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@libunwind_hppa_la_SOURCES = $(libunwind_hppa_la_SOURCES_hppa) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@libunwind_hppa_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@libunwind_hppa_la_LIBADD = libunwind-dwarf-generic.la \ @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@ libunwind-elf32.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@ $(am__append_23) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_TRUE@@ARCH_IA64_FALSE@ $(am__append_34) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@libunwind_mips_la_SOURCES = $(libunwind_mips_la_SOURCES_mips) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@libunwind_mips_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@libunwind_mips_la_LIBADD = libunwind-dwarf-generic.la \ @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@ libunwind-elfxx.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@ $(am__append_26) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_TRUE@ $(am__append_36) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@libunwind_tilegx_la_SOURCES = $(libunwind_tilegx_la_SOURCES_tilegx) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@libunwind_tilegx_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@libunwind_tilegx_la_LIBADD = libunwind-dwarf-generic.la \ @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@ libunwind-elfxx.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@ $(am__append_29) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_TILEGX_TRUE@ $(am__append_38) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@libunwind_riscv_la_SOURCES = $(libunwind_riscv_la_SOURCES_riscv) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@libunwind_riscv_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@libunwind_riscv_la_LIBADD = libunwind-dwarf-generic.la \ @ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@ libunwind-elf64.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@ $(am__append_32) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@libunwind_x86_la_SOURCES = $(libunwind_x86_la_SOURCES_x86) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@libunwind_x86_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@libunwind_x86_la_LIBADD = libunwind-dwarf-generic.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ libunwind-elf32.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ $(am__append_35) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@libunwind_x86_64_la_SOURCES = $(libunwind_x86_64_la_SOURCES_x86_64) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@libunwind_x86_64_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@libunwind_x86_64_la_LIBADD = libunwind-dwarf-generic.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@ libunwind-elf64.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@ $(am__append_38) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc32_la_SOURCES = $(libunwind_ppc32_la_SOURCES_ppc32) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc32_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc32_la_LIBADD = libunwind-dwarf-generic.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf32.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__append_41) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc64_la_SOURCES = $(libunwind_ppc64_la_SOURCES_ppc64) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc64_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc64_la_LIBADD = libunwind-dwarf-generic.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf64.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__append_44) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_sh_la_SOURCES = $(libunwind_sh_la_SOURCES_sh) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_sh_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_sh_la_LIBADD = libunwind-dwarf-generic.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf32.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__append_47) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_s390x_la_SOURCES = $(libunwind_s390x_la_SOURCES_s390x) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_s390x_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_s390x_la_LIBADD = libunwind-dwarf-generic.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf64.la \ -@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__append_50) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_TRUE@@ARCH_TILEGX_FALSE@ $(am__append_40) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@libunwind_loongarch64_la_SOURCES = $(libunwind_loongarch64_la_SOURCES_loongarch64) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@libunwind_loongarch64_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@libunwind_loongarch64_la_LIBADD = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@ libunwind-elf64.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_TRUE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@ $(am__append_42) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@libunwind_x86_la_SOURCES = $(libunwind_x86_la_SOURCES_x86) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@libunwind_x86_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@libunwind_x86_la_LIBADD = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ libunwind-elf32.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_TRUE@ $(am__append_44) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@libunwind_x86_64_la_SOURCES = $(libunwind_x86_64_la_SOURCES_x86_64) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@libunwind_x86_64_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@libunwind_x86_64_la_LIBADD = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@ libunwind-elf64.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_TRUE@@ARCH_X86_FALSE@ $(am__append_46) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc32_la_SOURCES = $(libunwind_ppc32_la_SOURCES_ppc32) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc32_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc32_la_LIBADD = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf32.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__append_48) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc64_la_SOURCES = $(libunwind_ppc64_la_SOURCES_ppc64) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc64_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_ppc64_la_LIBADD = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf64.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_TRUE@@ARCH_RISCV_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__append_50) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_sh_la_SOURCES = $(libunwind_sh_la_SOURCES_sh) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_sh_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_sh_la_LIBADD = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf32.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_SH_TRUE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__append_52) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_s390x_la_SOURCES = $(libunwind_s390x_la_SOURCES_s390x) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_s390x_la_LDFLAGS = $(COMMON_SO_LDFLAGS) -version-info $(SOVERSION) +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@libunwind_s390x_la_LIBADD = libunwind-dwarf-generic.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ libunwind-elf64.la \ +@ARCH_AARCH64_FALSE@@ARCH_ARM_FALSE@@ARCH_HPPA_FALSE@@ARCH_IA64_FALSE@@ARCH_LOONGARCH64_FALSE@@ARCH_MIPS_FALSE@@ARCH_PPC32_FALSE@@ARCH_PPC64_FALSE@@ARCH_RISCV_FALSE@@ARCH_S390X_TRUE@@ARCH_SH_FALSE@@ARCH_TILEGX_FALSE@@ARCH_X86_64_FALSE@@ARCH_X86_FALSE@ $(am__append_54) # # Don't link with standard libraries, because those may mention @@ -2338,8 +2070,8 @@ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ + 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) @@ -2352,37 +2084,6 @@ $(am__aclocal_m4_deps): libunwind-generic.pc: $(top_builddir)/config.status $(srcdir)/libunwind-generic.pc.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ -install-libLIBRARIES: $(lib_LIBRARIES) - @$(NORMAL_INSTALL) - @list='$(lib_LIBRARIES)'; 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 " $(INSTALL_DATA) $$list2 '$(DESTDIR)$(libdir)'"; \ - $(INSTALL_DATA) $$list2 "$(DESTDIR)$(libdir)" || exit $$?; } - @$(POST_INSTALL) - @list='$(lib_LIBRARIES)'; test -n "$(libdir)" || list=; \ - for p in $$list; do \ - if test -f $$p; then \ - $(am__strip_dir) \ - echo " ( cd '$(DESTDIR)$(libdir)' && $(RANLIB) $$f )"; \ - ( cd "$(DESTDIR)$(libdir)" && $(RANLIB) $$f ) || exit $$?; \ - else :; fi; \ - done - -uninstall-libLIBRARIES: - @$(NORMAL_UNINSTALL) - @list='$(lib_LIBRARIES)'; test -n "$(libdir)" || list=; \ - files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ - dir='$(DESTDIR)$(libdir)'; $(am__uninstall_files_from_dir) - -clean-libLIBRARIES: - -test -z "$(lib_LIBRARIES)" || rm -f $(lib_LIBRARIES) install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @@ -2457,6 +2158,8 @@ mi/Gget_proc_info_by_ip.lo: mi/$(am__dirstamp) \ mi/$(DEPDIR)/$(am__dirstamp) mi/Gget_proc_name.lo: mi/$(am__dirstamp) mi/$(DEPDIR)/$(am__dirstamp) +mi/Gget_proc_info_in_range.lo: mi/$(am__dirstamp) \ + mi/$(DEPDIR)/$(am__dirstamp) mi/Gput_dynamic_unwind_info.lo: mi/$(am__dirstamp) \ mi/$(DEPDIR)/$(am__dirstamp) mi/Gdestroy_addr_space.lo: mi/$(am__dirstamp) \ @@ -2557,6 +2260,8 @@ coredump/$(DEPDIR)/$(am__dirstamp) coredump/_UCD_corefile_elf.lo: coredump/$(am__dirstamp) \ coredump/$(DEPDIR)/$(am__dirstamp) +coredump/ucd_file_table.lo: coredump/$(am__dirstamp) \ + coredump/$(DEPDIR)/$(am__dirstamp) coredump/_UPT_elf.lo: coredump/$(am__dirstamp) \ coredump/$(DEPDIR)/$(am__dirstamp) coredump/_UPT_access_fpreg.lo: coredump/$(am__dirstamp) \ @@ -2693,6 +2398,45 @@ libunwind-ia64.la: $(libunwind_ia64_la_OBJECTS) $(libunwind_ia64_la_DEPENDENCIES) $(EXTRA_libunwind_ia64_la_DEPENDENCIES) $(AM_V_CCLD)$(libunwind_ia64_la_LINK) $(am_libunwind_ia64_la_rpath) $(libunwind_ia64_la_OBJECTS) $(libunwind_ia64_la_LIBADD) $(LIBS) +loongarch64/$(am__dirstamp): + @$(MKDIR_P) loongarch64 + @: > loongarch64/$(am__dirstamp) +loongarch64/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) loongarch64/$(DEPDIR) + @: > loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/is_fpreg.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/regname.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Gapply_reg_state.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Greg_states_iterate.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Gcreate_addr_space.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Gget_proc_info.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Gget_save_loc.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Gglobal.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Ginit.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Ginit_local.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Ginit_remote.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Gis_signal_frame.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Gregs.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Gresume.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Gstep.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) + +libunwind-loongarch64.la: $(libunwind_loongarch64_la_OBJECTS) $(libunwind_loongarch64_la_DEPENDENCIES) $(EXTRA_libunwind_loongarch64_la_DEPENDENCIES) + $(AM_V_CCLD)$(libunwind_loongarch64_la_LINK) $(am_libunwind_loongarch64_la_rpath) $(libunwind_loongarch64_la_OBJECTS) $(libunwind_loongarch64_la_LIBADD) $(LIBS) mips/$(am__dirstamp): @$(MKDIR_P) mips @: > mips/$(am__dirstamp) @@ -2934,6 +2678,8 @@ tilegx/$(DEPDIR)/$(am__dirstamp) riscv/siglongjmp.lo: riscv/$(am__dirstamp) \ riscv/$(DEPDIR)/$(am__dirstamp) +loongarch64/siglongjmp.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) x86/$(am__dirstamp): @$(MKDIR_P) x86 @: > x86/$(am__dirstamp) @@ -3097,6 +2843,8 @@ mi/Lget_proc_info_by_ip.lo: mi/$(am__dirstamp) \ mi/$(DEPDIR)/$(am__dirstamp) mi/Lget_proc_name.lo: mi/$(am__dirstamp) mi/$(DEPDIR)/$(am__dirstamp) +mi/Lget_proc_info_in_range.lo: mi/$(am__dirstamp) \ + mi/$(DEPDIR)/$(am__dirstamp) mi/Lput_dynamic_unwind_info.lo: mi/$(am__dirstamp) \ mi/$(DEPDIR)/$(am__dirstamp) mi/Ldestroy_addr_space.lo: mi/$(am__dirstamp) \ @@ -3289,6 +3037,34 @@ x86/$(DEPDIR)/$(am__dirstamp) x86/getcontext-linux.lo: x86/$(am__dirstamp) \ x86/$(DEPDIR)/$(am__dirstamp) +loongarch64/getcontext.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Lapply_reg_state.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Lreg_states_iterate.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Lcreate_addr_space.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Lget_proc_info.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Lget_save_loc.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Lglobal.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Linit.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Linit_local.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Linit_remote.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Lis_signal_frame.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Lregs.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Lresume.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) +loongarch64/Lstep.lo: loongarch64/$(am__dirstamp) \ + loongarch64/$(DEPDIR)/$(am__dirstamp) riscv/getcontext.lo: riscv/$(am__dirstamp) \ riscv/$(DEPDIR)/$(am__dirstamp) riscv/setcontext.lo: riscv/$(am__dirstamp) \ @@ -3499,6 +3275,8 @@ -rm -f hppa/*.lo -rm -f ia64/*.$(OBJEXT) -rm -f ia64/*.lo + -rm -f loongarch64/*.$(OBJEXT) + -rm -f loongarch64/*.lo -rm -f mi/*.$(OBJEXT) -rm -f mi/*.lo -rm -f mips/*.$(OBJEXT) @@ -3531,545 +3309,572 @@ distclean-compile: -rm -f *.tab.c -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/dl-iterate-phdr.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf64.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elfxx.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/os-freebsd.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/os-hpux.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/os-linux.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/os-qnx.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/os-solaris.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Ginit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Ginit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gstash_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gtrace.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Linit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Linit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lstash_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Ltrace.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/getcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/is_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/siglongjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gex_tables.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Ginit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Ginit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gos-freebsd.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gos-linux.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gos-other.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gstash_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gtrace.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lex_tables.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Linit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Linit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Los-freebsd.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Los-linux.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Los-other.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lstash_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Ltrace.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/getcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/is_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/siglongjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_access_mem.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_access_reg_freebsd.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_access_reg_linux.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_accessors.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_corefile_elf.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_create.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_destroy.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_elf_map_image.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_find_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_get_mapinfo_generic.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_get_mapinfo_linux.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_get_proc_name.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_get_threadinfo_prstatus.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UPT_access_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UPT_elf.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UPT_get_dyn_info_list_addr.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UPT_put_unwind_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UPT_resume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Gexpr.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Gfde.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Gfind_proc_info-lsb.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Gfind_unwind_table.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Gparser.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Gpe.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Lexpr.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Lfde.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Lfind_proc_info-lsb.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Lfind_unwind_table.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Lparser.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Lpe.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/global.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Ginit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Ginit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Linit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Linit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/getcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/setcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/siglongjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gfind_unwind_table.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Ginit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Ginit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Ginstall_cursor.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gparser.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Grbs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gscript.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gtables.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lfind_unwind_table.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Linit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Linit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Linstall_cursor.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lparser.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lrbs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lscript.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Ltables.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/dyn_info_list.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/getcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/longjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/setjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/siglongjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/sigsetjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gdestroy_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gdyn-extract.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gdyn-remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gfind_dynamic_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gget_accessors.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gget_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gget_proc_info_by_ip.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gget_proc_name.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gget_reg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gput_dynamic_unwind_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gset_cache_size.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gset_caching_policy.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gset_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gset_reg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Ldestroy_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Ldyn-extract.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lfind_dynamic_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lget_accessors.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lget_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lget_proc_info_by_ip.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lget_proc_name.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lget_reg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lput_dynamic_unwind_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lset_cache_size.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lset_caching_policy.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lset_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lset_reg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/_ReadSLEB.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/_ReadULEB.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/backtrace.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/dyn-cancel.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/dyn-info-list.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/dyn-register.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/flush_cache.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/init.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/mempool.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/strerror.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Ginit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Ginit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Linit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Linit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/getcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/is_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/siglongjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Ginit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Ginit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Linit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Linit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/longjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/siglongjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/get_func_addr.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/is_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/get_func_addr.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/is_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_access_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_access_mem.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_access_reg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_accessors.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_create.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_destroy.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_elf.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_find_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_get_dyn_info_list_addr.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_get_proc_name.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_put_unwind_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_reg_offset.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_resume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Ginit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Ginit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Linit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Linit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/getcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/is_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/setcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/siglongjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Ginit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Ginit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Linit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Linit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/getcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/is_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/setcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@setjmp/$(DEPDIR)/longjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@setjmp/$(DEPDIR)/siglongjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Ginit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Ginit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Linit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Linit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/is_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/siglongjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Ginit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Ginit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Linit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Linit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/getcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/is_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/siglongjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/Backtrace.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/DeleteException.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/FindEnclosingFunction.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/ForcedUnwind.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetBSP.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetCFA.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetDataRelBase.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetGR.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetIP.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetIPInfo.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetLanguageSpecificData.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetRegionStart.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetTextRelBase.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/RaiseException.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/Resume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/Resume_or_Rethrow.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/SetGR.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/SetIP.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Ginit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Ginit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gos-freebsd.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gos-linux.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Linit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Linit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Los-freebsd.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Los-linux.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/getcontext-freebsd.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/getcontext-linux.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/is_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/longjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/siglongjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Ginit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Ginit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Ginit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gos-freebsd.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gos-linux.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gos-solaris.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gstash_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gtrace.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lglobal.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Linit.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Linit_local.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Linit_remote.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Los-freebsd.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Los-linux.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Los-solaris.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lregs.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lresume.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lstash_frame.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lstep.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Ltrace.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/getcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/is_fpreg.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/longjmp.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/regname.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/setcontext.Plo@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/siglongjmp.Plo@am__quote@ # am--include-marker - -$(am__depfiles_remade): - @$(MKDIR_P) $(@D) - @echo '# dummy' >$@-t && $(am__mv) $@-t $@ - -am--depfiles: $(am__depfiles_remade) +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/dl-iterate-phdr.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf64.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elfxx.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/os-freebsd.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/os-hpux.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/os-linux.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/os-qnx.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/os-solaris.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gstash_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Gtrace.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lstash_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/Ltrace.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/getcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/is_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@aarch64/$(DEPDIR)/siglongjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gex_tables.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gos-freebsd.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gos-linux.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gos-other.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gstash_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Gtrace.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lex_tables.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Los-freebsd.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Los-linux.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Los-other.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lstash_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/Ltrace.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/getcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/is_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@arm/$(DEPDIR)/siglongjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_access_mem.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_access_reg_freebsd.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_access_reg_linux.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_accessors.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_corefile_elf.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_create.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_destroy.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_elf_map_image.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_find_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_get_mapinfo_generic.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_get_mapinfo_linux.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_get_proc_name.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UCD_get_threadinfo_prstatus.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UPT_access_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UPT_elf.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UPT_get_dyn_info_list_addr.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UPT_put_unwind_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/_UPT_resume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@coredump/$(DEPDIR)/ucd_file_table.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Gexpr.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Gfde.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Gfind_proc_info-lsb.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Gfind_unwind_table.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Gparser.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Gpe.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Lexpr.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Lfde.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Lfind_proc_info-lsb.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Lfind_unwind_table.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Lparser.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/Lpe.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dwarf/$(DEPDIR)/global.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/getcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/setcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@hppa/$(DEPDIR)/siglongjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gfind_unwind_table.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Ginstall_cursor.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gparser.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Grbs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gscript.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Gtables.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lfind_unwind_table.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Linstall_cursor.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lparser.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lrbs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lscript.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/Ltables.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/dyn_info_list.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/getcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/longjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/setjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/siglongjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ia64/$(DEPDIR)/sigsetjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/getcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/is_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@loongarch64/$(DEPDIR)/siglongjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gdestroy_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gdyn-extract.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gdyn-remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gfind_dynamic_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gget_accessors.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gget_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gget_proc_info_by_ip.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gget_proc_info_in_range.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gget_proc_name.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gget_reg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gput_dynamic_unwind_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gset_cache_size.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gset_caching_policy.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gset_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Gset_reg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Ldestroy_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Ldyn-extract.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lfind_dynamic_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lget_accessors.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lget_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lget_proc_info_by_ip.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lget_proc_info_in_range.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lget_proc_name.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lget_reg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lput_dynamic_unwind_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lset_cache_size.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lset_caching_policy.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lset_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/Lset_reg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/_ReadSLEB.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/_ReadULEB.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/backtrace.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/dyn-cancel.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/dyn-info-list.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/dyn-register.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/flush_cache.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/init.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/mempool.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mi/$(DEPDIR)/strerror.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/getcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/is_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@mips/$(DEPDIR)/siglongjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/longjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc/$(DEPDIR)/siglongjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/get_func_addr.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/is_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc32/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/get_func_addr.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/is_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ppc64/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_access_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_access_mem.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_access_reg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_accessors.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_create.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_destroy.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_elf.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_find_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_get_dyn_info_list_addr.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_get_proc_name.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_put_unwind_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_reg_offset.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@ptrace/$(DEPDIR)/_UPT_resume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/getcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/is_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/setcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@riscv/$(DEPDIR)/siglongjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/getcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/is_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@s390x/$(DEPDIR)/setcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@setjmp/$(DEPDIR)/longjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@setjmp/$(DEPDIR)/siglongjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/is_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@sh/$(DEPDIR)/siglongjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lis_signal_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/getcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/is_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@tilegx/$(DEPDIR)/siglongjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/Backtrace.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/DeleteException.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/FindEnclosingFunction.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/ForcedUnwind.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetBSP.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetCFA.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetDataRelBase.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetGR.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetIP.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetIPInfo.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetLanguageSpecificData.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetRegionStart.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/GetTextRelBase.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/RaiseException.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/Resume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/Resume_or_Rethrow.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/SetGR.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@unwind/$(DEPDIR)/SetIP.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gos-freebsd.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gos-linux.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Los-freebsd.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Los-linux.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/getcontext-freebsd.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/getcontext-linux.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/is_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/longjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86/$(DEPDIR)/siglongjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Ginit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Ginit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Ginit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gos-freebsd.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gos-linux.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gos-solaris.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Greg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gstash_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Gtrace.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lapply_reg_state.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lcreate_addr_space.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lget_proc_info.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lget_save_loc.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lglobal.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Linit.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Linit_local.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Linit_remote.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Los-freebsd.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Los-linux.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Los-solaris.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lreg_states_iterate.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lregs.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lresume.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lstash_frame.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Lstep.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/Ltrace.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/getcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/is_fpreg.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/longjmp.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/regname.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/setcontext.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@x86_64/$(DEPDIR)/siglongjmp.Plo@am__quote@ .S.o: @am__fastdepCCAS_TRUE@ $(AM_V_CPPAS)depbase=`echo $@ | sed 's|^/*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @@ -4130,6 +3935,7 @@ -rm -rf dwarf/.libs dwarf/_libs -rm -rf hppa/.libs hppa/_libs -rm -rf ia64/.libs ia64/_libs + -rm -rf loongarch64/.libs loongarch64/_libs -rm -rf mi/.libs mi/_libs -rm -rf mips/.libs mips/_libs -rm -rf ppc/.libs ppc/_libs @@ -4217,10 +4023,8 @@ distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags -distdir: $(BUILT_SOURCES) - $(MAKE) $(AM_MAKEFLAGS) distdir-am -distdir-am: $(DISTFILES) +distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/.^$$\\*/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/.^$$\\*/\\\\&/g'`; \ list='$(DISTFILES)'; \ @@ -4253,15 +4057,14 @@ check-am: all-am check: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) check-am -all-am: Makefile $(LIBRARIES) $(LTLIBRARIES) $(DATA) $(HEADERS) +all-am: Makefile $(LTLIBRARIES) $(DATA) $(HEADERS) installdirs: - for dir in "$(DESTDIR)$(libdir)" "$(DESTDIR)$(libdir)" "$(DESTDIR)$(pkgconfigdir)"; do \ + for dir in "$(DESTDIR)$(libdir)" "$(DESTDIR)$(pkgconfigdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) install-am -install-exec: $(BUILT_SOURCES) - $(MAKE) $(AM_MAKEFLAGS) install-exec-am +install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am @@ -4298,6 +4101,8 @@ -rm -f hppa/$(am__dirstamp) -rm -f ia64/$(DEPDIR)/$(am__dirstamp) -rm -f ia64/$(am__dirstamp) + -rm -f loongarch64/$(DEPDIR)/$(am__dirstamp) + -rm -f loongarch64/$(am__dirstamp) -rm -f mi/$(DEPDIR)/$(am__dirstamp) -rm -f mi/$(am__dirstamp) -rm -f mips/$(DEPDIR)/$(am__dirstamp) @@ -4334,543 +4139,11 @@ -test -z "$(MAINTAINERCLEANFILES)" || rm -f $(MAINTAINERCLEANFILES) clean: clean-am -clean-am: clean-generic clean-libLIBRARIES clean-libLTLIBRARIES \ - clean-libtool clean-noinstLTLIBRARIES mostlyclean-am +clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ + clean-noinstLTLIBRARIES mostlyclean-am distclean: distclean-am - -rm -f ./$(DEPDIR)/dl-iterate-phdr.Plo - -rm -f ./$(DEPDIR)/elf32.Plo - -rm -f ./$(DEPDIR)/elf64.Plo - -rm -f ./$(DEPDIR)/elfxx.Plo - -rm -f ./$(DEPDIR)/os-freebsd.Plo - -rm -f ./$(DEPDIR)/os-hpux.Plo - -rm -f ./$(DEPDIR)/os-linux.Plo - -rm -f ./$(DEPDIR)/os-qnx.Plo - -rm -f ./$(DEPDIR)/os-solaris.Plo - -rm -f aarch64/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f aarch64/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f aarch64/$(DEPDIR)/Gget_proc_info.Plo - -rm -f aarch64/$(DEPDIR)/Gget_save_loc.Plo - -rm -f aarch64/$(DEPDIR)/Gglobal.Plo - -rm -f aarch64/$(DEPDIR)/Ginit.Plo - -rm -f aarch64/$(DEPDIR)/Ginit_local.Plo - -rm -f aarch64/$(DEPDIR)/Ginit_remote.Plo - -rm -f aarch64/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f aarch64/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f aarch64/$(DEPDIR)/Gregs.Plo - -rm -f aarch64/$(DEPDIR)/Gresume.Plo - -rm -f aarch64/$(DEPDIR)/Gstash_frame.Plo - -rm -f aarch64/$(DEPDIR)/Gstep.Plo - -rm -f aarch64/$(DEPDIR)/Gtrace.Plo - -rm -f aarch64/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f aarch64/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f aarch64/$(DEPDIR)/Lget_proc_info.Plo - -rm -f aarch64/$(DEPDIR)/Lget_save_loc.Plo - -rm -f aarch64/$(DEPDIR)/Lglobal.Plo - -rm -f aarch64/$(DEPDIR)/Linit.Plo - -rm -f aarch64/$(DEPDIR)/Linit_local.Plo - -rm -f aarch64/$(DEPDIR)/Linit_remote.Plo - -rm -f aarch64/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f aarch64/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f aarch64/$(DEPDIR)/Lregs.Plo - -rm -f aarch64/$(DEPDIR)/Lresume.Plo - -rm -f aarch64/$(DEPDIR)/Lstash_frame.Plo - -rm -f aarch64/$(DEPDIR)/Lstep.Plo - -rm -f aarch64/$(DEPDIR)/Ltrace.Plo - -rm -f aarch64/$(DEPDIR)/getcontext.Plo - -rm -f aarch64/$(DEPDIR)/is_fpreg.Plo - -rm -f aarch64/$(DEPDIR)/regname.Plo - -rm -f aarch64/$(DEPDIR)/siglongjmp.Plo - -rm -f arm/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f arm/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f arm/$(DEPDIR)/Gex_tables.Plo - -rm -f arm/$(DEPDIR)/Gget_proc_info.Plo - -rm -f arm/$(DEPDIR)/Gget_save_loc.Plo - -rm -f arm/$(DEPDIR)/Gglobal.Plo - -rm -f arm/$(DEPDIR)/Ginit.Plo - -rm -f arm/$(DEPDIR)/Ginit_local.Plo - -rm -f arm/$(DEPDIR)/Ginit_remote.Plo - -rm -f arm/$(DEPDIR)/Gos-freebsd.Plo - -rm -f arm/$(DEPDIR)/Gos-linux.Plo - -rm -f arm/$(DEPDIR)/Gos-other.Plo - -rm -f arm/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f arm/$(DEPDIR)/Gregs.Plo - -rm -f arm/$(DEPDIR)/Gresume.Plo - -rm -f arm/$(DEPDIR)/Gstash_frame.Plo - -rm -f arm/$(DEPDIR)/Gstep.Plo - -rm -f arm/$(DEPDIR)/Gtrace.Plo - -rm -f arm/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f arm/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f arm/$(DEPDIR)/Lex_tables.Plo - -rm -f arm/$(DEPDIR)/Lget_proc_info.Plo - -rm -f arm/$(DEPDIR)/Lget_save_loc.Plo - -rm -f arm/$(DEPDIR)/Lglobal.Plo - -rm -f arm/$(DEPDIR)/Linit.Plo - -rm -f arm/$(DEPDIR)/Linit_local.Plo - -rm -f arm/$(DEPDIR)/Linit_remote.Plo - -rm -f arm/$(DEPDIR)/Los-freebsd.Plo - -rm -f arm/$(DEPDIR)/Los-linux.Plo - -rm -f arm/$(DEPDIR)/Los-other.Plo - -rm -f arm/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f arm/$(DEPDIR)/Lregs.Plo - -rm -f arm/$(DEPDIR)/Lresume.Plo - -rm -f arm/$(DEPDIR)/Lstash_frame.Plo - -rm -f arm/$(DEPDIR)/Lstep.Plo - -rm -f arm/$(DEPDIR)/Ltrace.Plo - -rm -f arm/$(DEPDIR)/getcontext.Plo - -rm -f arm/$(DEPDIR)/is_fpreg.Plo - -rm -f arm/$(DEPDIR)/regname.Plo - -rm -f arm/$(DEPDIR)/siglongjmp.Plo - -rm -f coredump/$(DEPDIR)/_UCD_access_mem.Plo - -rm -f coredump/$(DEPDIR)/_UCD_access_reg_freebsd.Plo - -rm -f coredump/$(DEPDIR)/_UCD_access_reg_linux.Plo - -rm -f coredump/$(DEPDIR)/_UCD_accessors.Plo - -rm -f coredump/$(DEPDIR)/_UCD_corefile_elf.Plo - -rm -f coredump/$(DEPDIR)/_UCD_create.Plo - -rm -f coredump/$(DEPDIR)/_UCD_destroy.Plo - -rm -f coredump/$(DEPDIR)/_UCD_elf_map_image.Plo - -rm -f coredump/$(DEPDIR)/_UCD_find_proc_info.Plo - -rm -f coredump/$(DEPDIR)/_UCD_get_mapinfo_generic.Plo - -rm -f coredump/$(DEPDIR)/_UCD_get_mapinfo_linux.Plo - -rm -f coredump/$(DEPDIR)/_UCD_get_proc_name.Plo - -rm -f coredump/$(DEPDIR)/_UCD_get_threadinfo_prstatus.Plo - -rm -f coredump/$(DEPDIR)/_UPT_access_fpreg.Plo - -rm -f coredump/$(DEPDIR)/_UPT_elf.Plo - -rm -f coredump/$(DEPDIR)/_UPT_get_dyn_info_list_addr.Plo - -rm -f coredump/$(DEPDIR)/_UPT_put_unwind_info.Plo - -rm -f coredump/$(DEPDIR)/_UPT_resume.Plo - -rm -f dwarf/$(DEPDIR)/Gexpr.Plo - -rm -f dwarf/$(DEPDIR)/Gfde.Plo - -rm -f dwarf/$(DEPDIR)/Gfind_proc_info-lsb.Plo - -rm -f dwarf/$(DEPDIR)/Gfind_unwind_table.Plo - -rm -f dwarf/$(DEPDIR)/Gparser.Plo - -rm -f dwarf/$(DEPDIR)/Gpe.Plo - -rm -f dwarf/$(DEPDIR)/Lexpr.Plo - -rm -f dwarf/$(DEPDIR)/Lfde.Plo - -rm -f dwarf/$(DEPDIR)/Lfind_proc_info-lsb.Plo - -rm -f dwarf/$(DEPDIR)/Lfind_unwind_table.Plo - -rm -f dwarf/$(DEPDIR)/Lparser.Plo - -rm -f dwarf/$(DEPDIR)/Lpe.Plo - -rm -f dwarf/$(DEPDIR)/global.Plo - -rm -f hppa/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f hppa/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f hppa/$(DEPDIR)/Gget_proc_info.Plo - -rm -f hppa/$(DEPDIR)/Gget_save_loc.Plo - -rm -f hppa/$(DEPDIR)/Gglobal.Plo - -rm -f hppa/$(DEPDIR)/Ginit.Plo - -rm -f hppa/$(DEPDIR)/Ginit_local.Plo - -rm -f hppa/$(DEPDIR)/Ginit_remote.Plo - -rm -f hppa/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f hppa/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f hppa/$(DEPDIR)/Gregs.Plo - -rm -f hppa/$(DEPDIR)/Gresume.Plo - -rm -f hppa/$(DEPDIR)/Gstep.Plo - -rm -f hppa/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f hppa/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f hppa/$(DEPDIR)/Lget_proc_info.Plo - -rm -f hppa/$(DEPDIR)/Lget_save_loc.Plo - -rm -f hppa/$(DEPDIR)/Lglobal.Plo - -rm -f hppa/$(DEPDIR)/Linit.Plo - -rm -f hppa/$(DEPDIR)/Linit_local.Plo - -rm -f hppa/$(DEPDIR)/Linit_remote.Plo - -rm -f hppa/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f hppa/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f hppa/$(DEPDIR)/Lregs.Plo - -rm -f hppa/$(DEPDIR)/Lresume.Plo - -rm -f hppa/$(DEPDIR)/Lstep.Plo - -rm -f hppa/$(DEPDIR)/getcontext.Plo - -rm -f hppa/$(DEPDIR)/regname.Plo - -rm -f hppa/$(DEPDIR)/setcontext.Plo - -rm -f hppa/$(DEPDIR)/siglongjmp.Plo - -rm -f ia64/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f ia64/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f ia64/$(DEPDIR)/Gfind_unwind_table.Plo - -rm -f ia64/$(DEPDIR)/Gget_proc_info.Plo - -rm -f ia64/$(DEPDIR)/Gget_save_loc.Plo - -rm -f ia64/$(DEPDIR)/Gglobal.Plo - -rm -f ia64/$(DEPDIR)/Ginit.Plo - -rm -f ia64/$(DEPDIR)/Ginit_local.Plo - -rm -f ia64/$(DEPDIR)/Ginit_remote.Plo - -rm -f ia64/$(DEPDIR)/Ginstall_cursor.Plo - -rm -f ia64/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f ia64/$(DEPDIR)/Gparser.Plo - -rm -f ia64/$(DEPDIR)/Grbs.Plo - -rm -f ia64/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f ia64/$(DEPDIR)/Gregs.Plo - -rm -f ia64/$(DEPDIR)/Gresume.Plo - -rm -f ia64/$(DEPDIR)/Gscript.Plo - -rm -f ia64/$(DEPDIR)/Gstep.Plo - -rm -f ia64/$(DEPDIR)/Gtables.Plo - -rm -f ia64/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f ia64/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f ia64/$(DEPDIR)/Lfind_unwind_table.Plo - -rm -f ia64/$(DEPDIR)/Lget_proc_info.Plo - -rm -f ia64/$(DEPDIR)/Lget_save_loc.Plo - -rm -f ia64/$(DEPDIR)/Lglobal.Plo - -rm -f ia64/$(DEPDIR)/Linit.Plo - -rm -f ia64/$(DEPDIR)/Linit_local.Plo - -rm -f ia64/$(DEPDIR)/Linit_remote.Plo - -rm -f ia64/$(DEPDIR)/Linstall_cursor.Plo - -rm -f ia64/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f ia64/$(DEPDIR)/Lparser.Plo - -rm -f ia64/$(DEPDIR)/Lrbs.Plo - -rm -f ia64/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f ia64/$(DEPDIR)/Lregs.Plo - -rm -f ia64/$(DEPDIR)/Lresume.Plo - -rm -f ia64/$(DEPDIR)/Lscript.Plo - -rm -f ia64/$(DEPDIR)/Lstep.Plo - -rm -f ia64/$(DEPDIR)/Ltables.Plo - -rm -f ia64/$(DEPDIR)/dyn_info_list.Plo - -rm -f ia64/$(DEPDIR)/getcontext.Plo - -rm -f ia64/$(DEPDIR)/longjmp.Plo - -rm -f ia64/$(DEPDIR)/regname.Plo - -rm -f ia64/$(DEPDIR)/setjmp.Plo - -rm -f ia64/$(DEPDIR)/siglongjmp.Plo - -rm -f ia64/$(DEPDIR)/sigsetjmp.Plo - -rm -f mi/$(DEPDIR)/Gdestroy_addr_space.Plo - -rm -f mi/$(DEPDIR)/Gdyn-extract.Plo - -rm -f mi/$(DEPDIR)/Gdyn-remote.Plo - -rm -f mi/$(DEPDIR)/Gfind_dynamic_proc_info.Plo - -rm -f mi/$(DEPDIR)/Gget_accessors.Plo - -rm -f mi/$(DEPDIR)/Gget_fpreg.Plo - -rm -f mi/$(DEPDIR)/Gget_proc_info_by_ip.Plo - -rm -f mi/$(DEPDIR)/Gget_proc_name.Plo - -rm -f mi/$(DEPDIR)/Gget_reg.Plo - -rm -f mi/$(DEPDIR)/Gput_dynamic_unwind_info.Plo - -rm -f mi/$(DEPDIR)/Gset_cache_size.Plo - -rm -f mi/$(DEPDIR)/Gset_caching_policy.Plo - -rm -f mi/$(DEPDIR)/Gset_fpreg.Plo - -rm -f mi/$(DEPDIR)/Gset_reg.Plo - -rm -f mi/$(DEPDIR)/Ldestroy_addr_space.Plo - -rm -f mi/$(DEPDIR)/Ldyn-extract.Plo - -rm -f mi/$(DEPDIR)/Lfind_dynamic_proc_info.Plo - -rm -f mi/$(DEPDIR)/Lget_accessors.Plo - -rm -f mi/$(DEPDIR)/Lget_fpreg.Plo - -rm -f mi/$(DEPDIR)/Lget_proc_info_by_ip.Plo - -rm -f mi/$(DEPDIR)/Lget_proc_name.Plo - -rm -f mi/$(DEPDIR)/Lget_reg.Plo - -rm -f mi/$(DEPDIR)/Lput_dynamic_unwind_info.Plo - -rm -f mi/$(DEPDIR)/Lset_cache_size.Plo - -rm -f mi/$(DEPDIR)/Lset_caching_policy.Plo - -rm -f mi/$(DEPDIR)/Lset_fpreg.Plo - -rm -f mi/$(DEPDIR)/Lset_reg.Plo - -rm -f mi/$(DEPDIR)/_ReadSLEB.Plo - -rm -f mi/$(DEPDIR)/_ReadULEB.Plo - -rm -f mi/$(DEPDIR)/backtrace.Plo - -rm -f mi/$(DEPDIR)/dyn-cancel.Plo - -rm -f mi/$(DEPDIR)/dyn-info-list.Plo - -rm -f mi/$(DEPDIR)/dyn-register.Plo - -rm -f mi/$(DEPDIR)/flush_cache.Plo - -rm -f mi/$(DEPDIR)/init.Plo - -rm -f mi/$(DEPDIR)/mempool.Plo - -rm -f mi/$(DEPDIR)/strerror.Plo - -rm -f mips/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f mips/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f mips/$(DEPDIR)/Gget_proc_info.Plo - -rm -f mips/$(DEPDIR)/Gget_save_loc.Plo - -rm -f mips/$(DEPDIR)/Gglobal.Plo - -rm -f mips/$(DEPDIR)/Ginit.Plo - -rm -f mips/$(DEPDIR)/Ginit_local.Plo - -rm -f mips/$(DEPDIR)/Ginit_remote.Plo - -rm -f mips/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f mips/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f mips/$(DEPDIR)/Gregs.Plo - -rm -f mips/$(DEPDIR)/Gresume.Plo - -rm -f mips/$(DEPDIR)/Gstep.Plo - -rm -f mips/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f mips/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f mips/$(DEPDIR)/Lget_proc_info.Plo - -rm -f mips/$(DEPDIR)/Lget_save_loc.Plo - -rm -f mips/$(DEPDIR)/Lglobal.Plo - -rm -f mips/$(DEPDIR)/Linit.Plo - -rm -f mips/$(DEPDIR)/Linit_local.Plo - -rm -f mips/$(DEPDIR)/Linit_remote.Plo - -rm -f mips/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f mips/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f mips/$(DEPDIR)/Lregs.Plo - -rm -f mips/$(DEPDIR)/Lresume.Plo - -rm -f mips/$(DEPDIR)/Lstep.Plo - -rm -f mips/$(DEPDIR)/getcontext.Plo - -rm -f mips/$(DEPDIR)/is_fpreg.Plo - -rm -f mips/$(DEPDIR)/regname.Plo - -rm -f mips/$(DEPDIR)/siglongjmp.Plo - -rm -f ppc/$(DEPDIR)/Gget_proc_info.Plo - -rm -f ppc/$(DEPDIR)/Gget_save_loc.Plo - -rm -f ppc/$(DEPDIR)/Ginit_local.Plo - -rm -f ppc/$(DEPDIR)/Ginit_remote.Plo - -rm -f ppc/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f ppc/$(DEPDIR)/Lget_proc_info.Plo - -rm -f ppc/$(DEPDIR)/Lget_save_loc.Plo - -rm -f ppc/$(DEPDIR)/Linit_local.Plo - -rm -f ppc/$(DEPDIR)/Linit_remote.Plo - -rm -f ppc/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f ppc/$(DEPDIR)/longjmp.Plo - -rm -f ppc/$(DEPDIR)/siglongjmp.Plo - -rm -f ppc32/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f ppc32/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f ppc32/$(DEPDIR)/Gglobal.Plo - -rm -f ppc32/$(DEPDIR)/Ginit.Plo - -rm -f ppc32/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f ppc32/$(DEPDIR)/Gregs.Plo - -rm -f ppc32/$(DEPDIR)/Gresume.Plo - -rm -f ppc32/$(DEPDIR)/Gstep.Plo - -rm -f ppc32/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f ppc32/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f ppc32/$(DEPDIR)/Lglobal.Plo - -rm -f ppc32/$(DEPDIR)/Linit.Plo - -rm -f ppc32/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f ppc32/$(DEPDIR)/Lregs.Plo - -rm -f ppc32/$(DEPDIR)/Lresume.Plo - -rm -f ppc32/$(DEPDIR)/Lstep.Plo - -rm -f ppc32/$(DEPDIR)/get_func_addr.Plo - -rm -f ppc32/$(DEPDIR)/is_fpreg.Plo - -rm -f ppc32/$(DEPDIR)/regname.Plo - -rm -f ppc64/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f ppc64/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f ppc64/$(DEPDIR)/Gglobal.Plo - -rm -f ppc64/$(DEPDIR)/Ginit.Plo - -rm -f ppc64/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f ppc64/$(DEPDIR)/Gregs.Plo - -rm -f ppc64/$(DEPDIR)/Gresume.Plo - -rm -f ppc64/$(DEPDIR)/Gstep.Plo - -rm -f ppc64/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f ppc64/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f ppc64/$(DEPDIR)/Lglobal.Plo - -rm -f ppc64/$(DEPDIR)/Linit.Plo - -rm -f ppc64/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f ppc64/$(DEPDIR)/Lregs.Plo - -rm -f ppc64/$(DEPDIR)/Lresume.Plo - -rm -f ppc64/$(DEPDIR)/Lstep.Plo - -rm -f ppc64/$(DEPDIR)/get_func_addr.Plo - -rm -f ppc64/$(DEPDIR)/is_fpreg.Plo - -rm -f ppc64/$(DEPDIR)/regname.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_access_fpreg.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_access_mem.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_access_reg.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_accessors.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_create.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_destroy.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_elf.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_find_proc_info.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_get_dyn_info_list_addr.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_get_proc_name.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_put_unwind_info.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_reg_offset.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_resume.Plo - -rm -f riscv/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f riscv/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f riscv/$(DEPDIR)/Gget_proc_info.Plo - -rm -f riscv/$(DEPDIR)/Gget_save_loc.Plo - -rm -f riscv/$(DEPDIR)/Gglobal.Plo - -rm -f riscv/$(DEPDIR)/Ginit.Plo - -rm -f riscv/$(DEPDIR)/Ginit_local.Plo - -rm -f riscv/$(DEPDIR)/Ginit_remote.Plo - -rm -f riscv/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f riscv/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f riscv/$(DEPDIR)/Gregs.Plo - -rm -f riscv/$(DEPDIR)/Gresume.Plo - -rm -f riscv/$(DEPDIR)/Gstep.Plo - -rm -f riscv/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f riscv/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f riscv/$(DEPDIR)/Lget_proc_info.Plo - -rm -f riscv/$(DEPDIR)/Lget_save_loc.Plo - -rm -f riscv/$(DEPDIR)/Lglobal.Plo - -rm -f riscv/$(DEPDIR)/Linit.Plo - -rm -f riscv/$(DEPDIR)/Linit_local.Plo - -rm -f riscv/$(DEPDIR)/Linit_remote.Plo - -rm -f riscv/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f riscv/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f riscv/$(DEPDIR)/Lregs.Plo - -rm -f riscv/$(DEPDIR)/Lresume.Plo - -rm -f riscv/$(DEPDIR)/Lstep.Plo - -rm -f riscv/$(DEPDIR)/getcontext.Plo - -rm -f riscv/$(DEPDIR)/is_fpreg.Plo - -rm -f riscv/$(DEPDIR)/regname.Plo - -rm -f riscv/$(DEPDIR)/setcontext.Plo - -rm -f riscv/$(DEPDIR)/siglongjmp.Plo - -rm -f s390x/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f s390x/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f s390x/$(DEPDIR)/Gget_proc_info.Plo - -rm -f s390x/$(DEPDIR)/Gget_save_loc.Plo - -rm -f s390x/$(DEPDIR)/Gglobal.Plo - -rm -f s390x/$(DEPDIR)/Ginit.Plo - -rm -f s390x/$(DEPDIR)/Ginit_local.Plo - -rm -f s390x/$(DEPDIR)/Ginit_remote.Plo - -rm -f s390x/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f s390x/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f s390x/$(DEPDIR)/Gregs.Plo - -rm -f s390x/$(DEPDIR)/Gresume.Plo - -rm -f s390x/$(DEPDIR)/Gstep.Plo - -rm -f s390x/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f s390x/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f s390x/$(DEPDIR)/Lget_proc_info.Plo - -rm -f s390x/$(DEPDIR)/Lget_save_loc.Plo - -rm -f s390x/$(DEPDIR)/Lglobal.Plo - -rm -f s390x/$(DEPDIR)/Linit.Plo - -rm -f s390x/$(DEPDIR)/Linit_local.Plo - -rm -f s390x/$(DEPDIR)/Linit_remote.Plo - -rm -f s390x/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f s390x/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f s390x/$(DEPDIR)/Lregs.Plo - -rm -f s390x/$(DEPDIR)/Lresume.Plo - -rm -f s390x/$(DEPDIR)/Lstep.Plo - -rm -f s390x/$(DEPDIR)/getcontext.Plo - -rm -f s390x/$(DEPDIR)/is_fpreg.Plo - -rm -f s390x/$(DEPDIR)/regname.Plo - -rm -f s390x/$(DEPDIR)/setcontext.Plo - -rm -f setjmp/$(DEPDIR)/longjmp.Plo - -rm -f setjmp/$(DEPDIR)/siglongjmp.Plo - -rm -f sh/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f sh/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f sh/$(DEPDIR)/Gget_proc_info.Plo - -rm -f sh/$(DEPDIR)/Gget_save_loc.Plo - -rm -f sh/$(DEPDIR)/Gglobal.Plo - -rm -f sh/$(DEPDIR)/Ginit.Plo - -rm -f sh/$(DEPDIR)/Ginit_local.Plo - -rm -f sh/$(DEPDIR)/Ginit_remote.Plo - -rm -f sh/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f sh/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f sh/$(DEPDIR)/Gregs.Plo - -rm -f sh/$(DEPDIR)/Gresume.Plo - -rm -f sh/$(DEPDIR)/Gstep.Plo - -rm -f sh/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f sh/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f sh/$(DEPDIR)/Lget_proc_info.Plo - -rm -f sh/$(DEPDIR)/Lget_save_loc.Plo - -rm -f sh/$(DEPDIR)/Lglobal.Plo - -rm -f sh/$(DEPDIR)/Linit.Plo - -rm -f sh/$(DEPDIR)/Linit_local.Plo - -rm -f sh/$(DEPDIR)/Linit_remote.Plo - -rm -f sh/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f sh/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f sh/$(DEPDIR)/Lregs.Plo - -rm -f sh/$(DEPDIR)/Lresume.Plo - -rm -f sh/$(DEPDIR)/Lstep.Plo - -rm -f sh/$(DEPDIR)/is_fpreg.Plo - -rm -f sh/$(DEPDIR)/regname.Plo - -rm -f sh/$(DEPDIR)/siglongjmp.Plo - -rm -f tilegx/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f tilegx/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f tilegx/$(DEPDIR)/Gget_proc_info.Plo - -rm -f tilegx/$(DEPDIR)/Gget_save_loc.Plo - -rm -f tilegx/$(DEPDIR)/Gglobal.Plo - -rm -f tilegx/$(DEPDIR)/Ginit.Plo - -rm -f tilegx/$(DEPDIR)/Ginit_local.Plo - -rm -f tilegx/$(DEPDIR)/Ginit_remote.Plo - -rm -f tilegx/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f tilegx/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f tilegx/$(DEPDIR)/Gregs.Plo - -rm -f tilegx/$(DEPDIR)/Gresume.Plo - -rm -f tilegx/$(DEPDIR)/Gstep.Plo - -rm -f tilegx/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f tilegx/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f tilegx/$(DEPDIR)/Lget_proc_info.Plo - -rm -f tilegx/$(DEPDIR)/Lget_save_loc.Plo - -rm -f tilegx/$(DEPDIR)/Lglobal.Plo - -rm -f tilegx/$(DEPDIR)/Linit.Plo - -rm -f tilegx/$(DEPDIR)/Linit_local.Plo - -rm -f tilegx/$(DEPDIR)/Linit_remote.Plo - -rm -f tilegx/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f tilegx/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f tilegx/$(DEPDIR)/Lregs.Plo - -rm -f tilegx/$(DEPDIR)/Lresume.Plo - -rm -f tilegx/$(DEPDIR)/Lstep.Plo - -rm -f tilegx/$(DEPDIR)/getcontext.Plo - -rm -f tilegx/$(DEPDIR)/is_fpreg.Plo - -rm -f tilegx/$(DEPDIR)/regname.Plo - -rm -f tilegx/$(DEPDIR)/siglongjmp.Plo - -rm -f unwind/$(DEPDIR)/Backtrace.Plo - -rm -f unwind/$(DEPDIR)/DeleteException.Plo - -rm -f unwind/$(DEPDIR)/FindEnclosingFunction.Plo - -rm -f unwind/$(DEPDIR)/ForcedUnwind.Plo - -rm -f unwind/$(DEPDIR)/GetBSP.Plo - -rm -f unwind/$(DEPDIR)/GetCFA.Plo - -rm -f unwind/$(DEPDIR)/GetDataRelBase.Plo - -rm -f unwind/$(DEPDIR)/GetGR.Plo - -rm -f unwind/$(DEPDIR)/GetIP.Plo - -rm -f unwind/$(DEPDIR)/GetIPInfo.Plo - -rm -f unwind/$(DEPDIR)/GetLanguageSpecificData.Plo - -rm -f unwind/$(DEPDIR)/GetRegionStart.Plo - -rm -f unwind/$(DEPDIR)/GetTextRelBase.Plo - -rm -f unwind/$(DEPDIR)/RaiseException.Plo - -rm -f unwind/$(DEPDIR)/Resume.Plo - -rm -f unwind/$(DEPDIR)/Resume_or_Rethrow.Plo - -rm -f unwind/$(DEPDIR)/SetGR.Plo - -rm -f unwind/$(DEPDIR)/SetIP.Plo - -rm -f x86/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f x86/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f x86/$(DEPDIR)/Gget_proc_info.Plo - -rm -f x86/$(DEPDIR)/Gget_save_loc.Plo - -rm -f x86/$(DEPDIR)/Gglobal.Plo - -rm -f x86/$(DEPDIR)/Ginit.Plo - -rm -f x86/$(DEPDIR)/Ginit_local.Plo - -rm -f x86/$(DEPDIR)/Ginit_remote.Plo - -rm -f x86/$(DEPDIR)/Gos-freebsd.Plo - -rm -f x86/$(DEPDIR)/Gos-linux.Plo - -rm -f x86/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f x86/$(DEPDIR)/Gregs.Plo - -rm -f x86/$(DEPDIR)/Gresume.Plo - -rm -f x86/$(DEPDIR)/Gstep.Plo - -rm -f x86/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f x86/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f x86/$(DEPDIR)/Lget_proc_info.Plo - -rm -f x86/$(DEPDIR)/Lget_save_loc.Plo - -rm -f x86/$(DEPDIR)/Lglobal.Plo - -rm -f x86/$(DEPDIR)/Linit.Plo - -rm -f x86/$(DEPDIR)/Linit_local.Plo - -rm -f x86/$(DEPDIR)/Linit_remote.Plo - -rm -f x86/$(DEPDIR)/Los-freebsd.Plo - -rm -f x86/$(DEPDIR)/Los-linux.Plo - -rm -f x86/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f x86/$(DEPDIR)/Lregs.Plo - -rm -f x86/$(DEPDIR)/Lresume.Plo - -rm -f x86/$(DEPDIR)/Lstep.Plo - -rm -f x86/$(DEPDIR)/getcontext-freebsd.Plo - -rm -f x86/$(DEPDIR)/getcontext-linux.Plo - -rm -f x86/$(DEPDIR)/is_fpreg.Plo - -rm -f x86/$(DEPDIR)/longjmp.Plo - -rm -f x86/$(DEPDIR)/regname.Plo - -rm -f x86/$(DEPDIR)/siglongjmp.Plo - -rm -f x86_64/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f x86_64/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f x86_64/$(DEPDIR)/Gget_proc_info.Plo - -rm -f x86_64/$(DEPDIR)/Gget_save_loc.Plo - -rm -f x86_64/$(DEPDIR)/Gglobal.Plo - -rm -f x86_64/$(DEPDIR)/Ginit.Plo - -rm -f x86_64/$(DEPDIR)/Ginit_local.Plo - -rm -f x86_64/$(DEPDIR)/Ginit_remote.Plo - -rm -f x86_64/$(DEPDIR)/Gos-freebsd.Plo - -rm -f x86_64/$(DEPDIR)/Gos-linux.Plo - -rm -f x86_64/$(DEPDIR)/Gos-solaris.Plo - -rm -f x86_64/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f x86_64/$(DEPDIR)/Gregs.Plo - -rm -f x86_64/$(DEPDIR)/Gresume.Plo - -rm -f x86_64/$(DEPDIR)/Gstash_frame.Plo - -rm -f x86_64/$(DEPDIR)/Gstep.Plo - -rm -f x86_64/$(DEPDIR)/Gtrace.Plo - -rm -f x86_64/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f x86_64/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f x86_64/$(DEPDIR)/Lget_proc_info.Plo - -rm -f x86_64/$(DEPDIR)/Lget_save_loc.Plo - -rm -f x86_64/$(DEPDIR)/Lglobal.Plo - -rm -f x86_64/$(DEPDIR)/Linit.Plo - -rm -f x86_64/$(DEPDIR)/Linit_local.Plo - -rm -f x86_64/$(DEPDIR)/Linit_remote.Plo - -rm -f x86_64/$(DEPDIR)/Los-freebsd.Plo - -rm -f x86_64/$(DEPDIR)/Los-linux.Plo - -rm -f x86_64/$(DEPDIR)/Los-solaris.Plo - -rm -f x86_64/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f x86_64/$(DEPDIR)/Lregs.Plo - -rm -f x86_64/$(DEPDIR)/Lresume.Plo - -rm -f x86_64/$(DEPDIR)/Lstash_frame.Plo - -rm -f x86_64/$(DEPDIR)/Lstep.Plo - -rm -f x86_64/$(DEPDIR)/Ltrace.Plo - -rm -f x86_64/$(DEPDIR)/getcontext.Plo - -rm -f x86_64/$(DEPDIR)/is_fpreg.Plo - -rm -f x86_64/$(DEPDIR)/longjmp.Plo - -rm -f x86_64/$(DEPDIR)/regname.Plo - -rm -f x86_64/$(DEPDIR)/setcontext.Plo - -rm -f x86_64/$(DEPDIR)/siglongjmp.Plo + -rm -rf ./$(DEPDIR) aarch64/$(DEPDIR) arm/$(DEPDIR) coredump/$(DEPDIR) dwarf/$(DEPDIR) hppa/$(DEPDIR) ia64/$(DEPDIR) loongarch64/$(DEPDIR) mi/$(DEPDIR) mips/$(DEPDIR) ppc/$(DEPDIR) ppc32/$(DEPDIR) ppc64/$(DEPDIR) ptrace/$(DEPDIR) riscv/$(DEPDIR) s390x/$(DEPDIR) setjmp/$(DEPDIR) sh/$(DEPDIR) tilegx/$(DEPDIR) unwind/$(DEPDIR) x86/$(DEPDIR) x86_64/$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags @@ -4893,7 +4166,7 @@ install-dvi-am: -install-exec-am: install-libLIBRARIES install-libLTLIBRARIES +install-exec-am: install-libLTLIBRARIES @$(NORMAL_INSTALL) $(MAKE) $(AM_MAKEFLAGS) install-exec-hook install-html: install-html-am @@ -4917,539 +4190,7 @@ installcheck-am: maintainer-clean: maintainer-clean-am - -rm -f ./$(DEPDIR)/dl-iterate-phdr.Plo - -rm -f ./$(DEPDIR)/elf32.Plo - -rm -f ./$(DEPDIR)/elf64.Plo - -rm -f ./$(DEPDIR)/elfxx.Plo - -rm -f ./$(DEPDIR)/os-freebsd.Plo - -rm -f ./$(DEPDIR)/os-hpux.Plo - -rm -f ./$(DEPDIR)/os-linux.Plo - -rm -f ./$(DEPDIR)/os-qnx.Plo - -rm -f ./$(DEPDIR)/os-solaris.Plo - -rm -f aarch64/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f aarch64/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f aarch64/$(DEPDIR)/Gget_proc_info.Plo - -rm -f aarch64/$(DEPDIR)/Gget_save_loc.Plo - -rm -f aarch64/$(DEPDIR)/Gglobal.Plo - -rm -f aarch64/$(DEPDIR)/Ginit.Plo - -rm -f aarch64/$(DEPDIR)/Ginit_local.Plo - -rm -f aarch64/$(DEPDIR)/Ginit_remote.Plo - -rm -f aarch64/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f aarch64/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f aarch64/$(DEPDIR)/Gregs.Plo - -rm -f aarch64/$(DEPDIR)/Gresume.Plo - -rm -f aarch64/$(DEPDIR)/Gstash_frame.Plo - -rm -f aarch64/$(DEPDIR)/Gstep.Plo - -rm -f aarch64/$(DEPDIR)/Gtrace.Plo - -rm -f aarch64/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f aarch64/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f aarch64/$(DEPDIR)/Lget_proc_info.Plo - -rm -f aarch64/$(DEPDIR)/Lget_save_loc.Plo - -rm -f aarch64/$(DEPDIR)/Lglobal.Plo - -rm -f aarch64/$(DEPDIR)/Linit.Plo - -rm -f aarch64/$(DEPDIR)/Linit_local.Plo - -rm -f aarch64/$(DEPDIR)/Linit_remote.Plo - -rm -f aarch64/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f aarch64/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f aarch64/$(DEPDIR)/Lregs.Plo - -rm -f aarch64/$(DEPDIR)/Lresume.Plo - -rm -f aarch64/$(DEPDIR)/Lstash_frame.Plo - -rm -f aarch64/$(DEPDIR)/Lstep.Plo - -rm -f aarch64/$(DEPDIR)/Ltrace.Plo - -rm -f aarch64/$(DEPDIR)/getcontext.Plo - -rm -f aarch64/$(DEPDIR)/is_fpreg.Plo - -rm -f aarch64/$(DEPDIR)/regname.Plo - -rm -f aarch64/$(DEPDIR)/siglongjmp.Plo - -rm -f arm/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f arm/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f arm/$(DEPDIR)/Gex_tables.Plo - -rm -f arm/$(DEPDIR)/Gget_proc_info.Plo - -rm -f arm/$(DEPDIR)/Gget_save_loc.Plo - -rm -f arm/$(DEPDIR)/Gglobal.Plo - -rm -f arm/$(DEPDIR)/Ginit.Plo - -rm -f arm/$(DEPDIR)/Ginit_local.Plo - -rm -f arm/$(DEPDIR)/Ginit_remote.Plo - -rm -f arm/$(DEPDIR)/Gos-freebsd.Plo - -rm -f arm/$(DEPDIR)/Gos-linux.Plo - -rm -f arm/$(DEPDIR)/Gos-other.Plo - -rm -f arm/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f arm/$(DEPDIR)/Gregs.Plo - -rm -f arm/$(DEPDIR)/Gresume.Plo - -rm -f arm/$(DEPDIR)/Gstash_frame.Plo - -rm -f arm/$(DEPDIR)/Gstep.Plo - -rm -f arm/$(DEPDIR)/Gtrace.Plo - -rm -f arm/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f arm/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f arm/$(DEPDIR)/Lex_tables.Plo - -rm -f arm/$(DEPDIR)/Lget_proc_info.Plo - -rm -f arm/$(DEPDIR)/Lget_save_loc.Plo - -rm -f arm/$(DEPDIR)/Lglobal.Plo - -rm -f arm/$(DEPDIR)/Linit.Plo - -rm -f arm/$(DEPDIR)/Linit_local.Plo - -rm -f arm/$(DEPDIR)/Linit_remote.Plo - -rm -f arm/$(DEPDIR)/Los-freebsd.Plo - -rm -f arm/$(DEPDIR)/Los-linux.Plo - -rm -f arm/$(DEPDIR)/Los-other.Plo - -rm -f arm/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f arm/$(DEPDIR)/Lregs.Plo - -rm -f arm/$(DEPDIR)/Lresume.Plo - -rm -f arm/$(DEPDIR)/Lstash_frame.Plo - -rm -f arm/$(DEPDIR)/Lstep.Plo - -rm -f arm/$(DEPDIR)/Ltrace.Plo - -rm -f arm/$(DEPDIR)/getcontext.Plo - -rm -f arm/$(DEPDIR)/is_fpreg.Plo - -rm -f arm/$(DEPDIR)/regname.Plo - -rm -f arm/$(DEPDIR)/siglongjmp.Plo - -rm -f coredump/$(DEPDIR)/_UCD_access_mem.Plo - -rm -f coredump/$(DEPDIR)/_UCD_access_reg_freebsd.Plo - -rm -f coredump/$(DEPDIR)/_UCD_access_reg_linux.Plo - -rm -f coredump/$(DEPDIR)/_UCD_accessors.Plo - -rm -f coredump/$(DEPDIR)/_UCD_corefile_elf.Plo - -rm -f coredump/$(DEPDIR)/_UCD_create.Plo - -rm -f coredump/$(DEPDIR)/_UCD_destroy.Plo - -rm -f coredump/$(DEPDIR)/_UCD_elf_map_image.Plo - -rm -f coredump/$(DEPDIR)/_UCD_find_proc_info.Plo - -rm -f coredump/$(DEPDIR)/_UCD_get_mapinfo_generic.Plo - -rm -f coredump/$(DEPDIR)/_UCD_get_mapinfo_linux.Plo - -rm -f coredump/$(DEPDIR)/_UCD_get_proc_name.Plo - -rm -f coredump/$(DEPDIR)/_UCD_get_threadinfo_prstatus.Plo - -rm -f coredump/$(DEPDIR)/_UPT_access_fpreg.Plo - -rm -f coredump/$(DEPDIR)/_UPT_elf.Plo - -rm -f coredump/$(DEPDIR)/_UPT_get_dyn_info_list_addr.Plo - -rm -f coredump/$(DEPDIR)/_UPT_put_unwind_info.Plo - -rm -f coredump/$(DEPDIR)/_UPT_resume.Plo - -rm -f dwarf/$(DEPDIR)/Gexpr.Plo - -rm -f dwarf/$(DEPDIR)/Gfde.Plo - -rm -f dwarf/$(DEPDIR)/Gfind_proc_info-lsb.Plo - -rm -f dwarf/$(DEPDIR)/Gfind_unwind_table.Plo - -rm -f dwarf/$(DEPDIR)/Gparser.Plo - -rm -f dwarf/$(DEPDIR)/Gpe.Plo - -rm -f dwarf/$(DEPDIR)/Lexpr.Plo - -rm -f dwarf/$(DEPDIR)/Lfde.Plo - -rm -f dwarf/$(DEPDIR)/Lfind_proc_info-lsb.Plo - -rm -f dwarf/$(DEPDIR)/Lfind_unwind_table.Plo - -rm -f dwarf/$(DEPDIR)/Lparser.Plo - -rm -f dwarf/$(DEPDIR)/Lpe.Plo - -rm -f dwarf/$(DEPDIR)/global.Plo - -rm -f hppa/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f hppa/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f hppa/$(DEPDIR)/Gget_proc_info.Plo - -rm -f hppa/$(DEPDIR)/Gget_save_loc.Plo - -rm -f hppa/$(DEPDIR)/Gglobal.Plo - -rm -f hppa/$(DEPDIR)/Ginit.Plo - -rm -f hppa/$(DEPDIR)/Ginit_local.Plo - -rm -f hppa/$(DEPDIR)/Ginit_remote.Plo - -rm -f hppa/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f hppa/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f hppa/$(DEPDIR)/Gregs.Plo - -rm -f hppa/$(DEPDIR)/Gresume.Plo - -rm -f hppa/$(DEPDIR)/Gstep.Plo - -rm -f hppa/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f hppa/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f hppa/$(DEPDIR)/Lget_proc_info.Plo - -rm -f hppa/$(DEPDIR)/Lget_save_loc.Plo - -rm -f hppa/$(DEPDIR)/Lglobal.Plo - -rm -f hppa/$(DEPDIR)/Linit.Plo - -rm -f hppa/$(DEPDIR)/Linit_local.Plo - -rm -f hppa/$(DEPDIR)/Linit_remote.Plo - -rm -f hppa/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f hppa/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f hppa/$(DEPDIR)/Lregs.Plo - -rm -f hppa/$(DEPDIR)/Lresume.Plo - -rm -f hppa/$(DEPDIR)/Lstep.Plo - -rm -f hppa/$(DEPDIR)/getcontext.Plo - -rm -f hppa/$(DEPDIR)/regname.Plo - -rm -f hppa/$(DEPDIR)/setcontext.Plo - -rm -f hppa/$(DEPDIR)/siglongjmp.Plo - -rm -f ia64/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f ia64/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f ia64/$(DEPDIR)/Gfind_unwind_table.Plo - -rm -f ia64/$(DEPDIR)/Gget_proc_info.Plo - -rm -f ia64/$(DEPDIR)/Gget_save_loc.Plo - -rm -f ia64/$(DEPDIR)/Gglobal.Plo - -rm -f ia64/$(DEPDIR)/Ginit.Plo - -rm -f ia64/$(DEPDIR)/Ginit_local.Plo - -rm -f ia64/$(DEPDIR)/Ginit_remote.Plo - -rm -f ia64/$(DEPDIR)/Ginstall_cursor.Plo - -rm -f ia64/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f ia64/$(DEPDIR)/Gparser.Plo - -rm -f ia64/$(DEPDIR)/Grbs.Plo - -rm -f ia64/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f ia64/$(DEPDIR)/Gregs.Plo - -rm -f ia64/$(DEPDIR)/Gresume.Plo - -rm -f ia64/$(DEPDIR)/Gscript.Plo - -rm -f ia64/$(DEPDIR)/Gstep.Plo - -rm -f ia64/$(DEPDIR)/Gtables.Plo - -rm -f ia64/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f ia64/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f ia64/$(DEPDIR)/Lfind_unwind_table.Plo - -rm -f ia64/$(DEPDIR)/Lget_proc_info.Plo - -rm -f ia64/$(DEPDIR)/Lget_save_loc.Plo - -rm -f ia64/$(DEPDIR)/Lglobal.Plo - -rm -f ia64/$(DEPDIR)/Linit.Plo - -rm -f ia64/$(DEPDIR)/Linit_local.Plo - -rm -f ia64/$(DEPDIR)/Linit_remote.Plo - -rm -f ia64/$(DEPDIR)/Linstall_cursor.Plo - -rm -f ia64/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f ia64/$(DEPDIR)/Lparser.Plo - -rm -f ia64/$(DEPDIR)/Lrbs.Plo - -rm -f ia64/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f ia64/$(DEPDIR)/Lregs.Plo - -rm -f ia64/$(DEPDIR)/Lresume.Plo - -rm -f ia64/$(DEPDIR)/Lscript.Plo - -rm -f ia64/$(DEPDIR)/Lstep.Plo - -rm -f ia64/$(DEPDIR)/Ltables.Plo - -rm -f ia64/$(DEPDIR)/dyn_info_list.Plo - -rm -f ia64/$(DEPDIR)/getcontext.Plo - -rm -f ia64/$(DEPDIR)/longjmp.Plo - -rm -f ia64/$(DEPDIR)/regname.Plo - -rm -f ia64/$(DEPDIR)/setjmp.Plo - -rm -f ia64/$(DEPDIR)/siglongjmp.Plo - -rm -f ia64/$(DEPDIR)/sigsetjmp.Plo - -rm -f mi/$(DEPDIR)/Gdestroy_addr_space.Plo - -rm -f mi/$(DEPDIR)/Gdyn-extract.Plo - -rm -f mi/$(DEPDIR)/Gdyn-remote.Plo - -rm -f mi/$(DEPDIR)/Gfind_dynamic_proc_info.Plo - -rm -f mi/$(DEPDIR)/Gget_accessors.Plo - -rm -f mi/$(DEPDIR)/Gget_fpreg.Plo - -rm -f mi/$(DEPDIR)/Gget_proc_info_by_ip.Plo - -rm -f mi/$(DEPDIR)/Gget_proc_name.Plo - -rm -f mi/$(DEPDIR)/Gget_reg.Plo - -rm -f mi/$(DEPDIR)/Gput_dynamic_unwind_info.Plo - -rm -f mi/$(DEPDIR)/Gset_cache_size.Plo - -rm -f mi/$(DEPDIR)/Gset_caching_policy.Plo - -rm -f mi/$(DEPDIR)/Gset_fpreg.Plo - -rm -f mi/$(DEPDIR)/Gset_reg.Plo - -rm -f mi/$(DEPDIR)/Ldestroy_addr_space.Plo - -rm -f mi/$(DEPDIR)/Ldyn-extract.Plo - -rm -f mi/$(DEPDIR)/Lfind_dynamic_proc_info.Plo - -rm -f mi/$(DEPDIR)/Lget_accessors.Plo - -rm -f mi/$(DEPDIR)/Lget_fpreg.Plo - -rm -f mi/$(DEPDIR)/Lget_proc_info_by_ip.Plo - -rm -f mi/$(DEPDIR)/Lget_proc_name.Plo - -rm -f mi/$(DEPDIR)/Lget_reg.Plo - -rm -f mi/$(DEPDIR)/Lput_dynamic_unwind_info.Plo - -rm -f mi/$(DEPDIR)/Lset_cache_size.Plo - -rm -f mi/$(DEPDIR)/Lset_caching_policy.Plo - -rm -f mi/$(DEPDIR)/Lset_fpreg.Plo - -rm -f mi/$(DEPDIR)/Lset_reg.Plo - -rm -f mi/$(DEPDIR)/_ReadSLEB.Plo - -rm -f mi/$(DEPDIR)/_ReadULEB.Plo - -rm -f mi/$(DEPDIR)/backtrace.Plo - -rm -f mi/$(DEPDIR)/dyn-cancel.Plo - -rm -f mi/$(DEPDIR)/dyn-info-list.Plo - -rm -f mi/$(DEPDIR)/dyn-register.Plo - -rm -f mi/$(DEPDIR)/flush_cache.Plo - -rm -f mi/$(DEPDIR)/init.Plo - -rm -f mi/$(DEPDIR)/mempool.Plo - -rm -f mi/$(DEPDIR)/strerror.Plo - -rm -f mips/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f mips/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f mips/$(DEPDIR)/Gget_proc_info.Plo - -rm -f mips/$(DEPDIR)/Gget_save_loc.Plo - -rm -f mips/$(DEPDIR)/Gglobal.Plo - -rm -f mips/$(DEPDIR)/Ginit.Plo - -rm -f mips/$(DEPDIR)/Ginit_local.Plo - -rm -f mips/$(DEPDIR)/Ginit_remote.Plo - -rm -f mips/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f mips/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f mips/$(DEPDIR)/Gregs.Plo - -rm -f mips/$(DEPDIR)/Gresume.Plo - -rm -f mips/$(DEPDIR)/Gstep.Plo - -rm -f mips/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f mips/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f mips/$(DEPDIR)/Lget_proc_info.Plo - -rm -f mips/$(DEPDIR)/Lget_save_loc.Plo - -rm -f mips/$(DEPDIR)/Lglobal.Plo - -rm -f mips/$(DEPDIR)/Linit.Plo - -rm -f mips/$(DEPDIR)/Linit_local.Plo - -rm -f mips/$(DEPDIR)/Linit_remote.Plo - -rm -f mips/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f mips/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f mips/$(DEPDIR)/Lregs.Plo - -rm -f mips/$(DEPDIR)/Lresume.Plo - -rm -f mips/$(DEPDIR)/Lstep.Plo - -rm -f mips/$(DEPDIR)/getcontext.Plo - -rm -f mips/$(DEPDIR)/is_fpreg.Plo - -rm -f mips/$(DEPDIR)/regname.Plo - -rm -f mips/$(DEPDIR)/siglongjmp.Plo - -rm -f ppc/$(DEPDIR)/Gget_proc_info.Plo - -rm -f ppc/$(DEPDIR)/Gget_save_loc.Plo - -rm -f ppc/$(DEPDIR)/Ginit_local.Plo - -rm -f ppc/$(DEPDIR)/Ginit_remote.Plo - -rm -f ppc/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f ppc/$(DEPDIR)/Lget_proc_info.Plo - -rm -f ppc/$(DEPDIR)/Lget_save_loc.Plo - -rm -f ppc/$(DEPDIR)/Linit_local.Plo - -rm -f ppc/$(DEPDIR)/Linit_remote.Plo - -rm -f ppc/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f ppc/$(DEPDIR)/longjmp.Plo - -rm -f ppc/$(DEPDIR)/siglongjmp.Plo - -rm -f ppc32/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f ppc32/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f ppc32/$(DEPDIR)/Gglobal.Plo - -rm -f ppc32/$(DEPDIR)/Ginit.Plo - -rm -f ppc32/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f ppc32/$(DEPDIR)/Gregs.Plo - -rm -f ppc32/$(DEPDIR)/Gresume.Plo - -rm -f ppc32/$(DEPDIR)/Gstep.Plo - -rm -f ppc32/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f ppc32/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f ppc32/$(DEPDIR)/Lglobal.Plo - -rm -f ppc32/$(DEPDIR)/Linit.Plo - -rm -f ppc32/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f ppc32/$(DEPDIR)/Lregs.Plo - -rm -f ppc32/$(DEPDIR)/Lresume.Plo - -rm -f ppc32/$(DEPDIR)/Lstep.Plo - -rm -f ppc32/$(DEPDIR)/get_func_addr.Plo - -rm -f ppc32/$(DEPDIR)/is_fpreg.Plo - -rm -f ppc32/$(DEPDIR)/regname.Plo - -rm -f ppc64/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f ppc64/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f ppc64/$(DEPDIR)/Gglobal.Plo - -rm -f ppc64/$(DEPDIR)/Ginit.Plo - -rm -f ppc64/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f ppc64/$(DEPDIR)/Gregs.Plo - -rm -f ppc64/$(DEPDIR)/Gresume.Plo - -rm -f ppc64/$(DEPDIR)/Gstep.Plo - -rm -f ppc64/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f ppc64/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f ppc64/$(DEPDIR)/Lglobal.Plo - -rm -f ppc64/$(DEPDIR)/Linit.Plo - -rm -f ppc64/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f ppc64/$(DEPDIR)/Lregs.Plo - -rm -f ppc64/$(DEPDIR)/Lresume.Plo - -rm -f ppc64/$(DEPDIR)/Lstep.Plo - -rm -f ppc64/$(DEPDIR)/get_func_addr.Plo - -rm -f ppc64/$(DEPDIR)/is_fpreg.Plo - -rm -f ppc64/$(DEPDIR)/regname.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_access_fpreg.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_access_mem.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_access_reg.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_accessors.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_create.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_destroy.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_elf.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_find_proc_info.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_get_dyn_info_list_addr.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_get_proc_name.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_put_unwind_info.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_reg_offset.Plo - -rm -f ptrace/$(DEPDIR)/_UPT_resume.Plo - -rm -f riscv/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f riscv/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f riscv/$(DEPDIR)/Gget_proc_info.Plo - -rm -f riscv/$(DEPDIR)/Gget_save_loc.Plo - -rm -f riscv/$(DEPDIR)/Gglobal.Plo - -rm -f riscv/$(DEPDIR)/Ginit.Plo - -rm -f riscv/$(DEPDIR)/Ginit_local.Plo - -rm -f riscv/$(DEPDIR)/Ginit_remote.Plo - -rm -f riscv/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f riscv/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f riscv/$(DEPDIR)/Gregs.Plo - -rm -f riscv/$(DEPDIR)/Gresume.Plo - -rm -f riscv/$(DEPDIR)/Gstep.Plo - -rm -f riscv/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f riscv/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f riscv/$(DEPDIR)/Lget_proc_info.Plo - -rm -f riscv/$(DEPDIR)/Lget_save_loc.Plo - -rm -f riscv/$(DEPDIR)/Lglobal.Plo - -rm -f riscv/$(DEPDIR)/Linit.Plo - -rm -f riscv/$(DEPDIR)/Linit_local.Plo - -rm -f riscv/$(DEPDIR)/Linit_remote.Plo - -rm -f riscv/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f riscv/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f riscv/$(DEPDIR)/Lregs.Plo - -rm -f riscv/$(DEPDIR)/Lresume.Plo - -rm -f riscv/$(DEPDIR)/Lstep.Plo - -rm -f riscv/$(DEPDIR)/getcontext.Plo - -rm -f riscv/$(DEPDIR)/is_fpreg.Plo - -rm -f riscv/$(DEPDIR)/regname.Plo - -rm -f riscv/$(DEPDIR)/setcontext.Plo - -rm -f riscv/$(DEPDIR)/siglongjmp.Plo - -rm -f s390x/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f s390x/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f s390x/$(DEPDIR)/Gget_proc_info.Plo - -rm -f s390x/$(DEPDIR)/Gget_save_loc.Plo - -rm -f s390x/$(DEPDIR)/Gglobal.Plo - -rm -f s390x/$(DEPDIR)/Ginit.Plo - -rm -f s390x/$(DEPDIR)/Ginit_local.Plo - -rm -f s390x/$(DEPDIR)/Ginit_remote.Plo - -rm -f s390x/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f s390x/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f s390x/$(DEPDIR)/Gregs.Plo - -rm -f s390x/$(DEPDIR)/Gresume.Plo - -rm -f s390x/$(DEPDIR)/Gstep.Plo - -rm -f s390x/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f s390x/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f s390x/$(DEPDIR)/Lget_proc_info.Plo - -rm -f s390x/$(DEPDIR)/Lget_save_loc.Plo - -rm -f s390x/$(DEPDIR)/Lglobal.Plo - -rm -f s390x/$(DEPDIR)/Linit.Plo - -rm -f s390x/$(DEPDIR)/Linit_local.Plo - -rm -f s390x/$(DEPDIR)/Linit_remote.Plo - -rm -f s390x/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f s390x/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f s390x/$(DEPDIR)/Lregs.Plo - -rm -f s390x/$(DEPDIR)/Lresume.Plo - -rm -f s390x/$(DEPDIR)/Lstep.Plo - -rm -f s390x/$(DEPDIR)/getcontext.Plo - -rm -f s390x/$(DEPDIR)/is_fpreg.Plo - -rm -f s390x/$(DEPDIR)/regname.Plo - -rm -f s390x/$(DEPDIR)/setcontext.Plo - -rm -f setjmp/$(DEPDIR)/longjmp.Plo - -rm -f setjmp/$(DEPDIR)/siglongjmp.Plo - -rm -f sh/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f sh/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f sh/$(DEPDIR)/Gget_proc_info.Plo - -rm -f sh/$(DEPDIR)/Gget_save_loc.Plo - -rm -f sh/$(DEPDIR)/Gglobal.Plo - -rm -f sh/$(DEPDIR)/Ginit.Plo - -rm -f sh/$(DEPDIR)/Ginit_local.Plo - -rm -f sh/$(DEPDIR)/Ginit_remote.Plo - -rm -f sh/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f sh/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f sh/$(DEPDIR)/Gregs.Plo - -rm -f sh/$(DEPDIR)/Gresume.Plo - -rm -f sh/$(DEPDIR)/Gstep.Plo - -rm -f sh/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f sh/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f sh/$(DEPDIR)/Lget_proc_info.Plo - -rm -f sh/$(DEPDIR)/Lget_save_loc.Plo - -rm -f sh/$(DEPDIR)/Lglobal.Plo - -rm -f sh/$(DEPDIR)/Linit.Plo - -rm -f sh/$(DEPDIR)/Linit_local.Plo - -rm -f sh/$(DEPDIR)/Linit_remote.Plo - -rm -f sh/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f sh/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f sh/$(DEPDIR)/Lregs.Plo - -rm -f sh/$(DEPDIR)/Lresume.Plo - -rm -f sh/$(DEPDIR)/Lstep.Plo - -rm -f sh/$(DEPDIR)/is_fpreg.Plo - -rm -f sh/$(DEPDIR)/regname.Plo - -rm -f sh/$(DEPDIR)/siglongjmp.Plo - -rm -f tilegx/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f tilegx/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f tilegx/$(DEPDIR)/Gget_proc_info.Plo - -rm -f tilegx/$(DEPDIR)/Gget_save_loc.Plo - -rm -f tilegx/$(DEPDIR)/Gglobal.Plo - -rm -f tilegx/$(DEPDIR)/Ginit.Plo - -rm -f tilegx/$(DEPDIR)/Ginit_local.Plo - -rm -f tilegx/$(DEPDIR)/Ginit_remote.Plo - -rm -f tilegx/$(DEPDIR)/Gis_signal_frame.Plo - -rm -f tilegx/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f tilegx/$(DEPDIR)/Gregs.Plo - -rm -f tilegx/$(DEPDIR)/Gresume.Plo - -rm -f tilegx/$(DEPDIR)/Gstep.Plo - -rm -f tilegx/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f tilegx/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f tilegx/$(DEPDIR)/Lget_proc_info.Plo - -rm -f tilegx/$(DEPDIR)/Lget_save_loc.Plo - -rm -f tilegx/$(DEPDIR)/Lglobal.Plo - -rm -f tilegx/$(DEPDIR)/Linit.Plo - -rm -f tilegx/$(DEPDIR)/Linit_local.Plo - -rm -f tilegx/$(DEPDIR)/Linit_remote.Plo - -rm -f tilegx/$(DEPDIR)/Lis_signal_frame.Plo - -rm -f tilegx/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f tilegx/$(DEPDIR)/Lregs.Plo - -rm -f tilegx/$(DEPDIR)/Lresume.Plo - -rm -f tilegx/$(DEPDIR)/Lstep.Plo - -rm -f tilegx/$(DEPDIR)/getcontext.Plo - -rm -f tilegx/$(DEPDIR)/is_fpreg.Plo - -rm -f tilegx/$(DEPDIR)/regname.Plo - -rm -f tilegx/$(DEPDIR)/siglongjmp.Plo - -rm -f unwind/$(DEPDIR)/Backtrace.Plo - -rm -f unwind/$(DEPDIR)/DeleteException.Plo - -rm -f unwind/$(DEPDIR)/FindEnclosingFunction.Plo - -rm -f unwind/$(DEPDIR)/ForcedUnwind.Plo - -rm -f unwind/$(DEPDIR)/GetBSP.Plo - -rm -f unwind/$(DEPDIR)/GetCFA.Plo - -rm -f unwind/$(DEPDIR)/GetDataRelBase.Plo - -rm -f unwind/$(DEPDIR)/GetGR.Plo - -rm -f unwind/$(DEPDIR)/GetIP.Plo - -rm -f unwind/$(DEPDIR)/GetIPInfo.Plo - -rm -f unwind/$(DEPDIR)/GetLanguageSpecificData.Plo - -rm -f unwind/$(DEPDIR)/GetRegionStart.Plo - -rm -f unwind/$(DEPDIR)/GetTextRelBase.Plo - -rm -f unwind/$(DEPDIR)/RaiseException.Plo - -rm -f unwind/$(DEPDIR)/Resume.Plo - -rm -f unwind/$(DEPDIR)/Resume_or_Rethrow.Plo - -rm -f unwind/$(DEPDIR)/SetGR.Plo - -rm -f unwind/$(DEPDIR)/SetIP.Plo - -rm -f x86/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f x86/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f x86/$(DEPDIR)/Gget_proc_info.Plo - -rm -f x86/$(DEPDIR)/Gget_save_loc.Plo - -rm -f x86/$(DEPDIR)/Gglobal.Plo - -rm -f x86/$(DEPDIR)/Ginit.Plo - -rm -f x86/$(DEPDIR)/Ginit_local.Plo - -rm -f x86/$(DEPDIR)/Ginit_remote.Plo - -rm -f x86/$(DEPDIR)/Gos-freebsd.Plo - -rm -f x86/$(DEPDIR)/Gos-linux.Plo - -rm -f x86/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f x86/$(DEPDIR)/Gregs.Plo - -rm -f x86/$(DEPDIR)/Gresume.Plo - -rm -f x86/$(DEPDIR)/Gstep.Plo - -rm -f x86/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f x86/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f x86/$(DEPDIR)/Lget_proc_info.Plo - -rm -f x86/$(DEPDIR)/Lget_save_loc.Plo - -rm -f x86/$(DEPDIR)/Lglobal.Plo - -rm -f x86/$(DEPDIR)/Linit.Plo - -rm -f x86/$(DEPDIR)/Linit_local.Plo - -rm -f x86/$(DEPDIR)/Linit_remote.Plo - -rm -f x86/$(DEPDIR)/Los-freebsd.Plo - -rm -f x86/$(DEPDIR)/Los-linux.Plo - -rm -f x86/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f x86/$(DEPDIR)/Lregs.Plo - -rm -f x86/$(DEPDIR)/Lresume.Plo - -rm -f x86/$(DEPDIR)/Lstep.Plo - -rm -f x86/$(DEPDIR)/getcontext-freebsd.Plo - -rm -f x86/$(DEPDIR)/getcontext-linux.Plo - -rm -f x86/$(DEPDIR)/is_fpreg.Plo - -rm -f x86/$(DEPDIR)/longjmp.Plo - -rm -f x86/$(DEPDIR)/regname.Plo - -rm -f x86/$(DEPDIR)/siglongjmp.Plo - -rm -f x86_64/$(DEPDIR)/Gapply_reg_state.Plo - -rm -f x86_64/$(DEPDIR)/Gcreate_addr_space.Plo - -rm -f x86_64/$(DEPDIR)/Gget_proc_info.Plo - -rm -f x86_64/$(DEPDIR)/Gget_save_loc.Plo - -rm -f x86_64/$(DEPDIR)/Gglobal.Plo - -rm -f x86_64/$(DEPDIR)/Ginit.Plo - -rm -f x86_64/$(DEPDIR)/Ginit_local.Plo - -rm -f x86_64/$(DEPDIR)/Ginit_remote.Plo - -rm -f x86_64/$(DEPDIR)/Gos-freebsd.Plo - -rm -f x86_64/$(DEPDIR)/Gos-linux.Plo - -rm -f x86_64/$(DEPDIR)/Gos-solaris.Plo - -rm -f x86_64/$(DEPDIR)/Greg_states_iterate.Plo - -rm -f x86_64/$(DEPDIR)/Gregs.Plo - -rm -f x86_64/$(DEPDIR)/Gresume.Plo - -rm -f x86_64/$(DEPDIR)/Gstash_frame.Plo - -rm -f x86_64/$(DEPDIR)/Gstep.Plo - -rm -f x86_64/$(DEPDIR)/Gtrace.Plo - -rm -f x86_64/$(DEPDIR)/Lapply_reg_state.Plo - -rm -f x86_64/$(DEPDIR)/Lcreate_addr_space.Plo - -rm -f x86_64/$(DEPDIR)/Lget_proc_info.Plo - -rm -f x86_64/$(DEPDIR)/Lget_save_loc.Plo - -rm -f x86_64/$(DEPDIR)/Lglobal.Plo - -rm -f x86_64/$(DEPDIR)/Linit.Plo - -rm -f x86_64/$(DEPDIR)/Linit_local.Plo - -rm -f x86_64/$(DEPDIR)/Linit_remote.Plo - -rm -f x86_64/$(DEPDIR)/Los-freebsd.Plo - -rm -f x86_64/$(DEPDIR)/Los-linux.Plo - -rm -f x86_64/$(DEPDIR)/Los-solaris.Plo - -rm -f x86_64/$(DEPDIR)/Lreg_states_iterate.Plo - -rm -f x86_64/$(DEPDIR)/Lregs.Plo - -rm -f x86_64/$(DEPDIR)/Lresume.Plo - -rm -f x86_64/$(DEPDIR)/Lstash_frame.Plo - -rm -f x86_64/$(DEPDIR)/Lstep.Plo - -rm -f x86_64/$(DEPDIR)/Ltrace.Plo - -rm -f x86_64/$(DEPDIR)/getcontext.Plo - -rm -f x86_64/$(DEPDIR)/is_fpreg.Plo - -rm -f x86_64/$(DEPDIR)/longjmp.Plo - -rm -f x86_64/$(DEPDIR)/regname.Plo - -rm -f x86_64/$(DEPDIR)/setcontext.Plo - -rm -f x86_64/$(DEPDIR)/siglongjmp.Plo + -rm -rf ./$(DEPDIR) aarch64/$(DEPDIR) arm/$(DEPDIR) coredump/$(DEPDIR) dwarf/$(DEPDIR) hppa/$(DEPDIR) ia64/$(DEPDIR) loongarch64/$(DEPDIR) mi/$(DEPDIR) mips/$(DEPDIR) ppc/$(DEPDIR) ppc32/$(DEPDIR) ppc64/$(DEPDIR) ptrace/$(DEPDIR) riscv/$(DEPDIR) s390x/$(DEPDIR) setjmp/$(DEPDIR) sh/$(DEPDIR) tilegx/$(DEPDIR) unwind/$(DEPDIR) x86/$(DEPDIR) x86_64/$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic @@ -5466,28 +4207,25 @@ ps-am: -uninstall-am: uninstall-libLIBRARIES uninstall-libLTLIBRARIES \ - uninstall-pkgconfigDATA +uninstall-am: uninstall-libLTLIBRARIES uninstall-pkgconfigDATA -.MAKE: all check install install-am install-exec install-exec-am \ - install-strip +.MAKE: all check install install-am install-exec-am install-strip -.PHONY: CTAGS GTAGS TAGS all all-am am--depfiles check check-am clean \ - clean-generic clean-libLIBRARIES clean-libLTLIBRARIES \ - clean-libtool clean-noinstLTLIBRARIES 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-exec-hook install-html install-html-am \ - install-info install-info-am install-libLIBRARIES \ +.PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ + clean-libLTLIBRARIES clean-libtool clean-noinstLTLIBRARIES \ + 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-exec-hook install-html \ + install-html-am install-info install-info-am \ install-libLTLIBRARIES install-man install-pdf install-pdf-am \ install-pkgconfigDATA 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-libLIBRARIES \ - uninstall-libLTLIBRARIES uninstall-pkgconfigDATA + tags tags-am uninstall uninstall-am uninstall-libLTLIBRARIES \ + uninstall-pkgconfigDATA .PRECIOUS: Makefile
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/aarch64/Gglobal.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/aarch64/Gglobal.c
Changed
@@ -47,9 +47,9 @@ dwarf_init (); +#ifndef UNW_REMOTE_ONLY tdep_init_mem_validate (); -#ifndef UNW_REMOTE_ONLY aarch64_local_addr_space_init (); #endif atomic_store(&tdep_init_done, 1); /* signal that we're initialized... */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/aarch64/Ginit.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/aarch64/Ginit.c
Changed
@@ -46,12 +46,40 @@ static inline void * uc_addr (unw_tdep_context_t *uc, int reg) { - if (reg >= UNW_AARCH64_X0 && reg < UNW_AARCH64_V0) + if (reg == UNW_AARCH64_VG) + { + /* + * Support for saving the vector length in the context needs to be + * added to get_context() for this path to work. + */ + Debug(1, "Accessing VG register from context is not supported\n"); + return NULL; + } +#ifdef __FreeBSD__ + if (reg >= UNW_AARCH64_X0 && reg < UNW_AARCH64_X30) + return &uc->uc_mcontext.mc_gpregs.gp_xreg; + else if (reg == UNW_AARCH64_X30) + return &uc->uc_mcontext.mc_gpregs.gp_lr; + else if (reg == UNW_AARCH64_SP) + return &uc->uc_mcontext.mc_gpregs.gp_sp; + else if (reg == UNW_AARCH64_PC) + return &uc->uc_mcontext.mc_gpregs.gp_elr; + else if (reg >= UNW_AARCH64_V0 && reg <= UNW_AARCH64_V31) + return &GET_FPCTX(uc)->uc_mcontext.mc_fpregs.fp_qreg - UNW_AARCH64_V0; + else + return NULL; +#else /* __FreeBSD__ */ + if (reg >= UNW_AARCH64_X0 && reg <= UNW_AARCH64_X30) return &uc->uc_mcontext.regsreg; + else if (reg == UNW_AARCH64_SP) + return &uc->uc_mcontext.sp; + else if (reg == UNW_AARCH64_PC) + return &uc->uc_mcontext.pc; else if (reg >= UNW_AARCH64_V0 && reg <= UNW_AARCH64_V31) return &GET_FPCTX(uc)->vregsreg - UNW_AARCH64_V0; else return NULL; +#endif /* __FreeBSD__ */ } # ifdef UNW_LOCAL_ONLY @@ -84,8 +112,6 @@ return 0; } -#define PAGE_SIZE 4096 -#define PAGE_START(a) ((a) & ~(PAGE_SIZE-1)) static int mem_validate_pipe2 = {-1, -1}; @@ -197,11 +223,14 @@ #ifdef HAVE_MINCORE unsigned char present = 1; - unw_word_t addr = PAGE_START((unw_word_t)&present); + size_t len = unw_page_size; + unw_word_t addr = uwn_page_start((unw_word_t)&present); unsigned char mvec1; int ret; - while ((ret = mincore ((void*)addr, PAGE_SIZE, (unsigned char *)mvec)) == -1 && - errno == EAGAIN) {} + while ((ret = mincore((void *)addr, len, (unsigned char *)mvec)) == -1 && + errno == EAGAIN) + { + } if (ret == 0) { Debug(1, "using mincore to validate memory\n"); @@ -295,12 +324,8 @@ { size_t len; - if (PAGE_START(addr + sizeof (unw_word_t) - 1) == PAGE_START(addr)) - len = PAGE_SIZE; - else - len = PAGE_SIZE * 2; - - addr = PAGE_START(addr); + len = unw_page_size; + addr = uwn_page_start(addr); if (addr == 0) return -1; @@ -411,6 +436,11 @@ return _Uelf64_get_proc_name (as, getpid (), ip, buf, buf_len, offp); } +static unw_word_t empty_ptrauth_mask(unw_addr_space_t addr_space_unused, void *as_arg_unused) +{ + return 0; +} + HIDDEN void aarch64_local_addr_space_init (void) { @@ -424,6 +454,7 @@ local_addr_space.acc.access_fpreg = access_fpreg; local_addr_space.acc.resume = aarch64_local_resume; local_addr_space.acc.get_proc_name = get_static_proc_name; + local_addr_space.acc.ptrauth_insn_mask = empty_ptrauth_mask; local_addr_space.big_endian = target_is_big_endian(); unw_flush_cache (&local_addr_space, 0, 0); }
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/aarch64/Gregs.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/aarch64/Gregs.c
Changed
@@ -24,6 +24,7 @@ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ +#include "dwarf_i.h" #include "unwind_i.h" HIDDEN int @@ -88,6 +89,44 @@ case UNW_AARCH64_PSTATE: loc = c->dwarf.locreg; break; + case UNW_AARCH64_RA_SIGN_STATE: + Debug (1, "Reading from ra sign state not supported: %u\n", reg); + return -UNW_EBADREG; + + case UNW_AARCH64_VG: + if (write) + { + Debug (1, "Writing to VG pseudo register not supported\n"); + return -UNW_EBADREG; + } + + if (DWARF_IS_REG_LOC(c->dwarf.locreg)) + loc = c->dwarf.locreg; + else + { + unw_addr_space_t as = c->dwarf.as; + unw_accessors_t *a = unw_get_accessors_int (as); + void *arg = c->dwarf.as_arg; + unw_word_t addr = DWARF_GET_LOC (c->dwarf.locreg); + uint16_t val16; + + /* + * If it's a memory location it means it must be in the signal context + * and it's saved as VL rather than VG so it needs to be scaled. + * + * linux/Documentation/arm64/sve.rst: + * * Vector length (VL) = size of a Z-register in bytes + * + * https://github.com/ARM-software/abi-aa/blob/main/aadwarf64/aadwarf64.rst: + * * Vector granule (VG) = Size in bits of the SVE vector registers + * in the current call frame divided by 64. + */ + int ret = dwarf_readu16 (as, a, &addr, &val16, arg); + if (!ret) + *valp = (val16 * 8) / 64; + return ret; + } + break; case UNW_AARCH64_SP: if (write)
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/aarch64/Gstash_frame.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/aarch64/Gstash_frame.c
Changed
@@ -58,16 +58,19 @@ && rs->ret_addr_column == LR && (rs->reg.whereFP == DWARF_WHERE_UNDEF || rs->reg.whereFP == DWARF_WHERE_SAME + || rs->reg.whereFP == DWARF_WHERE_CFA || (rs->reg.whereFP == DWARF_WHERE_CFAREL && labs(rs->reg.valFP) < (1 << 29) && rs->reg.valFP+1 != 0)) && (rs->reg.whereLR == DWARF_WHERE_UNDEF || rs->reg.whereLR == DWARF_WHERE_SAME + || rs->reg.whereLR == DWARF_WHERE_CFA || (rs->reg.whereLR == DWARF_WHERE_CFAREL && labs(rs->reg.valLR) < (1 << 29) && rs->reg.valLR+1 != 0)) && (rs->reg.whereSP == DWARF_WHERE_UNDEF || rs->reg.whereSP == DWARF_WHERE_SAME + || rs->reg.whereSP == DWARF_WHERE_CFA || (rs->reg.whereSP == DWARF_WHERE_CFAREL && labs(rs->reg.valSP) < (1 << 29) && rs->reg.valSP+1 != 0))) @@ -82,6 +85,12 @@ f->lr_cfa_offset = rs->reg.valLR; if (rs->reg.whereSP == DWARF_WHERE_CFAREL) f->sp_cfa_offset = rs->reg.valSP; + if (rs->reg.whereFP == DWARF_WHERE_CFA) + f->fp_cfa_offset = 0; + if (rs->reg.whereLR == DWARF_WHERE_CFA) + f->lr_cfa_offset = 0; + if (rs->reg.whereSP == DWARF_WHERE_CFA) + f->sp_cfa_offset = 0; Debug (4, " standard frame\n"); } else
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/aarch64/Gstep.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/aarch64/Gstep.c
Changed
@@ -24,6 +24,7 @@ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ +#include "dwarf_i.h" #include "unwind_i.h" #include "offsets.h" @@ -51,11 +52,63 @@ return ret; } +/* + * Save the location of VL (vector length) from the signal frame to the VG (vector + * granule) register if it exists, otherwise do nothing. If there is an error, + * the location is also not modified. + */ +static int +get_sve_vl_signal_loc (struct dwarf_cursor* dwarf, unw_word_t sc_addr) +{ + uint32_t size; + unw_addr_space_t as = dwarf->as; + unw_accessors_t *a = unw_get_accessors_int (as); + void *arg = dwarf->as_arg; + unw_word_t res_addr = sc_addr + LINUX_SC_RESERVED_OFF; + + /* + * Max possible size of reserved section is 4096. Jump by size of each record + * until the SVE signal context section is found. + */ + for(unw_word_t section_off = 0; section_off < 4096; section_off += size) + { + uint32_t magic; + int ret; + unw_word_t item_addr = res_addr + section_off + LINUX_SC_RESERVED_MAGIC_OFF; + if ((ret = dwarf_readu32(as, a, &item_addr, &magic, arg)) < 0) + return ret; + item_addr = res_addr + section_off + LINUX_SC_RESERVED_SIZE_OFF; + if ((ret = dwarf_readu32(as, a, &item_addr, &size, arg)) < 0) + return ret; + + switch(magic) + { + case 0: + /* End marker, size must be 0 */ + return size ? -UNW_EUNSPEC : 1; + + /* Magic number marking the SVE context section */ + case 0x53564501: + /* Must be big enough so that the 16 bit VL value can be accessed */ + if (size < LINUX_SC_RESERVED_SVE_VL_OFF + 2) + return -UNW_EUNSPEC; + dwarf->locUNW_AARCH64_VG = DWARF_MEM_LOC(c->dwarf, res_addr + section_off + + LINUX_SC_RESERVED_SVE_VL_OFF); + return 1; + + default: + /* Don't care about any of the other sections */ + break; + } + } + return 1; +} + static int aarch64_handle_signal_frame (unw_cursor_t *cursor) { struct cursor *c = (struct cursor *) cursor; - int ret; + int i, ret; unw_word_t sc_addr, sp, sp_addr = c->dwarf.cfa; struct dwarf_loc sp_loc = DWARF_LOC (sp_addr, 0); @@ -82,43 +135,47 @@ c->frame_info.frame_type = UNW_AARCH64_FRAME_SIGRETURN; c->frame_info.cfa_reg_offset = sc_addr - sp_addr; + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + /* Update the dwarf cursor. Set the location of the registers to the corresponding addresses of the uc_mcontext / sigcontext structure contents. */ - c->dwarf.locUNW_AARCH64_X0 = DWARF_LOC (sc_addr + LINUX_SC_X0_OFF, 0); - c->dwarf.locUNW_AARCH64_X1 = DWARF_LOC (sc_addr + LINUX_SC_X1_OFF, 0); - c->dwarf.locUNW_AARCH64_X2 = DWARF_LOC (sc_addr + LINUX_SC_X2_OFF, 0); - c->dwarf.locUNW_AARCH64_X3 = DWARF_LOC (sc_addr + LINUX_SC_X3_OFF, 0); - c->dwarf.locUNW_AARCH64_X4 = DWARF_LOC (sc_addr + LINUX_SC_X4_OFF, 0); - c->dwarf.locUNW_AARCH64_X5 = DWARF_LOC (sc_addr + LINUX_SC_X5_OFF, 0); - c->dwarf.locUNW_AARCH64_X6 = DWARF_LOC (sc_addr + LINUX_SC_X6_OFF, 0); - c->dwarf.locUNW_AARCH64_X7 = DWARF_LOC (sc_addr + LINUX_SC_X7_OFF, 0); - c->dwarf.locUNW_AARCH64_X8 = DWARF_LOC (sc_addr + LINUX_SC_X8_OFF, 0); - c->dwarf.locUNW_AARCH64_X9 = DWARF_LOC (sc_addr + LINUX_SC_X9_OFF, 0); - c->dwarf.locUNW_AARCH64_X10 = DWARF_LOC (sc_addr + LINUX_SC_X10_OFF, 0); - c->dwarf.locUNW_AARCH64_X11 = DWARF_LOC (sc_addr + LINUX_SC_X11_OFF, 0); - c->dwarf.locUNW_AARCH64_X12 = DWARF_LOC (sc_addr + LINUX_SC_X12_OFF, 0); - c->dwarf.locUNW_AARCH64_X13 = DWARF_LOC (sc_addr + LINUX_SC_X13_OFF, 0); - c->dwarf.locUNW_AARCH64_X14 = DWARF_LOC (sc_addr + LINUX_SC_X14_OFF, 0); - c->dwarf.locUNW_AARCH64_X15 = DWARF_LOC (sc_addr + LINUX_SC_X15_OFF, 0); - c->dwarf.locUNW_AARCH64_X16 = DWARF_LOC (sc_addr + LINUX_SC_X16_OFF, 0); - c->dwarf.locUNW_AARCH64_X17 = DWARF_LOC (sc_addr + LINUX_SC_X17_OFF, 0); - c->dwarf.locUNW_AARCH64_X18 = DWARF_LOC (sc_addr + LINUX_SC_X18_OFF, 0); - c->dwarf.locUNW_AARCH64_X19 = DWARF_LOC (sc_addr + LINUX_SC_X19_OFF, 0); - c->dwarf.locUNW_AARCH64_X20 = DWARF_LOC (sc_addr + LINUX_SC_X20_OFF, 0); - c->dwarf.locUNW_AARCH64_X21 = DWARF_LOC (sc_addr + LINUX_SC_X21_OFF, 0); - c->dwarf.locUNW_AARCH64_X22 = DWARF_LOC (sc_addr + LINUX_SC_X22_OFF, 0); - c->dwarf.locUNW_AARCH64_X23 = DWARF_LOC (sc_addr + LINUX_SC_X23_OFF, 0); - c->dwarf.locUNW_AARCH64_X24 = DWARF_LOC (sc_addr + LINUX_SC_X24_OFF, 0); - c->dwarf.locUNW_AARCH64_X25 = DWARF_LOC (sc_addr + LINUX_SC_X25_OFF, 0); - c->dwarf.locUNW_AARCH64_X26 = DWARF_LOC (sc_addr + LINUX_SC_X26_OFF, 0); - c->dwarf.locUNW_AARCH64_X27 = DWARF_LOC (sc_addr + LINUX_SC_X27_OFF, 0); - c->dwarf.locUNW_AARCH64_X28 = DWARF_LOC (sc_addr + LINUX_SC_X28_OFF, 0); - c->dwarf.locUNW_AARCH64_X29 = DWARF_LOC (sc_addr + LINUX_SC_X29_OFF, 0); - c->dwarf.locUNW_AARCH64_X30 = DWARF_LOC (sc_addr + LINUX_SC_X30_OFF, 0); - c->dwarf.locUNW_AARCH64_SP = DWARF_LOC (sc_addr + LINUX_SC_SP_OFF, 0); - c->dwarf.locUNW_AARCH64_PC = DWARF_LOC (sc_addr + LINUX_SC_PC_OFF, 0); - c->dwarf.locUNW_AARCH64_PSTATE = DWARF_LOC (sc_addr + LINUX_SC_PSTATE_OFF, 0); + c->dwarf.locUNW_AARCH64_X0 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X0_OFF); + c->dwarf.locUNW_AARCH64_X1 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X1_OFF); + c->dwarf.locUNW_AARCH64_X2 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X2_OFF); + c->dwarf.locUNW_AARCH64_X3 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X3_OFF); + c->dwarf.locUNW_AARCH64_X4 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X4_OFF); + c->dwarf.locUNW_AARCH64_X5 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X5_OFF); + c->dwarf.locUNW_AARCH64_X6 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X6_OFF); + c->dwarf.locUNW_AARCH64_X7 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X7_OFF); + c->dwarf.locUNW_AARCH64_X8 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X8_OFF); + c->dwarf.locUNW_AARCH64_X9 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X9_OFF); + c->dwarf.locUNW_AARCH64_X10 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X10_OFF); + c->dwarf.locUNW_AARCH64_X11 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X11_OFF); + c->dwarf.locUNW_AARCH64_X12 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X12_OFF); + c->dwarf.locUNW_AARCH64_X13 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X13_OFF); + c->dwarf.locUNW_AARCH64_X14 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X14_OFF); + c->dwarf.locUNW_AARCH64_X15 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X15_OFF); + c->dwarf.locUNW_AARCH64_X16 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X16_OFF); + c->dwarf.locUNW_AARCH64_X17 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X17_OFF); + c->dwarf.locUNW_AARCH64_X18 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X18_OFF); + c->dwarf.locUNW_AARCH64_X19 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X19_OFF); + c->dwarf.locUNW_AARCH64_X20 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X20_OFF); + c->dwarf.locUNW_AARCH64_X21 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X21_OFF); + c->dwarf.locUNW_AARCH64_X22 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X22_OFF); + c->dwarf.locUNW_AARCH64_X23 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X23_OFF); + c->dwarf.locUNW_AARCH64_X24 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X24_OFF); + c->dwarf.locUNW_AARCH64_X25 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X25_OFF); + c->dwarf.locUNW_AARCH64_X26 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X26_OFF); + c->dwarf.locUNW_AARCH64_X27 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X27_OFF); + c->dwarf.locUNW_AARCH64_X28 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X28_OFF); + c->dwarf.locUNW_AARCH64_X29 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X29_OFF); + c->dwarf.locUNW_AARCH64_X30 = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_X30_OFF); + c->dwarf.locUNW_AARCH64_SP = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_SP_OFF); + c->dwarf.locUNW_AARCH64_PC = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_PC_OFF); + c->dwarf.locUNW_AARCH64_PSTATE = DWARF_MEM_LOC (c->dwarf, sc_addr + LINUX_SC_PSTATE_OFF); + c->dwarf.locUNW_AARCH64_VG = DWARF_NULL_LOC; /* Set SP/CFA and PC/IP. */ dwarf_get (&c->dwarf, c->dwarf.locUNW_AARCH64_SP, &c->dwarf.cfa); @@ -127,7 +184,7 @@ c->dwarf.pi_valid = 0; c->dwarf.use_prev_instr = 0; - return 1; + return get_sve_vl_signal_loc (&c->dwarf, sc_addr); } int
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/aarch64/init.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/aarch64/init.h
Changed
@@ -30,6 +30,9 @@ { int ret, i; + for (i = UNW_AARCH64_PSTATE + 1; i < UNW_AARCH64_V0; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + c->dwarf.locUNW_AARCH64_X0 = DWARF_REG_LOC (&c->dwarf, UNW_AARCH64_X0); c->dwarf.locUNW_AARCH64_X1 = DWARF_REG_LOC (&c->dwarf, UNW_AARCH64_X1); c->dwarf.locUNW_AARCH64_X2 = DWARF_REG_LOC (&c->dwarf, UNW_AARCH64_X2); @@ -65,6 +68,7 @@ c->dwarf.locUNW_AARCH64_PC = DWARF_REG_LOC (&c->dwarf, UNW_AARCH64_PC); c->dwarf.locUNW_AARCH64_PSTATE = DWARF_REG_LOC (&c->dwarf, UNW_AARCH64_PSTATE); + c->dwarf.locUNW_AARCH64_VG = DWARF_REG_LOC (&c->dwarf, UNW_AARCH64_VG); c->dwarf.locUNW_AARCH64_V0 = DWARF_REG_LOC (&c->dwarf, UNW_AARCH64_V0); c->dwarf.locUNW_AARCH64_V1 = DWARF_REG_LOC (&c->dwarf, UNW_AARCH64_V1); c->dwarf.locUNW_AARCH64_V2 = DWARF_REG_LOC (&c->dwarf, UNW_AARCH64_V2); @@ -98,9 +102,6 @@ c->dwarf.locUNW_AARCH64_V30 = DWARF_REG_LOC (&c->dwarf, UNW_AARCH64_V30); c->dwarf.locUNW_AARCH64_V31 = DWARF_REG_LOC (&c->dwarf, UNW_AARCH64_V31); - for (i = UNW_AARCH64_PSTATE + 1; i < UNW_AARCH64_V0; ++i) - c->dwarf.loci = DWARF_NULL_LOC; - ret = dwarf_get (&c->dwarf, c->dwarf.locUNW_AARCH64_PC, &c->dwarf.ip); if (ret < 0) return ret;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/aarch64/offsets.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/aarch64/offsets.h
Changed
@@ -47,3 +47,10 @@ #define LINUX_SC_SP_OFF 0x100 #define LINUX_SC_PC_OFF 0x108 #define LINUX_SC_PSTATE_OFF 0x110 +#define LINUX_SC_RESERVED_OFF 0x120 + +// struct _aarch64_ctx { __u32 magic; __u32 size; }; +// struct sve_context { struct _aarch64_ctx head; __u16 vl; __u16 __reserved3; }; +#define LINUX_SC_RESERVED_MAGIC_OFF 0x0 +#define LINUX_SC_RESERVED_SIZE_OFF 0x4 +#define LINUX_SC_RESERVED_SVE_VL_OFF 0x8 \ No newline at end of file
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/aarch64/unwind_i.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/aarch64/unwind_i.h
Changed
@@ -59,6 +59,10 @@ } while (0) #endif +#if defined(__FreeBSD__) +#define GET_FPCTX(uc) ((unw_tdep_context_t *)(&uc->uc_mcontext.mc_spare)) +#else #define GET_FPCTX(uc) ((unw_fpsimd_context_t *)(&uc->uc_mcontext.__reserved)) +#endif #endif /* unwind_i_h */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/arm/Gex_tables.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/arm/Gex_tables.c
Changed
@@ -119,10 +119,12 @@ dwarf_get (c, c->locUNW_ARM_R13, &c->cfa); break; case ARM_EXIDX_CMD_VFP_POP: - /* Skip VFP registers, but be sure to adjust stack */ for (i = ARM_EXBUF_START (edata->data); i <= ARM_EXBUF_END (edata->data); i++) + { + c->locUNW_ARM_S0 + i = DWARF_LOC (c->cfa, 0); c->cfa += 8; + } if (!(edata->data & ARM_EXIDX_VFP_DOUBLE)) c->cfa += 4; break; @@ -506,18 +508,20 @@ } HIDDEN int -arm_find_proc_info (unw_addr_space_t as, unw_word_t ip, - unw_proc_info_t *pi, int need_unwind_info, void *arg) +arm_find_proc_info2 (unw_addr_space_t as, unw_word_t ip, + unw_proc_info_t *pi, int need_unwind_info, void *arg, + int methods) { int ret = -1; intrmask_t saved_mask; Debug (14, "looking for IP=0x%lx\n", (long) ip); - if (UNW_TRY_METHOD(UNW_ARM_METHOD_DWARF)) + if (UNW_TRY_METHOD (UNW_ARM_METHOD_DWARF) && (methods & UNW_ARM_METHOD_DWARF)) ret = dwarf_find_proc_info (as, ip, pi, need_unwind_info, arg); - if (ret < 0 && UNW_TRY_METHOD (UNW_ARM_METHOD_EXIDX)) + if (ret < 0 && UNW_TRY_METHOD (UNW_ARM_METHOD_EXIDX) && + (methods & UNW_ARM_METHOD_EXIDX)) { struct arm_cb_data cb_data; @@ -540,6 +544,14 @@ return ret; } +HIDDEN int +arm_find_proc_info (unw_addr_space_t as, unw_word_t ip, + unw_proc_info_t *pi, int need_unwind_info, void *arg) +{ + return arm_find_proc_info2 (as, ip, pi, need_unwind_info, arg, + UNW_ARM_METHOD_ALL); +} + HIDDEN void arm_put_unwind_info (unw_addr_space_t as, unw_proc_info_t *proc_info, void *arg) {
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/arm/Gget_save_loc.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/arm/Gget_save_loc.c
Changed
@@ -53,6 +53,25 @@ loc = c->dwarf.locreg - UNW_ARM_R0; break; + case UNW_ARM_D0: + case UNW_ARM_D1: + case UNW_ARM_D2: + case UNW_ARM_D3: + case UNW_ARM_D4: + case UNW_ARM_D5: + case UNW_ARM_D6: + case UNW_ARM_D7: + case UNW_ARM_D8: + case UNW_ARM_D9: + case UNW_ARM_D10: + case UNW_ARM_D11: + case UNW_ARM_D12: + case UNW_ARM_D13: + case UNW_ARM_D14: + case UNW_ARM_D15: + loc = c->dwarf.locUNW_ARM_S0 + (reg - UNW_ARM_D0); + break; + default: break; }
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/arm/Ginit.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/arm/Ginit.c
Changed
@@ -43,6 +43,8 @@ { if (reg >= UNW_ARM_R0 && reg < UNW_ARM_R0 + 16) return &uc->regsreg - UNW_ARM_R0; + else if (reg >= UNW_ARM_D0 && reg <= UNW_ARM_D15) + return &uc->fpregsreg - UNW_ARM_D0; else return NULL; } @@ -71,9 +73,6 @@ return 0; } -#define PAGE_SIZE 4096 -#define PAGE_START(a) ((a) & ~(PAGE_SIZE-1)) - /* Cache of already validated addresses */ #define NLGA 4 static unw_word_t last_good_addrNLGA; @@ -83,14 +82,8 @@ validate_mem (unw_word_t addr) { int i, victim; - size_t len; - - if (PAGE_START(addr + sizeof (unw_word_t) - 1) == PAGE_START(addr)) - len = PAGE_SIZE; - else - len = PAGE_SIZE * 2; - - addr = PAGE_START(addr); + size_t len = unw_page_size; + addr = uwn_page_start(addr); if (addr == 0) return -1;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/arm/Gos-freebsd.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/arm/Gos-freebsd.c
Changed
@@ -38,7 +38,7 @@ arm_handle_signal_frame (unw_cursor_t *cursor) { struct cursor *c = (struct cursor *) cursor; - int ret, fmt; + int i, ret, fmt; unw_word_t sc_addr, sp, sp_addr = c->dwarf.cfa; struct dwarf_loc sp_loc = DWARF_LOC (sp_addr, 0); @@ -70,6 +70,9 @@ c->frame_info.frame_type = UNW_ARM_FRAME_SIGRETURN; c->frame_info.cfa_reg_offset = sc_addr - sp_addr; + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + /* Update the dwarf cursor. Set the location of the registers to the corresponding addresses of the uc_mcontext / sigcontext structure contents. */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/arm/Gos-linux.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/arm/Gos-linux.c
Changed
@@ -33,7 +33,7 @@ arm_handle_signal_frame (unw_cursor_t *cursor) { struct cursor *c = (struct cursor *) cursor; - int ret; + int i, ret; unw_word_t sc_addr, sp, sp_addr = c->dwarf.cfa; struct dwarf_loc sp_loc = DWARF_LOC (sp_addr, 0); @@ -93,6 +93,9 @@ c->frame_info.frame_type = UNW_ARM_FRAME_SIGRETURN; c->frame_info.cfa_reg_offset = sc_addr - sp_addr; + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + /* Update the dwarf cursor. Set the location of the registers to the corresponding addresses of the uc_mcontext / sigcontext structure contents. */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/arm/Gregs.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/arm/Gregs.c
Changed
@@ -78,6 +78,35 @@ tdep_access_fpreg (struct cursor *c, unw_regnum_t reg, unw_fpreg_t *valp, int write) { - Debug (1, "bad register number %u\n", reg); - return -UNW_EBADREG; + dwarf_loc_t loc = DWARF_NULL_LOC; + switch (reg) + { + case UNW_ARM_D0: + case UNW_ARM_D1: + case UNW_ARM_D2: + case UNW_ARM_D3: + case UNW_ARM_D4: + case UNW_ARM_D5: + case UNW_ARM_D6: + case UNW_ARM_D7: + case UNW_ARM_D8: + case UNW_ARM_D9: + case UNW_ARM_D10: + case UNW_ARM_D11: + case UNW_ARM_D12: + case UNW_ARM_D13: + case UNW_ARM_D14: + case UNW_ARM_D15: + loc = c->dwarf.locUNW_ARM_S0 + (reg - UNW_ARM_D0); + break; + + default: + Debug (1, "bad register number %u\n", reg); + return -UNW_EBADREG; + } + + if (write) + return dwarf_putfp (&c->dwarf, loc, *valp); + else + return dwarf_getfp (&c->dwarf, loc, valp); }
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/arm/Gstash_frame.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/arm/Gstash_frame.c
Changed
@@ -58,16 +58,19 @@ && rs->ret_addr_column == LR && (rs->reg.whereR7 == DWARF_WHERE_UNDEF || rs->reg.whereR7 == DWARF_WHERE_SAME + || rs->reg.whereR7 == DWARF_WHERE_CFA || (rs->reg.whereR7 == DWARF_WHERE_CFAREL && labs(rs->reg.valR7) < (1 << 29) && rs->reg.valR7+1 != 0)) && (rs->reg.whereLR == DWARF_WHERE_UNDEF || rs->reg.whereLR == DWARF_WHERE_SAME + || rs->reg.whereR7 == DWARF_WHERE_CFA || (rs->reg.whereLR == DWARF_WHERE_CFAREL && labs(rs->reg.valLR) < (1 << 29) && rs->reg.valLR+1 != 0)) && (rs->reg.whereSP == DWARF_WHERE_UNDEF || rs->reg.whereSP == DWARF_WHERE_SAME + || rs->reg.whereSP == DWARF_WHERE_CFA || (rs->reg.whereSP == DWARF_WHERE_CFAREL && labs(rs->reg.valSP) < (1 << 29) && rs->reg.valSP+1 != 0))) @@ -82,6 +85,12 @@ f->lr_cfa_offset = rs->reg.valLR; if (rs->reg.whereSP == DWARF_WHERE_CFAREL) f->sp_cfa_offset = rs->reg.valSP; + if (rs->reg.whereR7 == DWARF_WHERE_CFA) + f->r7_cfa_offset = 0; + if (rs->reg.whereLR == DWARF_WHERE_CFA) + f->lr_cfa_offset = 0; + if (rs->reg.whereSP == DWARF_WHERE_CFA) + f->sp_cfa_offset = 0; Debug (4, " standard frame\n"); } else
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/arm/Gstep.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/arm/Gstep.c
Changed
@@ -54,17 +54,22 @@ c->dwarf.as_arg); if (ret == -UNW_ENOINFO) { +#ifdef UNW_LOCAL_ONLY + if ((ret = arm_find_proc_info2 (c->dwarf.as, ip, &c->dwarf.pi, + 1, c->dwarf.as_arg, + UNW_ARM_METHOD_EXIDX)) < 0) + return ret; +#else if ((ret = tdep_find_proc_info (&c->dwarf, ip, 1)) < 0) return ret; +#endif } if (c->dwarf.pi.format != UNW_INFO_FORMAT_ARM_EXIDX) return -UNW_ENOINFO; ret = arm_exidx_extract (&c->dwarf, buf); - if (ret == -UNW_ESTOPUNWIND) - return 0; - else if (ret < 0) + if (ret < 0) return ret; ret = arm_exidx_decode (buf, ret, &c->dwarf); @@ -88,6 +93,7 @@ { struct cursor *c = (struct cursor *) cursor; int ret = -UNW_EUNSPEC; + int has_stopunwind = 0; Debug (1, "(cursor=%p)\n", c); @@ -95,17 +101,31 @@ if (unw_is_signal_frame (cursor) > 0) return arm_handle_signal_frame (cursor); + /* First, try extbl-based unwinding. */ + if (UNW_TRY_METHOD (UNW_ARM_METHOD_EXIDX)) + { + ret = arm_exidx_step (c); + Debug(1, "arm_exidx_step()=%d\n", ret); + if (ret > 0) + return 1; + if (ret == 0) + return ret; + if (ret == -UNW_ESTOPUNWIND) + has_stopunwind = 1; + } + #ifdef CONFIG_DEBUG_FRAME - /* First, try DWARF-based unwinding. */ + /* Second, try DWARF-based unwinding. */ if (UNW_TRY_METHOD(UNW_ARM_METHOD_DWARF)) { + Debug (13, "%s(ret=%d), trying extbl\n", + UNW_TRY_METHOD(UNW_ARM_METHOD_EXIDX) ? "arm_exidx_step() failed " : "", + ret); ret = dwarf_step (&c->dwarf); Debug(1, "dwarf_step()=%d\n", ret); if (likely (ret > 0)) return 1; - else if (unlikely (ret == -UNW_ESTOPUNWIND)) - return ret; if (ret < 0 && ret != -UNW_ENOINFO) { @@ -115,18 +135,9 @@ } #endif /* CONFIG_DEBUG_FRAME */ - /* Next, try extbl-based unwinding. */ - if (UNW_TRY_METHOD (UNW_ARM_METHOD_EXIDX)) - { - Debug (13, "%s(ret=%d), trying extbl\n", - UNW_TRY_METHOD(UNW_ARM_METHOD_DWARF) ? "dwarf_step() failed " : "", - ret); - ret = arm_exidx_step (c); - if (ret > 0) - return 1; - if (ret == -UNW_ESTOPUNWIND || ret == 0) - return ret; - } + // Before trying the fallback, if any unwind info tell us to stop, do that. + if (has_stopunwind) + return -UNW_ESTOPUNWIND; /* Fall back on APCS frame parsing. Note: This won't work in case the ARM EABI is used. */ @@ -139,13 +150,13 @@ if (UNW_TRY_METHOD(UNW_ARM_METHOD_FRAME)) { Debug (13, "%s%s%s%s(ret=%d), trying frame-chain\n", - UNW_TRY_METHOD(UNW_ARM_METHOD_DWARF) ? "dwarf_step() " : "", - (UNW_TRY_METHOD(UNW_ARM_METHOD_DWARF) && UNW_TRY_METHOD(UNW_ARM_METHOD_EXIDX)) ? "and " : "", UNW_TRY_METHOD(UNW_ARM_METHOD_EXIDX) ? "arm_exidx_step() " : "", - (UNW_TRY_METHOD(UNW_ARM_METHOD_DWARF) || UNW_TRY_METHOD(UNW_ARM_METHOD_EXIDX)) ? "failed " : "", + (UNW_TRY_METHOD(UNW_ARM_METHOD_EXIDX) && UNW_TRY_METHOD(UNW_ARM_METHOD_DWARF)) ? "and " : "", + UNW_TRY_METHOD(UNW_ARM_METHOD_DWARF) ? "dwarf_step() " : "", + (UNW_TRY_METHOD(UNW_ARM_METHOD_EXIDX) || UNW_TRY_METHOD(UNW_ARM_METHOD_DWARF)) ? "failed " : "", ret); ret = UNW_ESUCCESS; - /* DWARF unwinding failed, try to follow APCS/optimized APCS frame chain */ + /* EXIDX and/or DWARF unwinding failed, try to follow APCS/optimized APCS frame chain */ unw_word_t instr, i; dwarf_loc_t ip_loc, fp_loc; unw_word_t frame;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/arm/init.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/arm/init.h
Changed
@@ -45,7 +45,24 @@ c->dwarf.locUNW_ARM_R13 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_R13); c->dwarf.locUNW_ARM_R14 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_R14); c->dwarf.locUNW_ARM_R15 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_R15); - for (i = UNW_ARM_R15 + 1; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.locUNW_ARM_S0 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S0); + c->dwarf.locUNW_ARM_S1 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S1); + c->dwarf.locUNW_ARM_S2 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S2); + c->dwarf.locUNW_ARM_S3 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S3); + c->dwarf.locUNW_ARM_S4 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S4); + c->dwarf.locUNW_ARM_S5 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S5); + c->dwarf.locUNW_ARM_S6 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S6); + c->dwarf.locUNW_ARM_S7 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S7); + c->dwarf.locUNW_ARM_S8 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S8); + c->dwarf.locUNW_ARM_S9 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S9); + c->dwarf.locUNW_ARM_S10 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S10); + c->dwarf.locUNW_ARM_S11 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S11); + c->dwarf.locUNW_ARM_S12 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S12); + c->dwarf.locUNW_ARM_S13 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S13); + c->dwarf.locUNW_ARM_S14 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S14); + c->dwarf.locUNW_ARM_S15 = DWARF_REG_LOC (&c->dwarf, UNW_ARM_S15); + + for (i = UNW_ARM_S15 + 1; i < DWARF_NUM_PRESERVED_REGS; ++i) c->dwarf.loci = DWARF_NULL_LOC; ret = dwarf_get (&c->dwarf, c->dwarf.locUNW_ARM_R15, &c->dwarf.ip);
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/coredump/_UCD_access_mem.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/_UCD_access_mem.c
Changed
@@ -23,76 +23,83 @@ #include "_UCD_lib.h" #include "_UCD_internal.h" +#include "ucd_file_table.h" int -_UCD_access_mem(unw_addr_space_t as, unw_word_t addr, unw_word_t *val, - int write, void *arg) +_UCD_access_mem (unw_addr_space_t as, + unw_word_t addr, + unw_word_t *val, + int write, + void *arg) { if (write) { - Debug(0, "write is not supported\n"); + Debug (0, "write is not supported\n"); return -UNW_EINVAL; } struct UCD_info *ui = arg; - unw_word_t addr_last = addr + sizeof(*val)-1; - coredump_phdr_t *phdr; + unw_word_t addr_last = addr + sizeof (*val) - 1; + unsigned i; + for (i = 0; i < ui->phdrs_count; i++) { - phdr = &ui->phdrsi; - if (phdr->p_vaddr <= addr && addr_last < phdr->p_vaddr + phdr->p_memsz) + coredump_phdr_t *phdr = &ui->phdrsi; + + /* First check the (in-memory) backup file image. */ + if (phdr->p_backing_file_index != ucd_file_no_index) { - goto found; - } - } - Debug(1, "addr 0x%llx is unmapped\n", (unsigned long long)addr); - return -UNW_EINVAL; + ucd_file_t *ucd_file = ucd_file_table_at (&ui->ucd_file_table, phdr->p_backing_file_index); - found: ; + if (ucd_file == NULL) + { + Debug (0, "invalid backing file index for phdr%d\n", i); + return -UNW_EINVAL; + } - const char *filename UNUSED; - off_t fileofs; - int fd; - if (addr_last >= phdr->p_vaddr + phdr->p_filesz) - { - /* This part of mapped address space is not present in coredump file */ - /* Do we have it in the backup file? */ - if (phdr->backing_fd < 0) + off_t image_offset = addr - phdr->p_vaddr; + + if (phdr->p_vaddr <= addr && addr_last < phdr->p_vaddr + ucd_file->size) + { + memcpy (val, ucd_file->image + image_offset, sizeof (*val)); + Debug (16, "%#010llx <- addr:%#010llx file:%s\n", + (unsigned long long) (*val), + (unsigned long long)image_offset, + ucd_file->filename); + return UNW_ESUCCESS; + } + } + + /* Next, check the on-disk corefile. */ + if (phdr->p_vaddr <= addr && addr_last < phdr->p_vaddr + phdr->p_memsz) { - Debug(1, "access to not-present data in phdr%d: addr:0x%llx\n", - i, (unsigned long long)addr - ); - return -UNW_EINVAL; + off_t fileofs = phdr->p_offset + (addr - phdr->p_vaddr); + + if (lseek (ui->coredump_fd, fileofs, SEEK_SET) != fileofs) + { + Debug (0, "error %d in lseek(\"%s\", %lld): %s\n", + errno, ui->coredump_filename, (long long)fileofs, strerror (errno)); + return -UNW_EINVAL; + } + + if (read (ui->coredump_fd, val, sizeof (*val)) != sizeof (*val)) + { + Debug (0, "error %d in read(\"%s\", %lld): %s\n", + errno, ui->coredump_filename, (long long)sizeof (*val), strerror (errno)); + return -UNW_EINVAL; + } + + Debug (16, "0x%llx <- addr:0x%llx fileofs:0x%llx file:%s\n", + (unsigned long long) (*val), + (unsigned long long)addr, + (unsigned long long)fileofs, + ui->coredump_filename); + return UNW_ESUCCESS; } - filename = phdr->backing_filename; - fileofs = addr - phdr->p_vaddr; - fd = phdr->backing_fd; - goto read; } - filename = ui->coredump_filename; - fileofs = phdr->p_offset + (addr - phdr->p_vaddr); - fd = ui->coredump_fd; - read: - if (lseek(fd, fileofs, SEEK_SET) != fileofs) - goto read_error; - if (read(fd, val, sizeof(*val)) != sizeof(*val)) - goto read_error; - - Debug(1, "0x%llx <- addr:0x%llx fileofs:0x%llx\n", - (unsigned long long)(*val), - (unsigned long long)addr, - (unsigned long long)fileofs - ); - return 0; - - read_error: - Debug(1, "access out of file: addr:0x%llx fileofs:%llx file:'%s'\n", - (unsigned long long)addr, - (unsigned long long)fileofs, - filename - ); + Debug (0, "addr %#010llx is unmapped\n", (unsigned long long)addr); return -UNW_EINVAL; }
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/coredump/_UCD_access_reg_linux.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/_UCD_access_reg_linux.c
Changed
@@ -54,9 +54,6 @@ #elif defined(UNW_TARGET_TILEGX) if (regnum > UNW_TILEGX_CFA) goto badreg; -#elif defined(UNW_TARGET_S390X) - if (regnum > UNW_S390X_R15) - goto badreg; #elif defined(UNW_TARGET_IA64) || defined(UNW_TARGET_HPPA) || defined(UNW_TARGET_PPC32) || defined(UNW_TARGET_PPC64) if (regnum >= ARRAY_SIZE(ui->prstatus->pr_reg)) goto badreg; @@ -65,6 +62,43 @@ regnum = 0; else if (regnum > UNW_RISCV_X31) goto badreg; +#elif defined(UNW_TARGET_LOONGARCH64) +# include <asm/reg.h> + + static const uint8_t remap_regs = + { + UNW_LOONGARCH64_R0 = LOONGARCH_EF_R0, + UNW_LOONGARCH64_R1 = LOONGARCH_EF_R1, + UNW_LOONGARCH64_R2 = LOONGARCH_EF_R2, + UNW_LOONGARCH64_R3 = LOONGARCH_EF_R3, + UNW_LOONGARCH64_R4 = LOONGARCH_EF_R4, + UNW_LOONGARCH64_R5 = LOONGARCH_EF_R5, + UNW_LOONGARCH64_R6 = LOONGARCH_EF_R6, + UNW_LOONGARCH64_R7 = LOONGARCH_EF_R7, + UNW_LOONGARCH64_R8 = LOONGARCH_EF_R8, + UNW_LOONGARCH64_R9 = LOONGARCH_EF_R9, + UNW_LOONGARCH64_R10 = LOONGARCH_EF_R10, + UNW_LOONGARCH64_R11 = LOONGARCH_EF_R11, + UNW_LOONGARCH64_R12 = LOONGARCH_EF_R12, + UNW_LOONGARCH64_R13 = LOONGARCH_EF_R13, + UNW_LOONGARCH64_R14 = LOONGARCH_EF_R14, + UNW_LOONGARCH64_R15 = LOONGARCH_EF_R15, + UNW_LOONGARCH64_R16 = LOONGARCH_EF_R16, + UNW_LOONGARCH64_R17 = LOONGARCH_EF_R17, + UNW_LOONGARCH64_R18 = LOONGARCH_EF_R18, + UNW_LOONGARCH64_R19 = LOONGARCH_EF_R19, + UNW_LOONGARCH64_R20 = LOONGARCH_EF_R20, + UNW_LOONGARCH64_R21 = LOONGARCH_EF_R21, + UNW_LOONGARCH64_R22 = LOONGARCH_EF_R22, + UNW_LOONGARCH64_R23 = LOONGARCH_EF_R23, + UNW_LOONGARCH64_R24 = LOONGARCH_EF_R24, + UNW_LOONGARCH64_R25 = LOONGARCH_EF_R25, + UNW_LOONGARCH64_R28 = LOONGARCH_EF_R28, + UNW_LOONGARCH64_R29 = LOONGARCH_EF_R29, + UNW_LOONGARCH64_R30 = LOONGARCH_EF_R30, + UNW_LOONGARCH64_R31 = LOONGARCH_EF_R31, + UNW_LOONGARCH64_PC = LOONGARCH_EF_CSR_ERA, + }; #else #if defined(UNW_TARGET_MIPS) static const uint8_t remap_regs = @@ -101,6 +135,27 @@ UNW_MIPS_R31 = EF_REG31, UNW_MIPS_PC = EF_CP0_EPC, }; +#elif defined(UNW_TARGET_S390X) + static const uint8_t remap_regs = + { + UNW_S390X_IP = offsetof(struct user_regs_struct, psw.addr) / sizeof(long), + UNW_S390X_R0 = offsetof(struct user_regs_struct, gprs0) / sizeof(long), + UNW_S390X_R1 = offsetof(struct user_regs_struct, gprs1) / sizeof(long), + UNW_S390X_R2 = offsetof(struct user_regs_struct, gprs2) / sizeof(long), + UNW_S390X_R3 = offsetof(struct user_regs_struct, gprs3) / sizeof(long), + UNW_S390X_R4 = offsetof(struct user_regs_struct, gprs4) / sizeof(long), + UNW_S390X_R5 = offsetof(struct user_regs_struct, gprs5) / sizeof(long), + UNW_S390X_R6 = offsetof(struct user_regs_struct, gprs6) / sizeof(long), + UNW_S390X_R7 = offsetof(struct user_regs_struct, gprs7) / sizeof(long), + UNW_S390X_R8 = offsetof(struct user_regs_struct, gprs8) / sizeof(long), + UNW_S390X_R9 = offsetof(struct user_regs_struct, gprs9) / sizeof(long), + UNW_S390X_R10 = offsetof(struct user_regs_struct, gprs10) / sizeof(long), + UNW_S390X_R11 = offsetof(struct user_regs_struct, gprs11) / sizeof(long), + UNW_S390X_R12 = offsetof(struct user_regs_struct, gprs12) / sizeof(long), + UNW_S390X_R13 = offsetof(struct user_regs_struct, gprs13) / sizeof(long), + UNW_S390X_R14 = offsetof(struct user_regs_struct, gprs14) / sizeof(long), + UNW_S390X_R15 = offsetof(struct user_regs_struct, gprs15) / sizeof(long), + }; #elif defined(UNW_TARGET_X86) static const uint8_t remap_regs = {
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/coredump/_UCD_create.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/_UCD_create.c
Changed
@@ -142,9 +142,7 @@ cur->p_filesz = hdr64.p_filesz; cur->p_memsz = hdr64.p_memsz ; cur->p_align = hdr64.p_align ; - /* cur->backing_filename = NULL; - done by memset */ - cur->backing_fd = -1; - cur->backing_filesize = hdr64.p_filesz; + cur->p_backing_file_index = -1; i++; cur++; } @@ -167,9 +165,7 @@ cur->p_filesz = hdr32.p_filesz; cur->p_memsz = hdr32.p_memsz ; cur->p_align = hdr32.p_align ; - /* cur->backing_filename = NULL; - done by memset */ - cur->backing_fd = -1; - cur->backing_filesize = hdr32.p_memsz; + cur->p_backing_file_index = -1; i++; cur++; } @@ -181,6 +177,10 @@ goto err; } + ret = ucd_file_table_init(&ui->ucd_file_table); + if (ret != UNW_ESUCCESS) { + Debug(0, "error initializing backing file table\n"); + } ret = _UCD_get_mapinfo(ui, phdrs, size); if (ret != UNW_ESUCCESS) { Debug(0, "failure retrieving file mapping from core file\n"); @@ -192,23 +192,17 @@ { if (cur->p_type == PT_LOAD) { - Debug(2, " ofs:%08llx va:%08llx filesize:%08llx memsize:%08llx flg:%x", + Debug(2, "phdr%u ofs:%#010llx va:%#010llx filesize:%#010llx memsize:%#010llx flg:%#04x bf_idx=%d %s %s\n", + i, (unsigned long long) cur->p_offset, (unsigned long long) cur->p_vaddr, (unsigned long long) cur->p_filesz, (unsigned long long) cur->p_memsz, - cur->p_flags - ); - if (cur->p_filesz < cur->p_memsz) - { - Debug(2, " partial"); - } - if (cur->p_flags & PF_X) - { - Debug(2, " executable"); - } + cur->p_flags, + cur->p_backing_file_index, + (cur->p_filesz < cur->p_memsz)?"partial":" ", + (cur->p_flags & PF_X)?"exec":" "); } - Debug(2, "\n"); cur++; } @@ -218,7 +212,10 @@ goto err; } - ui->prstatus = &ui->threads0; + ui->prstatus = &ui->threads0.prstatus; +#ifdef HAVE_ELF_FPREGSET_T + ui->fpregset = &ui->threads0.fpregset; +#endif return ui; @@ -234,96 +231,29 @@ void _UCD_select_thread(struct UCD_info *ui, int n) { - if (n >= 0 && n < ui->n_threads) - ui->prstatus = &ui->threadsn; + if (n >= 0 && n < ui->n_threads) { + ui->prstatus = &ui->threadsn.prstatus; +#ifdef HAVE_ELF_FPREGSET_T + ui->fpregset = &ui->threadsn.fpregset; +#endif + } } pid_t _UCD_get_pid(struct UCD_info *ui) { +#if defined(HAVE_PROCFS_STATUS) + return ui->prstatus->pid; +#else return ui->prstatus->pr_pid; +#endif } int _UCD_get_cursig(struct UCD_info *ui) { - return ui->prstatus->pr_cursig; -} - -int _UCD_add_backing_file_at_segment(struct UCD_info *ui, int phdr_no, const char *filename) -{ - if ((unsigned)phdr_no >= ui->phdrs_count) - { - Debug(0, "There is no segment %d in this coredump\n", phdr_no); - return -1; - } - - struct coredump_phdr *phdr = &ui->phdrsphdr_no; - if (phdr->backing_filename) - { - Debug(0, "Backing file already added to segment %d\n", phdr_no); - return -1; - } - - int fd = open(filename, O_RDONLY); - if (fd < 0) - { - Debug(0, "Can't open '%s'\n", filename); - return -1; - } - - phdr->backing_fd = fd; - phdr->backing_filename = strdup(filename); - - struct stat statbuf; - if (fstat(fd, &statbuf) != 0) - { - Debug(0, "Can't stat '%s'\n", filename); - goto err; - } - phdr->backing_filesize = (uoff_t)statbuf.st_size; - - if (phdr->p_flags != (PF_X | PF_R)) - { - Debug(1, "Note: phdr%u is not r-x: flags are 0x%x\n", - phdr_no, phdr->p_flags); - } - - if (phdr->backing_filesize > phdr->p_memsz) - { - /* This is expected */ - Debug(2, "Note: phdr%u is %lld bytes, file is larger: %lld bytes\n", - phdr_no, - (unsigned long long)phdr->p_memsz, - (unsigned long long)phdr->backing_filesize - ); - } -//TODO: else loudly complain? Maybe even fail? - - /* Success */ +#if defined(HAVE_PROCFS_STATUS) return 0; - - err: - if (phdr->backing_fd >= 0) - { - close(phdr->backing_fd); - phdr->backing_fd = -1; - } - free(phdr->backing_filename); - phdr->backing_filename = NULL; - return -1; +#else + return ui->prstatus->pr_cursig; +#endif } -int _UCD_add_backing_file_at_vaddr(struct UCD_info *ui, - unsigned long vaddr, - const char *filename) -{ - unsigned i; - for (i = 0; i < ui->phdrs_count; i++) - { - struct coredump_phdr *phdr = &ui->phdrsi; - if (phdr->p_vaddr != vaddr) - continue; - /* It seems to match. Add it. */ - return _UCD_add_backing_file_at_segment(ui, i, filename); - } - return -1; -}
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/coredump/_UCD_destroy.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/_UCD_destroy.c
Changed
@@ -35,14 +35,7 @@ invalidate_edi (&ui->edi); - unsigned i; - for (i = 0; i < ui->phdrs_count; i++) - { - struct coredump_phdr *phdr = &ui->phdrsi; - free(phdr->backing_filename); - if (phdr->backing_fd >= 0) - close(phdr->backing_fd); - } + ucd_file_table_dispose(&ui->ucd_file_table); free(ui->phdrs); free(ui->note_phdr);
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/coredump/_UCD_elf_map_image.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/_UCD_elf_map_image.c
Changed
@@ -29,13 +29,14 @@ #include "_UCD_lib.h" #include "_UCD_internal.h" +#include "ucd_file_table.h" static coredump_phdr_t * CD_elf_map_image(struct UCD_info *ui, coredump_phdr_t *phdr) { struct elf_image *ei = &ui->edi.ei; - if (phdr->backing_fd < 0) + if (phdr->p_backing_file_index == ucd_file_no_index) { /* Note: coredump file contains only phdr->p_filesz bytes. * We want to map bigger area (phdr->p_memsz bytes) to make sure @@ -45,6 +46,7 @@ ei->image = mmap(NULL, phdr->p_memsz, PROT_READ, MAP_PRIVATE, ui->coredump_fd, phdr->p_offset); if (ei->image == MAP_FAILED) { + Debug(0, "error %d in mmap(): %s\n", errno, strerror(errno)); ei->image = NULL; return NULL; } @@ -56,21 +58,19 @@ munmap(remainder_base, remainder_len); } } else { - /* We have a backing file for this segment. - * This file is always longer than phdr->p_memsz, - * and if phdr->p_filesz !=0, first phdr->p_filesz bytes in coredump - * are the same as first bytes in the file. (Thus no need to map coredump) - * We map the entire file: - * unwinding may need data which is past phdr->p_memsz bytes. - */ + ucd_file_t *ucd_file = ucd_file_table_at(&ui->ucd_file_table, phdr->p_backing_file_index); + if (ucd_file == NULL) + { + Debug(0, "error retrieving backing file for index %d\n", phdr->p_backing_file_index); + return NULL; + } /* addr, length, prot, flags, fd, fd_offset */ - ei->image = mmap(NULL, phdr->backing_filesize, PROT_READ, MAP_PRIVATE, phdr->backing_fd, 0); - if (ei->image == MAP_FAILED) + ei->image = ucd_file_map (ucd_file); + if (ei->image == NULL) { - ei->image = NULL; return NULL; } - ei->size = phdr->backing_filesize; + ei->size = ucd_file->size; } /* Check ELF header for sanity */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/coredump/_UCD_find_proc_info.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/_UCD_find_proc_info.c
Changed
@@ -53,6 +53,9 @@ && ip >= ui->edi.di_debug.start_ip && ip < ui->edi.di_debug.end_ip)) return 0; + /* The invalidate_edi call unmaps memory it doesn't own, so just null it out + instead. */ + ui->edi.ei.image = NULL; invalidate_edi (&ui->edi); /* Used to be tdep_get_elf_image() in ptrace unwinding code */ @@ -62,17 +65,22 @@ Debug(1, "returns error: _UCD_get_elf_image failed\n"); return -UNW_ENOINFO; } + + ucd_file_t *ucd_file = ucd_file_table_at(&ui->ucd_file_table, phdr->p_backing_file_index); + if (ucd_file == NULL) + { + Debug(0, "no backing file for index %d\n", phdr->p_backing_file_index); + return -UNW_ENOINFO; + } + /* segbase: where it is mapped in virtual memory */ - /* mapoff: offset in the file */ segbase = phdr->p_vaddr; - /*mapoff = phdr->p_offset; WRONG! phdr->p_offset is the offset in COREDUMP file */ + /* mapoff doesn't matter since the entire file is loaded */ mapoff = 0; -///FIXME. text segment is USUALLY, not always, at offset 0 in the binary/.so file. -// ensure that at initialization. /* Here, SEGBASE is the starting-address of the (mmap'ped) segment which covers the IP we're looking for. */ - if (tdep_find_unwind_table(&ui->edi, as, phdr->backing_filename, segbase, mapoff, ip) < 0) + if (tdep_find_unwind_table(&ui->edi, as, ucd_file->filename, segbase, mapoff, ip) < 0) { Debug(1, "returns error: tdep_find_unwind_table failed\n"); return -UNW_ENOINFO;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/coredump/_UCD_get_mapinfo_linux.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/_UCD_get_mapinfo_linux.c
Changed
@@ -3,17 +3,17 @@ */ /* This file is part of libunwind. - + 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 @@ -43,60 +43,105 @@ * containing the mapped file names. They are ordered correspondingly to each * entry in the map structure array. */ -typedef struct { +struct core_nt_file_hdr_s +{ unsigned long count; unsigned long pagesz; -} linux_mapinfo_hdr_t; +}; +typedef struct core_nt_file_hdr_s core_nt_file_hdr_t; -typedef struct { +struct core_nt_file_entry_s +{ unsigned long start; unsigned long end; unsigned long offset; -} linux_mapinfo_t; +}; +typedef struct core_nt_file_entry_s core_nt_file_entry_t; + + +static const char deleted = "(deleted)"; +static const size_t deleted_len = sizeof (deleted); +static const size_t mapinfo_offset = sizeof (core_nt_file_hdr_t); /** - * Map a file note to program headers + * Handle the CORE/NT_FILE note type. + * @paramin desc The note-specific data + * @paramin arg The user-supplied callback argument * - * If a NT_FILE note is recognized, parse it and add the resulting backing files - * to the program header list. + * The CORE/NT_FILE note type contains a list of start/end virtual addresses + * within the core file and an associated filename. The purpose is to map + * various segments loaded into memory from ELF files with the ELF file from + * which those segments were loaded. + * + * This function links the file namess mapped in the CORE/NT_FILE note with + * the program headers in the core file through the UCD_info file table. * * Any file names that end in the string "(deleted)" are ignored. */ static int -_handle_file_note(uint32_t n_namesz, uint32_t n_descsz, uint32_t n_type, char *name, uint8_t *desc, void *arg) +_handle_nt_file_note (uint8_t *desc, void *arg) { struct UCD_info *ui = (struct UCD_info *)arg; -#ifdef NT_FILE - if (n_type == NT_FILE) - { - Debug(0, "found a PT_FILE note\n"); - static const char * deleted = "(deleted)"; - size_t deleted_len = strlen(deleted); - static const size_t mapinfo_offset = sizeof(linux_mapinfo_hdr_t); - - linux_mapinfo_hdr_t *mapinfo = (linux_mapinfo_hdr_t *)desc; - linux_mapinfo_t *maps = (linux_mapinfo_t *)(desc + mapinfo_offset); - char *strings = (char *)(desc + mapinfo_offset + sizeof(linux_mapinfo_t)*mapinfo->count); - for (unsigned long i = 0; i < mapinfo->count; ++i) + core_nt_file_hdr_t *mapinfo = (core_nt_file_hdr_t *)desc; + core_nt_file_entry_t *maps = (core_nt_file_entry_t *) (desc + mapinfo_offset); + char *strings = (char *) (desc + mapinfo_offset + sizeof (core_nt_file_entry_t) * mapinfo->count); + + for (unsigned long i = 0; i < mapinfo->count; ++i) { - size_t len = strlen(strings); + size_t len = strlen (strings); + for (unsigned p = 0; p < ui->phdrs_count; ++p) - { - if (ui->phdrsp.p_type == PT_LOAD - && mapsi.start >= ui->phdrsp.p_vaddr - && mapsi.end <= ui->phdrsp.p_vaddr + ui->phdrsp.p_filesz) - { - if (len > deleted_len && memcmp(strings + len - deleted_len, deleted, deleted_len)) - { - _UCD_add_backing_file_at_segment(ui, p, strings); - } - break; - } - } + { + if (ui->phdrsp.p_type == PT_LOAD + && mapsi.start >= ui->phdrsp.p_vaddr + && mapsi.end <= ui->phdrsp.p_vaddr + ui->phdrsp.p_memsz) + { + if (len > deleted_len && memcmp (strings + len - deleted_len, deleted, deleted_len)) + { + ui->phdrsp.p_backing_file_index = ucd_file_table_insert (&ui->ucd_file_table, strings); + Debug (3, "adding '%s' at index %d\n", strings, ui->phdrsp.p_backing_file_index); + } + + break; + } + } + strings += (len + 1); } - } + + return UNW_ESUCCESS; +} + +/** + * Callback to handle notes. + * @paramin n_namesz size of name data + * @paramin n_descsz size of desc data + * @paramin n_type type of note + * @paramin name zero-terminated string, n_namesz bytes plus alignment padding + * @paramin desc note-specific data, n_descsz bytes plus alignment padding + * @paramin arg user-supplied callback argument + * + * Add additional note types here for fun and frolicks. Right now the only note + * type handled is the CORE/NT_FILE note used on GNU/Linux. FreeBSD uses a + * FreeBSD/NT_PROCSTAT_VMMAP note and QNX uses a QNX/QNT_DEBUG_LINK_MAP note for + * similar purposes. Other target OSes probably use something else. + * + * Note interpretation requires both name and type. + */ +static int +_handle_pt_note_segment (uint32_t n_namesz, + uint32_t n_descsz, + uint32_t n_type, + char *name, + uint8_t *desc, + void *arg) +{ +#ifdef NT_FILE + if (n_type == NT_FILE && strcmp (name, "CORE") == 0) + { + return _handle_nt_file_note (desc, arg); + } #endif return UNW_ESUCCESS; } @@ -111,24 +156,25 @@ * fail. */ int -_UCD_get_mapinfo(struct UCD_info *ui, coredump_phdr_t *phdrs, unsigned phdr_size) +_UCD_get_mapinfo (struct UCD_info *ui, coredump_phdr_t *phdrs, unsigned phdr_size) { int ret = UNW_ESUCCESS; /* it's OK if there are no file mappings */ for (unsigned i = 0; i < phdr_size; ++i) - { - if (phdrsi.p_type == PT_NOTE) { - uint8_t *segment; - size_t segment_size; - ret = _UCD_elf_read_segment(ui, &phdrsi, &segment, &segment_size); - if (ret == UNW_ESUCCESS) - { - _UCD_elf_visit_notes(segment, segment_size, _handle_file_note, ui); - free(segment); - } + if (phdrsi.p_type == PT_NOTE) + { + uint8_t *segment; + size_t segment_size; + ret = _UCD_elf_read_segment (ui, &phdrsi, &segment, &segment_size); + + if (ret == UNW_ESUCCESS) + { + _UCD_elf_visit_notes (segment, segment_size, _handle_pt_note_segment, ui); + free (segment); + } + } } - } return ret; }
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/coredump/_UCD_get_proc_name.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/_UCD_get_proc_name.c
Changed
@@ -24,6 +24,57 @@ #include "_UCD_lib.h" #include "_UCD_internal.h" +#if defined(HAVE_ELF_H) +# include <elf.h> +#elif defined(HAVE_SYS_ELF_H) +# include <sys/elf.h> +#endif + + +static off_t +_get_text_offset (uint8_t *image) +{ + off_t offset = 0; + typedef union + { + Elf32_Ehdr h32; + Elf64_Ehdr h64; + } elf_header_t; + + elf_header_t *elf_header = (elf_header_t *)image; + bool _64bits = (elf_header->h32.e_identEI_CLASS == ELFCLASS64); + off_t e_phofs = _64bits ? elf_header->h64.e_phoff : elf_header->h32.e_phoff; + unsigned e_phnum = _64bits ? elf_header->h64.e_phnum : elf_header->h32.e_phnum; + + for (unsigned i = 0; i < e_phnum; ++i) + { + if (_64bits) + { + Elf64_Phdr *phdr = (Elf64_Phdr *) (image + e_phofs); + + if (phdri.p_type == PT_LOAD && (phdri.p_flags & PF_X) == PF_X) + { + offset = phdri.p_offset; + break; + } + } + + else + { + Elf32_Phdr *phdr = (Elf32_Phdr *) (image + e_phofs); + + if ((phdri.p_flags & PF_X) == PF_X) + { + offset = phdri.p_offset; + break; + } + } + } + + Debug (4, "returning offset %ld\n", (long)offset); + return offset; +} + /* Find the ELF image that contains IP and return the "closest" procedure name, if there is one. With some caching, this could be @@ -31,30 +82,28 @@ sensitive to the performance of this routine, why bother... */ static int elf_w (CD_get_proc_name) (struct UCD_info *ui, unw_addr_space_t as, unw_word_t ip, - char *buf, size_t buf_len, unw_word_t *offp) + char *buf, size_t buf_len, unw_word_t *offp) { unsigned long segbase, mapoff; int ret; - - /* We're about to map an elf image. If there is an elf image currently mapped, - then make sure to unmap it. */ - invalidate_edi(&ui->edi); - + /* We're about to map an elf image. + The call will unmap memory it doesn't own, so just null it out and avoid + that. */ + ui->edi.ei.image = NULL; + invalidate_edi (&ui->edi); /* Used to be tdep_get_elf_image() in ptrace unwinding code */ - coredump_phdr_t *cphdr = _UCD_get_elf_image(ui, ip); + coredump_phdr_t *cphdr = _UCD_get_elf_image (ui, ip); + if (!cphdr) { - Debug(1, "returns error: _UCD_get_elf_image failed\n"); + Debug (1, "returns error: _UCD_get_elf_image failed\n"); return -UNW_ENOINFO; } - /* segbase: where it is mapped in virtual memory */ - /* mapoff: offset in the file */ - segbase = cphdr->p_vaddr; - /*mapoff = phdr->p_offset; WRONG! phdr->p_offset is the offset in COREDUMP file */ - mapoff = 0; - - ret = elf_w (get_proc_name_in_image) (as, &ui->edi.ei, segbase, mapoff, ip, buf, buf_len, offp); + segbase = 0; /* everything is relative to the beginning of the ELF file */ + /* Adjust IP to be relative to start of the .text section of the ELF file */ + ip = ip - cphdr->p_vaddr + _get_text_offset (ui->edi.ei.image); + ret = elf_w (get_proc_name_in_image) (as, &ui->edi.ei, segbase, ip, buf, buf_len, offp); return ret; } @@ -63,7 +112,6 @@ char *buf, size_t buf_len, unw_word_t *offp, void *arg) { struct UCD_info *ui = arg; - #if UNW_ELF_CLASS == UNW_ELFCLASS64 return _Uelf64_CD_get_proc_name (ui, as, ip, buf, buf_len, offp); #elif UNW_ELF_CLASS == UNW_ELFCLASS32
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/coredump/_UCD_get_threadinfo_prstatus.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/_UCD_get_threadinfo_prstatus.c
Changed
@@ -62,9 +62,15 @@ struct UCD_info *ui = (struct UCD_info *)arg; if (n_type == NT_PRSTATUS) { - memcpy(&ui->threadsui->n_threads, desc, sizeof(struct PRSTATUS_STRUCT)); + memcpy(&ui->threadsui->n_threads.prstatus, desc, sizeof(UCD_proc_status_t)); ++ui->n_threads; } + if (n_type == NT_FPREGSET) + { +#ifdef HAVE_ELF_FPREGSET_T + memcpy(&ui->threadsui->n_threads-1.fpregset, desc, sizeof(elf_fpregset_t)); +#endif + } return UNW_ESUCCESS; } @@ -89,33 +95,33 @@ int ret = -UNW_ENOINFO; for (unsigned i = 0; i < phdr_size; ++i) - { - Debug(8, "phdr%03d: type:%d", i, phdrsi.p_type); - if (phdrsi.p_type == PT_NOTE) { - size_t thread_count = 0; - uint8_t *segment; - size_t segment_size; - ret = _UCD_elf_read_segment(ui, &phdrsi, &segment, &segment_size); - if (ret == UNW_ESUCCESS) - { - _UCD_elf_visit_notes(segment, segment_size, _count_thread_notes, &thread_count); - Debug(2, "found %zu threads\n", thread_count); + Debug(8, "phdr%03d: type:%d", i, phdrsi.p_type); + if (phdrsi.p_type == PT_NOTE) + { + size_t thread_count = 0; + uint8_t *segment; + size_t segment_size; + ret = _UCD_elf_read_segment(ui, &phdrsi, &segment, &segment_size); + if (ret == UNW_ESUCCESS) + { + _UCD_elf_visit_notes(segment, segment_size, _count_thread_notes, &thread_count); + Debug(2, "found %zu threads\n", thread_count); - size_t new_size = sizeof(struct PRSTATUS_STRUCT) * (ui->n_threads + thread_count); - ui->threads = realloc(ui->threads, new_size); - if (ui->threads == NULL) - { - Debug(0, "error allocating %zu bytes of memory \n", new_size); - free(segment); - return -UNW_EUNSPEC; - } - _UCD_elf_visit_notes(segment, segment_size, _save_thread_notes, ui); + size_t new_size = sizeof(struct UCD_thread_info) * (ui->n_threads + thread_count); + ui->threads = realloc(ui->threads, new_size); + if (ui->threads == NULL) + { + Debug(0, "error allocating %zu bytes of memory \n", new_size); + free(segment); + return -UNW_EUNSPEC; + } + _UCD_elf_visit_notes(segment, segment_size, _save_thread_notes, ui); - free(segment); - } + free(segment); + } + } } - } return ret; }
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/coredump/_UCD_internal.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/_UCD_internal.h
Changed
@@ -34,6 +34,9 @@ #ifdef HAVE_SYS_PROCFS_H #include <sys/procfs.h> /* struct elf_prstatus */ #endif +#ifdef HAVE_ASM_PTRACE_H +#include <asm/ptrace.h> /* struct user_regs_struct on s390x */ +#endif #include <errno.h> #include <string.h> #include <limits.h> @@ -43,6 +46,7 @@ #include <libunwind-coredump.h> #include "libunwind_i.h" +#include "ucd_file_table.h" #if SIZEOF_OFF_T == 4 @@ -59,41 +63,52 @@ */ struct coredump_phdr { - uint32_t p_type; - uint32_t p_flags; - uoff_t p_offset; - uoff_t p_vaddr; - uoff_t p_filesz; - uoff_t p_memsz; - uoff_t p_align; - /* Data for backing file. If backing_fd < 0, there is no file */ - uoff_t backing_filesize; - char *backing_filename; /* for error meesages only */ - int backing_fd; + uint32_t p_type; + uint32_t p_flags; + uoff_t p_offset; + uoff_t p_vaddr; + uoff_t p_filesz; + uoff_t p_memsz; + uoff_t p_align; + ucd_file_index_t p_backing_file_index; }; typedef struct coredump_phdr coredump_phdr_t; #if defined(HAVE_STRUCT_ELF_PRSTATUS) -#define PRSTATUS_STRUCT elf_prstatus +typedef struct elf_prstatus UCD_proc_status_t; #elif defined(HAVE_STRUCT_PRSTATUS) -#define PRSTATUS_STRUCT prstatus +typedef struct prstatus UCD_proc_status_t; +#elif defined(HAVE_PROCFS_STATUS) +typedef procfs_status UCD_proc_status_t; #else -#define PRSTATUS_STRUCT non_existent +# error UCD_proc_status_t undefined +#endif + +struct UCD_thread_info + { + UCD_proc_status_t prstatus; +#ifdef HAVE_ELF_FPREGSET_T + elf_fpregset_t fpregset; #endif + }; struct UCD_info { - int big_endian; /* bool */ - int coredump_fd; - char *coredump_filename; /* for error meesages only */ - coredump_phdr_t *phdrs; /* array, allocated */ - unsigned phdrs_count; - void *note_phdr; /* allocated or NULL */ - struct PRSTATUS_STRUCT *prstatus; /* points inside note_phdr */ - int n_threads; - struct PRSTATUS_STRUCT *threads; - struct elf_dyn_info edi; + int big_endian; /* bool */ + int coredump_fd; + char *coredump_filename; /* for error meesages only */ + coredump_phdr_t *phdrs; /* array, allocated */ + unsigned phdrs_count; + ucd_file_table_t ucd_file_table; + void *note_phdr; /* allocated or NULL */ + UCD_proc_status_t *prstatus; /* points inside note_phdr */ +#ifdef HAVE_ELF_FPREGSET_T + elf_fpregset_t *fpregset; +#endif + int n_threads; + struct UCD_thread_info *threads; + struct elf_dyn_info edi; };
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/coredump/_UPT_access_fpreg.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/_UPT_access_fpreg.c
Changed
@@ -28,7 +28,26 @@ _UCD_access_fpreg (unw_addr_space_t as, unw_regnum_t reg, unw_fpreg_t *val, int write, void *arg) { + struct UCD_info *ui UNUSED = arg; + + if (write) + { + Debug(0, "write is not supported\n"); + return -UNW_EINVAL; + } + +#ifdef __s390x__ + if (reg < UNW_S390X_F0 || reg > UNW_S390X_F15) + { + Debug(0, "bad regnum:%d\n", reg); + return -UNW_EINVAL; + } + + *val = ui->fpregset->fprsreg - UNW_S390X_F0.d; + return 0; +#else print_error (__func__); - print_error (" not implemented\n"); + print_error (" not implemented for this architecture\n"); return -UNW_EINVAL; +#endif }
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/ucd_file_table.c
Added
@@ -0,0 +1,275 @@ +/* + * Copyright 2022 Blackberry Limited. + * Contributed by Stephen M. Webb <stephen.webb@bregmasoft.ca> + * + * This file is part of libunwind, a platform-independent unwind library. + * + * 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 AUTHORS OR COPYRIGHT HOLDERS BE + * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION + * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION + * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + */ +#include "ucd_file_table.h" + +#include <errno.h> +#include <fcntl.h> +#include <string.h> +#include <sys/mman.h> +#include <sys/stat.h> +#include <unistd.h> + + +/** + * Initialize a UCD file object. + * @paramin ucd_file The `ucd_file_t` object to initialize. + * @paramin filename Name of a file. + * + * Stores the filename in the object and sets the fd to an uninitialized state. + * + * @returns UNW_ESUCCESS on success, a negated `unw_error_t` code otherwise. + */ +unw_error_t +ucd_file_init (ucd_file_t *ucd_file, char const *filename) +{ + size_t name_size = strlen (filename) + 1; + ucd_file->filename = malloc (name_size); + if (ucd_file->filename == NULL) + { + Debug (0, "error %d from malloc(): %s\n", errno, strerror (errno)); + return (unw_error_t) - UNW_ENOMEM; + } + memcpy ((char *)ucd_file->filename, filename, name_size); + ucd_file->fd = -1; + ucd_file->size = 0; + ucd_file->image = NULL; + + return UNW_ESUCCESS; +} + + +/** + * Dispose of a UCD file object. + * @paramin ucd_file The UCD file to dispose. + * + * Releases any resources sued and sets the object to an uninitialized state. + * + * @returns UNW_ESUCCESS always. + */ +unw_error_t +ucd_file_dispose (ucd_file_t *ucd_file) +{ + ucd_file_unmap(ucd_file); + if (ucd_file->filename != NULL) + { + free ((char *)ucd_file->filename); + ucd_file->filename = NULL; + } + + return UNW_ESUCCESS; +} + + +/** + * Opens a UCD file and gets its size + */ +static void +_ucd_file_open (ucd_file_t *ucd_file) +{ + ucd_file->fd = open(ucd_file->filename, O_RDONLY); + if (ucd_file->fd == -1) + { + Debug(0, "error %d in open(%s): %s\n", errno, ucd_file->filename, strerror(errno)); + } + + struct stat sbuf; + int sstat = fstat(ucd_file->fd, &sbuf); + if (sstat != 0) + { + Debug(0, "error %d in fstat(%s): %s\n", errno, ucd_file->filename, strerror(errno)); + close(ucd_file->fd); + ucd_file->fd = -1; + } + ucd_file->size = sbuf.st_size; +} + + +/** + * Memory-maps a UCD file + */ +uint8_t * +ucd_file_map (ucd_file_t *ucd_file) +{ + if (ucd_file->image != NULL) + { + Debug(0, "warning, file \"%s\" already loaded\n", ucd_file->filename); + return ucd_file->image; + } + + if (ucd_file->fd == -1) + { + _ucd_file_open (ucd_file); + } + + ucd_file->image = mmap(NULL, ucd_file->size, PROT_READ, MAP_PRIVATE, ucd_file->fd, 0); + if (ucd_file->image == MAP_FAILED) + { + Debug(0, "error %d in mmap(%s): %s\n", errno, ucd_file->filename, strerror(errno)); + ucd_file->image = NULL; + return NULL; + } + return ucd_file->image; +} + + +void +ucd_file_unmap (ucd_file_t *ucd_file) +{ + if (ucd_file->image != NULL) + { + munmap(ucd_file->image, ucd_file->size); + ucd_file->image = NULL; + ucd_file->size = 0; + } + if (ucd_file->fd != -1) + { + close(ucd_file->fd); + ucd_file->fd = -1; + } +} + + +/** + * Initialize a UCD file table. + * @paramin ucd_file_table The UCD file table to initialize. + * + * @returns UNW_ESUCCESS on success, a negated `unw_error_t` code otherwise. + */ +unw_error_t +ucd_file_table_init (ucd_file_table_t *ucd_file_table) +{ + ucd_file_table->uft_count = 0; + ucd_file_table->uft_size = 2; + ucd_file_table->uft_files = calloc (ucd_file_table->uft_size, + sizeof (ucd_file_t)); + + if (ucd_file_table->uft_files == NULL) + { + Debug (0, "error %d from malloc(): %s\n", errno, strerror (errno)); + return (unw_error_t) - UNW_ENOMEM; + } + + return UNW_ESUCCESS; +} + + +/** + * Dispose of a UCD file table object. + * @paramin ucd_file_table The UCD file table to dispose. + * + * Releases any resources used and sets the object to an uninitialized state. + * + * @returns UNW_ESUCCESS always. + */ +unw_error_t +ucd_file_table_dispose (ucd_file_table_t *ucd_file_table) +{ + if (ucd_file_table->uft_files != NULL) + { + for (size_t i = 0; i < ucd_file_table->uft_count; ++i) + { + ucd_file_dispose(&ucd_file_table->uft_filesi); + } + free (ucd_file_table->uft_files); + ucd_file_table->uft_files = NULL; + } + + ucd_file_table->uft_count = 0; + ucd_file_table->uft_size = 0; + + return UNW_ESUCCESS; +} + + +/** + * Insert a new entry in a UCD file table. + * @paramin ucd_file_table A UCD file table + * @paramin filename The filename to add. + * + * This table doe not allow duplicates: if a filename is already in the table, + * the index of that entry is returned, otherwise a new entry is created and + * the index of the new entry is returned. + * + * @returns the index of the newly-added UCD file, a negative `unw_error_t` + * code indicating failure otherwise. + */ +ucd_file_index_t ucd_file_table_insert (ucd_file_table_t *ucd_file_table, + char const *filename) +{ + for (int i = 0; i < (int)ucd_file_table->uft_count; ++i) + { + if (strcmp (ucd_file_table->uft_filesi.filename, filename) == 0) + { + return i; + } + } + + ucd_file_index_t index = ucd_file_table->uft_count; + ++ucd_file_table->uft_count; + + if (ucd_file_table->uft_count >= ucd_file_table->uft_size) + { + size_t new_size = ucd_file_table->uft_size * 2; + ucd_file_table->uft_files = realloc (ucd_file_table->uft_files, + new_size * sizeof (ucd_file_t)); + if (ucd_file_table->uft_files == NULL) + { + Debug (0, "error %d from malloc(): %s\n", errno, strerror (errno)); + return (unw_error_t) - UNW_ENOMEM; + } + + ucd_file_table->uft_size = new_size; + } + + unw_error_t err = ucd_file_init (&ucd_file_table->uft_filesindex, filename); + if (err != UNW_ESUCCESS) + { + return err; + } + return index; +} + + +/** + * Get an indicated entry from a UCD file table. + * @paramin ucd_file_table A UCD file table + * @paramin index Indicate which entry to retrieve. + * + * @returns a pointer to the indicated UCD file, NULL if the index is out of + * range. + */ +ucd_file_t * +ucd_file_table_at (ucd_file_table_t *ucd_file_table, + ucd_file_index_t index) +{ + if (0 <= index && index < (int)ucd_file_table->uft_count) + { + return &ucd_file_table->uft_filesindex; + } + + return NULL; +} +
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/coredump/ucd_file_table.h
Added
@@ -0,0 +1,83 @@ +/* + * Copyright 2022 Blackberry Limited. + * Contributed by Stephen M. Webb <stephen.webb@bregmasoft.ca> + * + * This file is part of libunwind, a platform-independent unwind library. + * + * 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 AUTHORS OR COPYRIGHT HOLDERS BE + * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION + * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION + * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + */ +#ifndef include_ucd_file_table_h_ +#define include_ucd_file_table_h_ + +#include "libunwind_i.h" + +#include <stdint.h> +#include <sys/types.h> +/** + * Describes a backing file. + * + * A *backing file* is usually the ELF image file that was the source of a + * particular PT_LOAD segment in memory: it could be the program executable or + * it could be a shared library, either resolved through the dynamic loader at + * program start or later through dl_open(). + * + * There may be one or more in-memory segments associated with the same backing + * file. + */ +struct ucd_file_s + { + char const *filename; /**< Name of the file */ + int fd; /**< File descriptor of the file if open, -1 otherwise */ + off_t size; /**< File size in bytyes */ + uint8_t *image; /**< Memory-mapped file image */ + }; + +typedef struct ucd_file_s ucd_file_t; + +HIDDEN unw_error_t ucd_file_init(ucd_file_t *ucd_file, char const *filename); +HIDDEN unw_error_t ucd_file_dispose(ucd_file_t *ucd_file); +HIDDEN uint8_t *ucd_file_map(ucd_file_t *ucd_file); +HIDDEN void ucd_file_unmap(ucd_file_t *ucd_file); + + +/** + * A table of backing files. + * + * Each entry in this table should be unique. + * + * This table is dynamically sized and should grow as required. + */ +struct ucd_file_table_s + { + size_t uft_count; /**< number of valid entries in table */ + size_t uft_size; /**< size (in entries) of the table storage */ + ucd_file_t *uft_files; /**< the table data */ + }; + +typedef struct ucd_file_table_s ucd_file_table_t; +typedef int ucd_file_index_t; +static const ucd_file_index_t ucd_file_no_index = -1; + +HIDDEN unw_error_t ucd_file_table_init(ucd_file_table_t *ucd_file_table); +HIDDEN unw_error_t ucd_file_table_dispose(ucd_file_table_t *ucd_file_table); +HIDDEN ucd_file_index_t ucd_file_table_insert(ucd_file_table_t *ucd_file_table, char const *filename); +HIDDEN ucd_file_t *ucd_file_table_at(ucd_file_table_t *ucd_file_table, ucd_file_index_t index); + +#endif /* include_ucd_file_table_h_ */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/dwarf/Gexpr.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/dwarf/Gexpr.c
Changed
@@ -265,7 +265,7 @@ return -UNW_EINVAL; \ } -// Removed the parentheses on the asignment +// Removed the parentheses on the assignment // to allow the extra stack error check // when x is evaluated # define push(x) \ @@ -530,7 +530,7 @@ Debug (15, "OP_abs\n"); tmp1 = pop (); if (tmp1 & ((unw_word_t) 1 << (8 * dwarf_addr_size (as) - 1))) - tmp1 = -tmp1; + tmp1 = (~tmp1 + 1); push (tmp1); break; @@ -578,7 +578,8 @@ case DW_OP_neg: Debug (15, "OP_neg\n"); - push (-pop ()); + tmp1 = pop (); + push (~tmp1 + 1); break; case DW_OP_not:
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/dwarf/Gfde.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/dwarf/Gfde.c
Changed
@@ -48,6 +48,7 @@ int is_debug_frame, void *arg) { uint8_t version, ch, augstr5, fde_encoding, handler_encoding; + uint8_t address_size, segment_size; unw_word_t len, cie_end_addr, aug_size; uint32_t u32val; uint64_t u64val; @@ -138,6 +139,15 @@ augstri++ = ch; } + if (version > 3) + { + if((ret = dwarf_readu8(as, a, &addr, &address_size, arg)) < 0) + return ret; + + if((ret = dwarf_readu8(as, a, &addr, &segment_size, arg)) < 0) + return ret; + } + if ((ret = dwarf_read_uleb128 (as, a, &addr, &dci->code_align, arg)) < 0 || (ret = dwarf_read_sleb128 (as, a, &addr, &dci->data_align, arg)) < 0) return ret; @@ -213,8 +223,8 @@ return 0; } -/* Extract proc-info from the FDE starting at adress ADDR. - +/* Extract proc-info from the FDE starting at address ADDR. + Pass BASE as zero for eh_frame behaviour, or a pointer to debug_frame base for debug_frame behaviour. */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/dwarf/Gfind_proc_info-lsb.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/dwarf/Gfind_proc_info-lsb.c
Changed
@@ -135,9 +135,9 @@ #if defined(SHF_COMPRESSED) if (shdr->sh_flags & SHF_COMPRESSED) { - unsigned long destSize; Elf_W (Chdr) *chdr = (shdr->sh_offset + ei.image); #ifdef HAVE_ZLIB + unsigned long destSize; if (chdr->ch_type == ELFCOMPRESS_ZLIB) { *bufsize = destSize = chdr->ch_size; @@ -658,7 +658,7 @@ { if (p_dynamic) { - /* For dynamicly linked executables and shared libraries, + /* For dynamically linked executables and shared libraries, DT_PLTGOT is the value that data-relative addresses are relative to for that object. We call this the "gp". */ Elf_W(Dyn) *dyn = (Elf_W(Dyn) *)(p_dynamic->p_vaddr + load_base); @@ -866,9 +866,9 @@ unw_word_t table, size_t table_size, int32_t rel_ip, struct table_entry *e, int32_t *last_ip_offset, void *arg) { - unsigned long table_len = table_size / sizeof (struct table_entry); + size_t table_len = table_size / sizeof (struct table_entry); unw_accessors_t *a = unw_get_accessors_int (as); - unsigned long lo, hi, mid; + size_t lo, hi, mid; unw_word_t e_addr = 0; int32_t start = 0; int ret; @@ -910,15 +910,15 @@ unw_dyn_info_t *di, unw_proc_info_t *pi, int need_unwind_info, void *arg) { - const struct table_entry *e = NULL, *table; + const struct table_entry *e = NULL, *table = NULL; unw_word_t ip_base = 0, segbase = 0, last_ip, fde_addr; unw_accessors_t *a; #ifndef UNW_LOCAL_ONLY struct table_entry ent; #endif int ret; - unw_word_t debug_frame_base; - size_t table_len; + unw_word_t debug_frame_base = 0; + size_t table_len = 0; #ifdef UNW_REMOTE_ONLY assert (is_remote_table(di->format)); @@ -966,7 +966,7 @@ if (as == unw_local_addr_space) { e = lookup (table, table_len, ip - ip_base - di->load_offset); - if (e && &e1 < &tabletable_len) + if (e && &e1 < &tabletable_len / sizeof (unw_word_t)) last_ip = e1.start_ip_offset + ip_base + di->load_offset; else last_ip = di->end_ip;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/dwarf/Gfind_unwind_table.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/dwarf/Gfind_unwind_table.c
Changed
@@ -37,7 +37,7 @@ int dwarf_find_unwind_table (struct elf_dyn_info *edi, unw_addr_space_t as, - char *path, unw_word_t segbase, unw_word_t mapoff, + const char *path, unw_word_t segbase, unw_word_t mapoff, unw_word_t ip) { Elf_W(Phdr) *phdr, *ptxt = NULL, *peh_hdr = NULL, *pdyn = NULL; @@ -50,7 +50,7 @@ unw_accessors_t *a; Elf_W(Ehdr) *ehdr; #if UNW_TARGET_ARM - const Elf_W(Phdr) *parm_exidx = NULL; + const Elf_W(Phdr) *param_exidx = NULL; #endif int i, ret, found = 0; @@ -73,7 +73,7 @@ if (phdri.p_vaddr + phdri.p_memsz > end_ip) end_ip = phdri.p_vaddr + phdri.p_memsz; - if (phdri.p_offset == mapoff) + if ((phdri.p_flags & PF_X) == PF_X) ptxt = phdr + i; if ((uintptr_t) edi->ei.image + phdr->p_filesz > max_load_addr) max_load_addr = (uintptr_t) edi->ei.image + phdr->p_filesz; @@ -92,7 +92,7 @@ #if UNW_TARGET_ARM case PT_ARM_EXIDX: - parm_exidx = phdr + i; + param_exidx = phdr + i; break; #endif @@ -112,7 +112,7 @@ { if (pdyn) { - /* For dynamicly linked executables and shared libraries, + /* For dynamically linked executables and shared libraries, DT_PLTGOT is the value that data-relative addresses are relative to for that object. We call this the "gp". */ Elf_W(Dyn) *dyn = (Elf_W(Dyn) *)(pdyn->p_offset @@ -212,14 +212,14 @@ } #if UNW_TARGET_ARM - if (parm_exidx) + if (param_exidx) { edi->di_arm.format = UNW_INFO_FORMAT_ARM_EXIDX; edi->di_arm.start_ip = start_ip; edi->di_arm.end_ip = end_ip; edi->di_arm.u.rti.name_ptr = to_unw_word (path); - edi->di_arm.u.rti.table_data = load_base + parm_exidx->p_vaddr; - edi->di_arm.u.rti.table_len = parm_exidx->p_memsz; + edi->di_arm.u.rti.table_data = load_base + param_exidx->p_vaddr; + edi->di_arm.u.rti.table_len = param_exidx->p_memsz; found = 1; } #endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/dwarf/Gparser.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/dwarf/Gparser.c
Changed
@@ -87,6 +87,13 @@ pop_rstate_stack(rs_stack); } +#ifdef UNW_TARGET_AARCH64 + +static void +aarch64_negate_ra_sign_state(dwarf_state_record_t *sr); + +#endif + /* Run a CFI program to update the register state. */ static int run_cfi_program (struct dwarf_cursor *c, dwarf_state_record_t *sr, @@ -390,9 +397,9 @@ if (((ret = read_regnum (as, a, addr, ®num, arg)) < 0) || ((ret = dwarf_read_uleb128 (as, a, addr, &val, arg)) < 0)) break; - set_reg (sr, regnum, DWARF_WHERE_CFAREL, -(val * dci->data_align)); + set_reg (sr, regnum, DWARF_WHERE_CFAREL, ~(val * dci->data_align) + 1); Debug (15, "CFA_GNU_negative_offset_extended cfa+0x%lx\n", - (long) -(val * dci->data_align)); + (long) (~(val * dci->data_align) + 1)); break; case DW_CFA_GNU_window_save: @@ -404,6 +411,11 @@ (regnum - 16) * sizeof (unw_word_t)); Debug (15, "CFA_GNU_window_save\n"); break; +#elif UNW_TARGET_AARCH64 + /* This is a specific opcode on aarch64, DW_CFA_AARCH64_negate_ra_state */ + Debug (15, "DW_CFA_AARCH64_negate_ra_state\n"); + aarch64_negate_ra_sign_state(sr); + break; #else /* FALL THROUGH */ #endif @@ -508,6 +520,11 @@ for (i = 0; i < DWARF_NUM_PRESERVED_REGS + 2; ++i) set_reg (sr, i, DWARF_WHERE_SAME, 0); +#if !defined(UNW_TARGET_ARM) && !(defined(UNW_TARGET_MIPS) && _MIPS_SIM == _ABI64) + // SP defaults to CFA (but is overridable) + set_reg (sr, TDEP_DWARF_SP, DWARF_WHERE_CFA, 0); +#endif + struct dwarf_cie_info *dci = c->pi.unwind_info; sr->rs_current.ret_addr_column = dci->ret_addr_column; unw_word_t addr = dci->cie_instr_start; @@ -764,6 +781,61 @@ return 0; } + +#ifdef UNW_TARGET_AARCH64 +#include "libunwind-aarch64.h" + +static void +aarch64_negate_ra_sign_state(dwarf_state_record_t *sr) +{ + unw_word_t ra_sign_state = sr->rs_current.reg.valUNW_AARCH64_RA_SIGN_STATE; + ra_sign_state ^= 0x1; + set_reg(sr, UNW_AARCH64_RA_SIGN_STATE, DWARF_WHERE_SAME, ra_sign_state); +} + +static unw_word_t +aarch64_strip_pac_remote(unw_accessors_t *a, unw_addr_space_t as, void *arg, unw_word_t old_ip) +{ + if (a->ptrauth_insn_mask) + { + unw_word_t ip, insn_mask; + + insn_mask = a->ptrauth_insn_mask(as, arg); + ip = old_ip & (~insn_mask); + + Debug(15, "stripping pac from address, before: %lx, after: %lx\n", old_ip, ip); + return ip; + } + else + { + Debug(15, "return address %lx might be signed, but no means to obtain mask\n", old_ip); + return old_ip; + } +} + +static unw_word_t +aarch64_strip_pac_local(unw_word_t in_addr) +{ + unw_word_t out_addr = in_addr; + +#if defined(__aarch64__) && !defined(UNW_REMOTE_ONLY) + // Strip the PAC with XPACLRI instruction + register unsigned long long x30 __asm__("x30") = in_addr; + __asm__("hint 0x7" : "+r" (x30)); + out_addr = x30; +#endif + + return out_addr; +} + +static unw_word_t +aarch64_get_ra_sign_state(struct dwarf_reg_state *rs) +{ + return rs->reg.valUNW_AARCH64_RA_SIGN_STATE; +} + +#endif + static int apply_reg_state (struct dwarf_cursor *c, struct dwarf_reg_state *rs) { @@ -775,6 +847,15 @@ int i, ret; void *arg; + /* In the case that we have incorrect CFI, the return address column may be + * outside the valid range of data and will read invalid data. Protect + * against the errant read and indicate that we have a bad frame. */ + if (rs->ret_addr_column >= DWARF_NUM_PRESERVED_REGS) { + Dprintf ("%s: return address entry %zu is outside of range of CIE", + __FUNCTION__, rs->ret_addr_column); + return -UNW_EBADFRAME; + } + prev_ip = c->ip; prev_cfa = c->cfa; @@ -792,14 +873,14 @@ /* As a special-case, if the stack-pointer is the CFA and the stack-pointer wasn't saved, popping the CFA implicitly pops the stack-pointer as well. */ - if ((rs->reg.valDWARF_CFA_REG_COLUMN == UNW_TDEP_SP) - && (UNW_TDEP_SP < ARRAY_SIZE(rs->reg.val)) - && (rs->reg.whereUNW_TDEP_SP == DWARF_WHERE_SAME)) + if ((rs->reg.valDWARF_CFA_REG_COLUMN == TDEP_DWARF_SP) + && (TDEP_DWARF_SP < ARRAY_SIZE(rs->reg.val)) + && (DWARF_IS_NULL_LOC(c->locTDEP_DWARF_SP))) cfa = c->cfa; else { regnum = dwarf_to_unw_regnum (rs->reg.valDWARF_CFA_REG_COLUMN); - if ((ret = unw_get_reg ((unw_cursor_t *) c, regnum, &cfa)) < 0) + if ((ret = unw_get_reg (dwarf_to_cursor(c), regnum, &cfa)) < 0) return ret; } cfa += rs->reg.valDWARF_CFA_OFF_COLUMN; @@ -836,6 +917,10 @@ case DWARF_WHERE_SAME: break; + case DWARF_WHERE_CFA: + new_loci = DWARF_VAL_LOC (c, cfa); + break; + case DWARF_WHERE_CFAREL: new_loci = DWARF_MEM_LOC (c, cfa + rs->reg.vali); break; @@ -885,6 +970,19 @@ ret = dwarf_get (c, c->locrs->ret_addr_column, &ip); if (ret < 0) return ret; +#ifdef UNW_TARGET_AARCH64 + if (aarch64_get_ra_sign_state(rs)) + { + if (c->as != unw_local_addr_space) + { + ip = aarch64_strip_pac_remote(a, as, arg, ip); + } + else + { + ip = aarch64_strip_pac_local(ip); + } + } +#endif c->ip = ip; ret = 1; } @@ -907,7 +1005,7 @@ static int find_reg_state (struct dwarf_cursor *c, dwarf_state_record_t *sr) { - dwarf_reg_state_t *rs; + dwarf_reg_state_t *rs = NULL; struct dwarf_rs_cache *cache; int ret = 0; intrmask_t saved_mask; @@ -953,13 +1051,11 @@ cache->linksc->prev_rs.hint = index + 1; c->prev_rs = index; } + if (ret >= 0) + tdep_reuse_frame (c, cache->linksindex.signal_frame); put_rs_cache (c->as, cache, &saved_mask); } - if (ret < 0) - return ret; - if (cache) - tdep_reuse_frame (c, cache->linksindex.signal_frame); - return 0; + return ret; } /* The function finds the saved locations and applies the register @@ -985,6 +1081,7 @@ args_size, and set cursor appropriately. Only needed for unw_resume */ dwarf_state_record_t sr; + sr.args_size = 0; int ret; /* Lookup it up the slow way... */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/elfxx.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/elfxx.c
Changed
@@ -158,14 +158,13 @@ } static Elf_W (Addr) -elf_w (get_load_offset) (struct elf_image *ei, unsigned long segbase, - unsigned long mapoff) +elf_w (get_load_offset) (struct elf_image *ei, unsigned long segbase) { Elf_W (Addr) offset = 0; Elf_W (Ehdr) *ehdr; Elf_W (Phdr) *phdr; int i; - // mapoff is obtained from mmap informations, so is always aligned on a page size. + // mapoff is obtained from mmap information, so it is always aligned on a page size. // PT_LOAD program headers p_offset however is not guaranteed to be aligned on a // page size, ld.lld generate libraries where this is not the case. So we must // make sure we compare both values with the same alignment. @@ -175,7 +174,7 @@ phdr = (Elf_W (Phdr) *) ((char *) ei->image + ehdr->e_phoff); for (i = 0; i < ehdr->e_phnum; ++i) - if (phdri.p_type == PT_LOAD && (phdri.p_offset & pagesize_alignment_mask) == mapoff) + if (phdri.p_type == PT_LOAD && phdri.p_flags & PF_X) { offset = segbase - phdri.p_vaddr + (phdri.p_offset & (~pagesize_alignment_mask)); break; @@ -276,7 +275,6 @@ HIDDEN int elf_w (get_proc_name_in_image) (unw_addr_space_t as, struct elf_image *ei, unsigned long segbase, - unsigned long mapoff, unw_word_t ip, char *buf, size_t buf_len, unw_word_t *offp) { @@ -284,7 +282,7 @@ Elf_W (Addr) min_dist = ~(Elf_W (Addr))0; int ret; - load_offset = elf_w (get_load_offset) (ei, segbase, mapoff); + load_offset = elf_w (get_load_offset) (ei, segbase); ret = elf_w (lookup_symbol) (as, ip, ei, load_offset, buf, buf_len, &min_dist); /* If the ELF image has MiniDebugInfo embedded in it, look up the symbol in @@ -328,7 +326,7 @@ if (ret < 0) return ret; - ret = elf_w (get_proc_name_in_image) (as, &ei, segbase, mapoff, ip, buf, buf_len, offp); + ret = elf_w (get_proc_name_in_image) (as, &ei, segbase, ip, buf, buf_len, offp); munmap (ei.image, ei.size); ei.image = NULL;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/elfxx.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/elfxx.h
Changed
@@ -50,7 +50,6 @@ extern int elf_w (get_proc_name_in_image) (unw_addr_space_t as, struct elf_image *ei, unsigned long segbase, - unsigned long mapoff, unw_word_t ip, char *buf, size_t buf_len, unw_word_t *offp);
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/ia64/Gscript.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/ia64/Gscript.c
Changed
@@ -287,7 +287,7 @@ { case IA64_WHERE_FR: /* Note: There is no need to handle NaT-bit info here - (indepent of is_preserved_gr), because for floating-point + (independent of is_preserved_gr), because for floating-point NaTs are represented as NaTVal, so the NaT-info never needs to be consulated. */ if (rval >= 2 && rval <= 5)
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/ia64/Gtables.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/ia64/Gtables.c
Changed
@@ -531,7 +531,7 @@ if (p_dynamic) { - /* For dynamicly linked executables and shared libraries, + /* For dynamically linked executables and shared libraries, DT_PLTGOT is the gp value for that object. */ Elf64_Dyn *dyn = (Elf64_Dyn *)(p_dynamic->p_vaddr + load_base); for (; dyn->d_tag != DT_NULL; ++dyn)
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64
Added
+(directory)
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Gapply_reg_state.c
Added
@@ -0,0 +1,37 @@ +/* libunwind - a platform-independent unwind library + Copyright (c) 2002-2003 Hewlett-Packard Development Company, L.P. + Contributed by David Mosberger-Tang <davidm@hpl.hp.com> + + Modified for x86_64 by Max Asbock <masbock@us.ibm.com> + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "unwind_i.h" + +int +unw_apply_reg_state (unw_cursor_t *cursor, + void *reg_states_data) +{ + struct cursor *c = (struct cursor *) cursor; + + return dwarf_apply_reg_state (&c->dwarf, (dwarf_reg_state_t *)reg_states_data); +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Gcreate_addr_space.c
Added
@@ -0,0 +1,52 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include <stdlib.h> + +#include "unwind_i.h" + +unw_addr_space_t +unw_create_addr_space (unw_accessors_t *a, int byte_order) +{ +#ifdef UNW_LOCAL_ONLY + return NULL; +#else + unw_addr_space_t as; + + /* LoongArch64 supports only little-endian. */ + if (byte_order != 0 && byte_order != __LITTLE_ENDIAN) + return NULL; + + as = malloc (sizeof (*as)); + if (!as) + return NULL; + + memset (as, 0, sizeof (*as)); + + as->acc = *a; + + return as; +#endif +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Gget_proc_info.c
Added
@@ -0,0 +1,44 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "unwind_i.h" + +int +unw_get_proc_info (unw_cursor_t *cursor, unw_proc_info_t *pi) +{ + struct cursor *c = (struct cursor *) cursor; + int ret; + + ret = dwarf_make_proc_info (&c->dwarf); + if (ret < 0) { + /* Construct a dummy proc info if Dwarf failed */ + memset (pi, 0, sizeof (*pi)); + pi->start_ip = c->dwarf.ip; + pi->end_ip = c->dwarf.ip + 4; + return 0; + } + + *pi = c->dwarf.pi; + return 0; +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Gget_save_loc.c
Added
@@ -0,0 +1,101 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "unwind_i.h" + +/* FIXME for LoongArch64. */ + +int +unw_get_save_loc (unw_cursor_t *cursor, int reg, unw_save_loc_t *sloc) +{ + struct cursor *c = (struct cursor *) cursor; + dwarf_loc_t loc; + + loc = DWARF_NULL_LOC; /* default to "not saved" */ + + switch (reg) + { + case UNW_LOONGARCH64_R0: + case UNW_LOONGARCH64_R1: + case UNW_LOONGARCH64_R2: + case UNW_LOONGARCH64_R3: + case UNW_LOONGARCH64_R4: + case UNW_LOONGARCH64_R5: + case UNW_LOONGARCH64_R6: + case UNW_LOONGARCH64_R7: + case UNW_LOONGARCH64_R8: + case UNW_LOONGARCH64_R9: + case UNW_LOONGARCH64_R10: + case UNW_LOONGARCH64_R11: + case UNW_LOONGARCH64_R12: + case UNW_LOONGARCH64_R13: + case UNW_LOONGARCH64_R14: + case UNW_LOONGARCH64_R15: + case UNW_LOONGARCH64_R16: + case UNW_LOONGARCH64_R17: + case UNW_LOONGARCH64_R18: + case UNW_LOONGARCH64_R19: + case UNW_LOONGARCH64_R20: + case UNW_LOONGARCH64_R21: + case UNW_LOONGARCH64_R22: + case UNW_LOONGARCH64_R23: + case UNW_LOONGARCH64_R24: + case UNW_LOONGARCH64_R25: + case UNW_LOONGARCH64_R26: + case UNW_LOONGARCH64_R27: + case UNW_LOONGARCH64_R28: + case UNW_LOONGARCH64_R29: + case UNW_LOONGARCH64_R30: + case UNW_LOONGARCH64_R31: + case UNW_LOONGARCH64_PC: + loc = c->dwarf.locreg - UNW_LOONGARCH64_R0; + break; + + default: + break; + } + + memset (sloc, 0, sizeof (*sloc)); + + if (DWARF_IS_NULL_LOC (loc)) + { + sloc->type = UNW_SLT_NONE; + return 0; + } + +#if !defined(UNW_LOCAL_ONLY) + if (DWARF_IS_REG_LOC (loc)) + { + sloc->type = UNW_SLT_REG; + sloc->u.regnum = DWARF_GET_LOC (loc); + } + else +#endif + { + sloc->type = UNW_SLT_MEMORY; + sloc->u.addr = DWARF_GET_LOC (loc); + } + return 0; +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Gglobal.c
Added
@@ -0,0 +1,58 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "unwind_i.h" +#include "dwarf_i.h" + +HIDDEN define_lock (loongarch64_lock); +HIDDEN atomic_bool tdep_init_done; + +HIDDEN void +tdep_init (void) +{ + intrmask_t saved_mask; + + sigfillset (&unwi_full_mask); + + lock_acquire (&loongarch64_lock, saved_mask); + { + if (tdep_init_done) + /* another thread else beat us to it... */ + goto out; + + mi_init (); + + dwarf_init (); + +#ifndef UNW_REMOTE_ONLY + tdep_init_mem_validate (); + + loongarch64_local_addr_space_init (); +#endif + tdep_init_done = 1; /* signal that we're initialized... */ + } + out: + lock_release (&loongarch64_lock, saved_mask); +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Ginit.c
Added
@@ -0,0 +1,400 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include <errno.h> +#include <stdlib.h> +#include <string.h> +#include <sys/mman.h> +#include <stdatomic.h> + +#include "unwind_i.h" + +#ifdef UNW_REMOTE_ONLY + +/* unw_local_addr_space is a NULL pointer in this case. */ +unw_addr_space_t unw_local_addr_space; + +#else /* !UNW_REMOTE_ONLY */ + +static struct unw_addr_space local_addr_space; + +unw_addr_space_t unw_local_addr_space = &local_addr_space; + +static inline void * +uc_addr (ucontext_t *uc, int reg) +{ + if (reg >= UNW_LOONGARCH64_R0 && reg <= UNW_LOONGARCH64_R31) + return &uc->uc_mcontext.__gregsreg - UNW_LOONGARCH64_R0; + else if (reg == UNW_LOONGARCH64_PC) + return &uc->uc_mcontext.__pc; + else + return NULL; +} + +# ifdef UNW_LOCAL_ONLY + +HIDDEN void * +tdep_uc_addr (ucontext_t *uc, int reg) +{ + return uc_addr (uc, reg); +} + +# endif /* UNW_LOCAL_ONLY */ + +static void +put_unwind_info (unw_addr_space_t as, unw_proc_info_t *proc_info, void *arg) +{ + /* it's a no-op */ +} + +static int +get_dyn_info_list_addr (unw_addr_space_t as, unw_word_t *dyn_info_list_addr, + void *arg) +{ +#ifndef UNW_LOCAL_ONLY +# pragma weak _U_dyn_info_list_addr + if (!_U_dyn_info_list_addr) + return -UNW_ENOINFO; +#endif + // Access the `_U_dyn_info_list` from `LOCAL_ONLY` library, i.e. libunwind.so. + *dyn_info_list_addr = _U_dyn_info_list_addr (); + return 0; +} + + +static int mem_validate_pipe2 = {-1, -1}; + +#ifdef HAVE_PIPE2 +static inline void +do_pipe2 (int pipefd2) +{ + pipe2 (pipefd, O_CLOEXEC | O_NONBLOCK); +} +#else +static inline void +set_pipe_flags (int fd) +{ + int fd_flags = fcntl (fd, F_GETFD, 0); + int status_flags = fcntl (fd, F_GETFL, 0); + + fd_flags |= FD_CLOEXEC; + fcntl (fd, F_SETFD, fd_flags); + + status_flags |= O_NONBLOCK; + fcntl (fd, F_SETFL, status_flags); +} + +static inline void +do_pipe2 (int pipefd2) +{ + pipe (pipefd); + set_pipe_flags(pipefd0); + set_pipe_flags(pipefd1); +} +#endif + +static inline void +open_pipe (void) +{ + if (mem_validate_pipe0 != -1) + close (mem_validate_pipe0); + if (mem_validate_pipe1 != -1) + close (mem_validate_pipe1); + + do_pipe2 (mem_validate_pipe); +} + +ALWAYS_INLINE +static int +write_validate (void *addr) +{ + int ret = -1; + ssize_t bytes = 0; + + do + { + char buf; + bytes = read (mem_validate_pipe0, &buf, 1); + } + while ( errno == EINTR ); + + int valid_read = (bytes > 0 || errno == EAGAIN || errno == EWOULDBLOCK); + if (!valid_read) + { + // re-open closed pipe + open_pipe (); + } + + do + { + ret = write (mem_validate_pipe1, addr, 1); + } + while ( errno == EINTR ); + + return ret; +} + +static int (*mem_validate_func) (void *addr, size_t len); +static int msync_validate (void *addr, size_t len) +{ + if (msync (addr, len, MS_ASYNC) != 0) + { + return -1; + } + + return write_validate (addr); +} + +#ifdef HAVE_MINCORE +static int mincore_validate (void *addr, size_t len) +{ + unsigned char mvec2; /* Unaligned access may cross page boundary */ + + /* mincore could fail with EAGAIN but we conservatively return -1 + instead of looping. */ + if (mincore (addr, len, (unsigned char *)mvec) != 0) + { + return -1; + } + + return write_validate (addr); +} +#endif + +/* Initialise memory validation method. On linux kernels <2.6.21, + mincore() returns incorrect value for MAP_PRIVATE mappings, + such as stacks. If mincore() was available at compile time, + check if we can actually use it. If not, use msync() instead. */ +HIDDEN void +tdep_init_mem_validate (void) +{ + open_pipe (); + +#ifdef HAVE_MINCORE + unsigned char present = 1; + size_t len = unw_page_size; + unw_word_t addr = uwn_page_start((unw_word_t)&present); + unsigned char mvec1; + int ret; + while ((ret = mincore ((void*)addr, len, (unsigned char *)mvec)) == -1 && + errno == EAGAIN) + { + } + if (ret == 0) + { + Debug(1, "using mincore to validate memory\n"); + mem_validate_func = mincore_validate; + } + else +#endif + { + Debug(1, "using msync to validate memory\n"); + mem_validate_func = msync_validate; + } +} + +/* Cache of already validated addresses */ +#define NLGA 4 +#if defined(HAVE___CACHE_PER_THREAD) && HAVE___CACHE_PER_THREAD +// thread-local variant +static _Thread_local unw_word_t last_good_addrNLGA; +static _Thread_local int lga_victim; + +static int +is_cached_valid_mem(unw_word_t addr) +{ + int i; + for (i = 0; i < NLGA; i++) + { + if (addr == last_good_addri) + return 1; + } + return 0; +} + +static void +cache_valid_mem(unw_word_t addr) +{ + int i, victim; + victim = lga_victim; + for (i = 0; i < NLGA; i++) { + if (last_good_addrvictim == 0) { + last_good_addrvictim = addr; + return; + } + victim = (victim + 1) % NLGA; + } + + /* All slots full. Evict the victim. */ + last_good_addrvictim = addr; + victim = (victim + 1) % NLGA; + lga_victim = victim; +} + +#else +// global, thread safe variant +static _Atomic unw_word_t last_good_addrNLGA; +static _Atomic int lga_victim; + +static int +is_cached_valid_mem(unw_word_t addr) +{ + int i; + for (i = 0; i < NLGA; i++) + { + if (addr == atomic_load(&last_good_addri)) + return 1; + } + return 0; +} + +static void +cache_valid_mem(unw_word_t addr) +{ + int i, victim; + victim = atomic_load(&lga_victim); + unw_word_t zero = 0; + for (i = 0; i < NLGA; i++) { + if (atomic_compare_exchange_strong(&last_good_addrvictim, &zero, addr)) { + return; + } + victim = (victim + 1) % NLGA; + } + + /* All slots full. Evict the victim. */ + atomic_store(&last_good_addrvictim, addr); + victim = (victim + 1) % NLGA; + atomic_store(&lga_victim, victim); +} +#endif + +static int +validate_mem (unw_word_t addr) +{ + size_t len = unw_page_size; + addr = uwn_page_start(addr); + + if (addr == 0) + return -1; + + if (is_cached_valid_mem(addr)) + return 0; + + if (mem_validate_func ((void *) addr, len) == -1) + return -1; + + cache_valid_mem(addr); + + return 0; +} + +static int +access_mem (unw_addr_space_t as, unw_word_t addr, unw_word_t *val, int write, + void *arg) +{ + if (unlikely (write)) + { + Debug (16, "mem%llx <- %llx\n", (long long) addr, (long long) *val); + *(unw_word_t *) (intptr_t) addr = *val; + } + else + { + /* validate address */ + const struct cursor *c = (const struct cursor *)arg; + if (likely (c != NULL) && unlikely (c->validate) + && unlikely (validate_mem (addr))) { + Debug (16, "mem%016lx -> invalid\n", addr); + return -1; + } + *val = *(unw_word_t *) (intptr_t) addr; + Debug (16, "mem%llx -> %llx\n", (long long) addr, (long long) *val); + } + return 0; +} + +static int +access_reg (unw_addr_space_t as, unw_regnum_t reg, unw_word_t *val, int write, + void *arg) +{ + unw_word_t *addr; + ucontext_t *uc = ((struct cursor *)arg)->uc; + + if (unw_is_fpreg (reg)) + goto badreg; + + Debug (16, "reg = %s\n", unw_regname (reg)); + if (!(addr = uc_addr (uc, reg))) + goto badreg; + + if (write) + { + *(unw_word_t *) (intptr_t) addr = (unw_word_t) *val; + Debug (12, "%s <- %llx\n", unw_regname (reg), (long long) *val); + } + else + { + *val = (unw_word_t) *(unw_word_t *) (intptr_t) addr; + Debug (12, "%s -> %llx\n", unw_regname (reg), (long long) *val); + } + return 0; + + badreg: + Debug (1, "bad register number %u\n", reg); + return -UNW_EBADREG; +} + +static int +access_fpreg (unw_addr_space_t as, unw_regnum_t reg, unw_fpreg_t *val, + int write, void *arg) +{ + return 0; +} + +static int +get_static_proc_name (unw_addr_space_t as, unw_word_t ip, + char *buf, size_t buf_len, unw_word_t *offp, + void *arg) +{ + return elf_w (get_proc_name) (as, getpid (), ip, buf, buf_len, offp); +} + +HIDDEN void +loongarch64_local_addr_space_init (void) +{ + memset (&local_addr_space, 0, sizeof (local_addr_space)); + + local_addr_space.caching_policy = UNW_CACHE_GLOBAL; + local_addr_space.acc.find_proc_info = dwarf_find_proc_info; + local_addr_space.acc.put_unwind_info = put_unwind_info; + local_addr_space.acc.get_dyn_info_list_addr = get_dyn_info_list_addr; + local_addr_space.acc.access_mem = access_mem; + local_addr_space.acc.access_reg = access_reg; + local_addr_space.acc.access_fpreg = access_fpreg; + local_addr_space.acc.resume = loongarch64_local_resume; + local_addr_space.acc.get_proc_name = get_static_proc_name; + unw_flush_cache (&local_addr_space, 0, 0); +} + +#endif /* !UNW_REMOTE_ONLY */
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Ginit_local.c
Added
@@ -0,0 +1,80 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "unwind_i.h" +#include "init.h" + +#ifdef UNW_REMOTE_ONLY + +int +unw_init_local (unw_cursor_t *cursor, ucontext_t *uc) +{ + return -UNW_EINVAL; +} + +#else /* !UNW_REMOTE_ONLY */ + +static int +unw_init_local_common(unw_cursor_t *cursor, ucontext_t *uc, unsigned use_prev_instr) +{ + struct cursor *c = (struct cursor *) cursor; + + if (!atomic_load(&tdep_init_done)) + tdep_init (); + + Debug (1, "(cursor=%p)\n", c); + + c->dwarf.as = unw_local_addr_space; + c->dwarf.as_arg = c; + c->uc = uc; + c->validate = 0; + + return common_init (c, use_prev_instr); +} + +int +unw_init_local(unw_cursor_t *cursor, ucontext_t *uc) +{ + return unw_init_local_common(cursor, uc, 1); +} + +int +unw_init_local2 (unw_cursor_t *cursor, ucontext_t *uc, int flag) +{ + if (!flag) + { + return unw_init_local_common(cursor, uc, 1); + } + else if (flag == UNW_INIT_SIGNAL_FRAME) + { + return unw_init_local_common(cursor, uc, 0); + } + else + { + return -UNW_EINVAL; + } +} + +#endif /* !UNW_REMOTE_ONLY */
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Ginit_remote.c
Added
@@ -0,0 +1,56 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "init.h" +#include "unwind_i.h" + +int +unw_init_remote (unw_cursor_t *cursor, unw_addr_space_t as, void *as_arg) +{ +#ifdef UNW_LOCAL_ONLY + return -UNW_EINVAL; +#else /* !UNW_LOCAL_ONLY */ + struct cursor *c = (struct cursor *) cursor; + + if (!tdep_init_done) + tdep_init (); + + Debug (1, "(cursor=%p)\n", c); + + c->dwarf.as = as; + if (as == unw_local_addr_space) + { + c->dwarf.as_arg = c; + c->uc = as_arg; + } + else + { + c->dwarf.as_arg = as_arg; + c->uc = 0; + } + + return common_init (c, 0); +#endif /* !UNW_LOCAL_ONLY */ +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Gis_signal_frame.c
Added
@@ -0,0 +1,71 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "unwind_i.h" +#include <stdio.h> + +/* + arch/loongarch/vdso/sigreturn.S: + + 0000000000000000 <__vdso_rt_sigreturn>: + 0: 03822c0b ori $r11,$r0,0x8b + 4: 002b0000 syscall 0x0 +*/ + +#define SIGRETURN_W0 0x03822c0b +#define SIGRETURN_W1 0x002b0000 + +int +unw_is_signal_frame (unw_cursor_t *cursor) +{ + struct cursor *c = (struct cursor *) cursor; + unw_word_t w0, w1, ip; + unw_addr_space_t as; + unw_accessors_t *a; + void *arg; + int ret; + + as = c->dwarf.as; + a = unw_get_accessors (as); + arg = c->dwarf.as_arg; + + ip = c->dwarf.ip; + + /* syscall 0x0 */ + if ((ret = (*a->access_mem) (as, ip + 4, &w1, 0, arg)) < 0) + return ret; + + /* ori a7,zero,0x8b */ + if ((ret = (*a->access_mem) (as, ip, &w0, 0, arg)) < 0) + return ret; + + if ((w1 & 0xffffffff) == SIGRETURN_W1 && (w0 & 0xffffffff) == SIGRETURN_W0) + { + Debug (8, "cursor at signal frame\n"); + return 1; + } + + return 0; +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Greg_states_iterate.c
Added
@@ -0,0 +1,37 @@ +/* libunwind - a platform-independent unwind library + Copyright (c) 2002-2003 Hewlett-Packard Development Company, L.P. + Contributed by David Mosberger-Tang <davidm@hpl.hp.com> + + Modified for x86_64 by Max Asbock <masbock@us.ibm.com> + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "unwind_i.h" + +int +unw_reg_states_iterate (unw_cursor_t *cursor, + unw_reg_states_callback cb, void *token) +{ + struct cursor *c = (struct cursor *) cursor; + + return dwarf_reg_states_iterate (&c->dwarf, cb, token); +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Gregs.c
Added
@@ -0,0 +1,109 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "unwind_i.h" + +/* FIXME: The following is probably unfinished and/or at least partly bogus. */ + +HIDDEN int +tdep_access_reg (struct cursor *c, unw_regnum_t reg, unw_word_t *valp, + int write) +{ + dwarf_loc_t loc = DWARF_NULL_LOC; + + switch (reg) + { + case UNW_LOONGARCH64_R0: + case UNW_LOONGARCH64_R1: + case UNW_LOONGARCH64_R2: + + case UNW_LOONGARCH64_R4: + case UNW_LOONGARCH64_R5: + case UNW_LOONGARCH64_R6: + case UNW_LOONGARCH64_R7: + case UNW_LOONGARCH64_R8: + case UNW_LOONGARCH64_R9: + case UNW_LOONGARCH64_R10: + case UNW_LOONGARCH64_R11: + case UNW_LOONGARCH64_R12: + case UNW_LOONGARCH64_R13: + case UNW_LOONGARCH64_R14: + case UNW_LOONGARCH64_R15: + case UNW_LOONGARCH64_R16: + case UNW_LOONGARCH64_R17: + case UNW_LOONGARCH64_R18: + case UNW_LOONGARCH64_R19: + case UNW_LOONGARCH64_R20: + case UNW_LOONGARCH64_R21: + case UNW_LOONGARCH64_R22: + case UNW_LOONGARCH64_R23: + case UNW_LOONGARCH64_R24: + case UNW_LOONGARCH64_R25: + case UNW_LOONGARCH64_R26: + case UNW_LOONGARCH64_R27: + case UNW_LOONGARCH64_R28: + case UNW_LOONGARCH64_R29: + case UNW_LOONGARCH64_R30: + case UNW_LOONGARCH64_R31: + loc = c->dwarf.locreg - UNW_LOONGARCH64_R0; + break; + + case UNW_LOONGARCH64_PC: + if (write) + { + Debug (16, "pc is now 0x%lx\n", *valp); + c->dwarf.ip = *valp; + } + loc = c->dwarf.locreg; + break; + case UNW_TDEP_SP: /* UNW_LOONGARCH64_R3 */ + case UNW_LOONGARCH64_CFA: + if (write) + return -UNW_EREADONLYREG; + *valp = c->dwarf.cfa; + return 0; + + /* FIXME: IP? Copro & shadow registers? */ + + default: + Debug (1, "bad register number %u\n", reg); + return -UNW_EBADREG; + } + + if (write) + return dwarf_put (&c->dwarf, loc, *valp); + else + return dwarf_get (&c->dwarf, loc, valp); + +} + +/* FIXME for LoongArch64. */ + +HIDDEN int +tdep_access_fpreg (struct cursor *c, unw_regnum_t reg, unw_fpreg_t *valp, + int write) +{ + return -UNW_EBADREG; +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Gresume.c
Added
@@ -0,0 +1,126 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +/* FIXME for LoongArch64. */ + +#include <stdlib.h> + +#include "unwind_i.h" + +#ifndef UNW_REMOTE_ONLY + +HIDDEN inline int +loongarch64_local_resume (unw_addr_space_t as, unw_cursor_t *cursor, void *arg) +{ + struct cursor *c = (struct cursor *) cursor; + unw_tdep_context_t *uc = c->uc; + + if (c->sigcontext_format == LOONGARCH64_SCF_NONE) + { + /* Since there are no signals involved here we restore EH and non scratch + registers only. */ + register void *gregs asm("$t0") = uc->uc_mcontext.__gregs; + asm volatile ( + "ld.d $ra, %0, 8\n" + "ld.d $sp, %0, 3*8\n" + "ld.d $fp, %0, 22*8\n" + "ld.d $s0, %0, 23*8\n" + "ld.d $s1, %0, 24*8\n" + "ld.d $s2, %0, 25*8\n" + "ld.d $s3, %0, 26*8\n" + "ld.d $s4, %0, 27*8\n" + "ld.d $s5, %0, 28*8\n" + "ld.d $s6, %0, 29*8\n" + "ld.d $s7, %0, 30*8\n" + "ld.d $s8, %0, 31*8\n" + "jr $ra\n" + : + : "r" (gregs) + ); + unreachable(); + } + else /* c->sigcontext_format == LOONGARCH64_SCF_LINUX_RT_SIGFRAME */ + { + int i; + struct sigcontext *sc = (struct sigcontext *) c->sigcontext_addr; + + sc->sc_pc = c->dwarf.ip; + for (i = UNW_LOONGARCH64_R0; i <= UNW_LOONGARCH64_R31; i++) + sc->sc_regsi = uc->uc_mcontext.__gregsi; + + Debug (8, "resuming at ip=0x%lx via sigreturn() (trampoline @ 0x%lx, sp @ 0x%lx)\n", + c->dwarf.ip, c->sigcontext_pc, c->sigcontext_sp); + + asm volatile ( + "move $sp, %0\n" + "jr %1\n" + : : "r" (c->sigcontext_sp), "r" (c->sigcontext_pc) + ); + } + unreachable(); + + return -UNW_EINVAL; +} + +#endif /* !UNW_REMOTE_ONLY */ + +static inline void +establish_machine_state (struct cursor *c) +{ + unw_addr_space_t as = c->dwarf.as; + void *arg = c->dwarf.as_arg; + unw_word_t val; + int reg; + + Debug (8, "copying out cursor state\n"); + + for (reg = UNW_LOONGARCH64_R0; reg <= UNW_LOONGARCH64_R31; reg++) + { + Debug (16, "copying %s %d\n", unw_regname (reg), reg); + if (tdep_access_reg (c, reg, &val, 0) >= 0) + as->acc.access_reg (as, reg, &val, 1, arg); + } +} + +int +unw_resume (unw_cursor_t *cursor) +{ + struct cursor *c = (struct cursor *) cursor; + + Debug (1, "(cursor=%p)\n", c); + + if (!c->dwarf.ip) + { + /* This can happen easily when the frame-chain gets truncated + due to bad or missing unwind-info. */ + Debug (1, "refusing to resume execution at address 0\n"); + return -UNW_EINVAL; + } + + establish_machine_state (c); + + return (*c->dwarf.as->acc.resume) (c->dwarf.as, (unw_cursor_t *) c, + c->dwarf.as_arg); +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Gstep.c
Added
@@ -0,0 +1,147 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2015 Imagination Technologies Limited + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "unwind_i.h" +#include "offsets.h" + +static int +loongarch64_handle_signal_frame (unw_cursor_t *cursor) +{ + struct cursor *c = (struct cursor *) cursor; + unw_word_t sc_addr, sp_addr = c->dwarf.cfa; + unw_word_t ra, fp; + int i, ret; + + if (unw_is_signal_frame (cursor)) { + sc_addr = sp_addr + sizeof (siginfo_t) + LINUX_UC_MCONTEXT_OFF; + } else { + c->sigcontext_format = LOONGARCH64_SCF_NONE; + return -UNW_EUNSPEC; + } + + c->sigcontext_addr = sc_addr; + + /* Save the SP and PC to be able to return execution at this point + later in time (unw_resume). */ + c->sigcontext_sp = c->dwarf.cfa; + c->sigcontext_pc = c->dwarf.ip; + c->sigcontext_format = LOONGARCH64_SCF_LINUX_RT_SIGFRAME; + + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + + /* Update the dwarf cursor. + Set the location of the registers to the corresponding addresses of the + uc_mcontext / sigcontext structure contents. */ + + c->dwarf.locUNW_LOONGARCH64_R0 = DWARF_LOC (sc_addr + LINUX_SC_R0_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R1 = DWARF_LOC (sc_addr + LINUX_SC_R1_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R2 = DWARF_LOC (sc_addr + LINUX_SC_R2_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R3 = DWARF_LOC (sc_addr + LINUX_SC_R3_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R4 = DWARF_LOC (sc_addr + LINUX_SC_R4_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R5 = DWARF_LOC (sc_addr + LINUX_SC_R5_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R6 = DWARF_LOC (sc_addr + LINUX_SC_R6_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R7 = DWARF_LOC (sc_addr + LINUX_SC_R7_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R8 = DWARF_LOC (sc_addr + LINUX_SC_R8_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R9 = DWARF_LOC (sc_addr + LINUX_SC_R9_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R10 = DWARF_LOC (sc_addr + LINUX_SC_R10_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R11 = DWARF_LOC (sc_addr + LINUX_SC_R11_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R12 = DWARF_LOC (sc_addr + LINUX_SC_R12_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R13 = DWARF_LOC (sc_addr + LINUX_SC_R13_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R14 = DWARF_LOC (sc_addr + LINUX_SC_R14_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R15 = DWARF_LOC (sc_addr + LINUX_SC_R15_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R16 = DWARF_LOC (sc_addr + LINUX_SC_R16_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R17 = DWARF_LOC (sc_addr + LINUX_SC_R17_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R18 = DWARF_LOC (sc_addr + LINUX_SC_R18_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R19 = DWARF_LOC (sc_addr + LINUX_SC_R19_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R20 = DWARF_LOC (sc_addr + LINUX_SC_R20_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R21 = DWARF_LOC (sc_addr + LINUX_SC_R21_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R22 = DWARF_LOC (sc_addr + LINUX_SC_R22_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R23 = DWARF_LOC (sc_addr + LINUX_SC_R23_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R24 = DWARF_LOC (sc_addr + LINUX_SC_R24_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R25 = DWARF_LOC (sc_addr + LINUX_SC_R25_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R26 = DWARF_LOC (sc_addr + LINUX_SC_R26_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R27 = DWARF_LOC (sc_addr + LINUX_SC_R27_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R28 = DWARF_LOC (sc_addr + LINUX_SC_R28_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R29 = DWARF_LOC (sc_addr + LINUX_SC_R29_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R30 = DWARF_LOC (sc_addr + LINUX_SC_R30_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_R31 = DWARF_LOC (sc_addr + LINUX_SC_R31_OFF, 0); + c->dwarf.locUNW_LOONGARCH64_PC = DWARF_LOC (sc_addr + LINUX_SC_PC_OFF, 0); + + /* Set SP/CFA and PC/IP. */ + dwarf_get (&c->dwarf, c->dwarf.locUNW_LOONGARCH64_R3, &c->dwarf.cfa); + + if ((ret = dwarf_get(&c->dwarf, DWARF_LOC(sc_addr + LINUX_SC_PC_OFF, 0), + &c->dwarf.ip)) < 0) + return ret; + + if ((ret = dwarf_get(&c->dwarf, DWARF_LOC(sc_addr + LINUX_SC_R1_OFF, 0), + &ra)) < 0) + return ret; + if ((ret = dwarf_get(&c->dwarf, DWARF_LOC(sc_addr + LINUX_SC_R22_OFF, 0), + &fp)) < 0) + return ret; + + Debug (2, "SH (ip=0x%016llx, ra=0x%016llx, sp=0x%016llx, fp=0x%016llx)\n", + (unsigned long long)c->dwarf.ip, (unsigned long long)ra, + (unsigned long long)c->dwarf.cfa, (unsigned long long)fp); + + c->dwarf.pi_valid = 0; + c->dwarf.use_prev_instr = 0; + + return 1; + +} + +int +unw_step (unw_cursor_t *cursor) +{ + struct cursor *c = (struct cursor *) cursor; + int validate = c->validate; + int ret; + + Debug (1, "(cursor=%p, ip=0x%016lx, sp=0x%016lx)\n", + c, c->dwarf.ip, c->dwarf.cfa); + + ret = unw_is_signal_frame (cursor); + if (ret > 0) + return loongarch64_handle_signal_frame (cursor); + + /* Not a signal frame, try DWARF-based unwinding. */ + ret = dwarf_step (&c->dwarf); + + /* Restore default memory validation state */ + c->validate = validate; + + if (unlikely (ret == -UNW_ESTOPUNWIND)) + return ret; + + /* Dwarf unwinding didn't work, stop. */ + if (unlikely (ret < 0)) + return 0; + + return (c->dwarf.ip == 0) ? 0 : 1; +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Lapply_reg_state.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Gapply_reg_state.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Lcreate_addr_space.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Gcreate_addr_space.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Lget_proc_info.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Gget_proc_info.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Lget_save_loc.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Gget_save_loc.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Lglobal.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Gglobal.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Linit.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Ginit.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Linit_local.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Ginit_local.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Linit_remote.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Ginit_remote.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Lis_signal_frame.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Gis_signal_frame.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Lreg_states_iterate.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Greg_states_iterate.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Lregs.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Gregs.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Lresume.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Gresume.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/Lstep.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Gstep.c" +#endif
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/getcontext.S
Added
@@ -0,0 +1,61 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2012 Tommi Rantala <tt.rantala@gmail.com> + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "offsets.h" +#include <endian.h> + .text + +#define SREG(X) st.d $r##X, $r4, (LINUX_UC_MCONTEXT_GREGS + 8 * X) +#define SPC st.d $r1, $r4, (LINUX_UC_MCONTEXT_PC) + + .global _Uloongarch64_getcontext + .type _Uloongarch64_getcontext, %function + +_Uloongarch64_getcontext: + .cfi_startproc + SREG(0) + SREG(1) + SREG(3) + SREG(21) + SREG(22) + SREG(23) + SREG(24) + SREG(25) + SREG(26) + SREG(27) + SREG(28) + SREG(29) + SREG(30) + SREG(31) + + SPC + + ori $r4, $r0, 0 + jirl $r0, $r1, 0 + + .cfi_endproc + + .size _Uloongarch64_getcontext, .-_Uloongarch64_getcontext
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/init.h
Added
@@ -0,0 +1,64 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "unwind_i.h" + +static inline int +common_init (struct cursor *c, unsigned use_prev_instr) +{ + int ret, i; + + for (i = UNW_LOONGARCH64_R0; i <= UNW_LOONGARCH64_R31; i++) + c->dwarf.loci = DWARF_REG_LOC (&c->dwarf, i); + + for (i = UNW_LOONGARCH64_R31 + 1; i < DWARF_NUM_PRESERVED_REGS; i++) + c->dwarf.loci = DWARF_NULL_LOC; + + c->dwarf.locUNW_LOONGARCH64_PC = DWARF_REG_LOC (&c->dwarf, UNW_LOONGARCH64_PC); + + ret = dwarf_get (&c->dwarf, c->dwarf.locUNW_LOONGARCH64_PC, &c->dwarf.ip); + if (ret < 0) + return ret; + + ret = dwarf_get (&c->dwarf, DWARF_REG_LOC (&c->dwarf, UNW_LOONGARCH64_R3), + &c->dwarf.cfa); + if (ret < 0) + return ret; + + c->sigcontext_format = LOONGARCH64_SCF_NONE; + c->sigcontext_addr = 0; + c->sigcontext_sp = 0; + c->sigcontext_pc = 0; + + c->dwarf.args_size = 0; + c->dwarf.stash_frames = 0; + c->dwarf.use_prev_instr = use_prev_instr; + c->dwarf.pi_valid = 0; + c->dwarf.pi_is_dynamic = 0; + c->dwarf.hint = 0; + c->dwarf.prev_rs = 0; + + return 0; +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/is_fpreg.c
Added
@@ -0,0 +1,35 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "libunwind_i.h" + +/* FIXME: I'm not sure if libunwind's FP register distinction is very useful + on LoongArch64. */ + +int +unw_is_fpreg (int regnum) +{ + /* FIXME: Support FP. */ + return 0; +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/offsets.h
Added
@@ -0,0 +1,50 @@ +/* Linux-specific definitions: */ + +/* Define various structure offsets to simplify cross-compilation. */ + +/* Offsets for LoongArch64 Linux "ucontext_t": */ + +# define LINUX_UC_FLAGS_OFF 0x0 /* offsetof(struct ucontext_t, __uc_flags) */ +# define LINUX_UC_LINK_OFF 0x8 /* offsetof(struct ucontext_t, uc_link) */ +# define LINUX_UC_STACK_OFF 0x10 /* offsetof(struct ucontext_t, uc_stack) */ +# define LINUX_UC_SIGMASK_OFF 0x28 /* offsetof(struct ucontext_t, uc_sigmask) */ +# define LINUX_UC_MCONTEXT_OFF 0xb0 /* offsetof(struct ucontext_t, uc_mcontext) */ + +# define LINUX_UC_MCONTEXT_PC 0xb0 /* offsetof(struct ucontext_t, uc_mcontext.__pc) */ +# define LINUX_UC_MCONTEXT_GREGS 0xb8 /* offsetof(struct ucontext_t, uc_mcontext.__gregs) */ +/* Offsets for LoongArch64 Linux "struct sigcontext": */ +#define LINUX_SC_R0_OFF (LINUX_UC_MCONTEXT_GREGS - LINUX_UC_MCONTEXT_OFF) +#define LINUX_SC_R1_OFF (LINUX_SC_R0_OFF + 1*8) +#define LINUX_SC_R2_OFF (LINUX_SC_R0_OFF + 2*8) +#define LINUX_SC_R3_OFF (LINUX_SC_R0_OFF + 3*8) +#define LINUX_SC_R4_OFF (LINUX_SC_R0_OFF + 4*8) +#define LINUX_SC_R5_OFF (LINUX_SC_R0_OFF + 5*8) +#define LINUX_SC_R6_OFF (LINUX_SC_R0_OFF + 6*8) +#define LINUX_SC_R7_OFF (LINUX_SC_R0_OFF + 7*8) +#define LINUX_SC_R8_OFF (LINUX_SC_R0_OFF + 8*8) +#define LINUX_SC_R9_OFF (LINUX_SC_R0_OFF + 9*8) +#define LINUX_SC_R10_OFF (LINUX_SC_R0_OFF + 10*8) +#define LINUX_SC_R11_OFF (LINUX_SC_R0_OFF + 11*8) +#define LINUX_SC_R12_OFF (LINUX_SC_R0_OFF + 12*8) +#define LINUX_SC_R13_OFF (LINUX_SC_R0_OFF + 13*8) +#define LINUX_SC_R14_OFF (LINUX_SC_R0_OFF + 14*8) +#define LINUX_SC_R15_OFF (LINUX_SC_R0_OFF + 15*8) +#define LINUX_SC_R16_OFF (LINUX_SC_R0_OFF + 16*8) +#define LINUX_SC_R17_OFF (LINUX_SC_R0_OFF + 17*8) +#define LINUX_SC_R18_OFF (LINUX_SC_R0_OFF + 18*8) +#define LINUX_SC_R19_OFF (LINUX_SC_R0_OFF + 19*8) +#define LINUX_SC_R20_OFF (LINUX_SC_R0_OFF + 20*8) +#define LINUX_SC_R21_OFF (LINUX_SC_R0_OFF + 21*8) +#define LINUX_SC_R22_OFF (LINUX_SC_R0_OFF + 22*8) +#define LINUX_SC_R23_OFF (LINUX_SC_R0_OFF + 23*8) +#define LINUX_SC_R24_OFF (LINUX_SC_R0_OFF + 24*8) +#define LINUX_SC_R25_OFF (LINUX_SC_R0_OFF + 25*8) +#define LINUX_SC_R26_OFF (LINUX_SC_R0_OFF + 26*8) +#define LINUX_SC_R27_OFF (LINUX_SC_R0_OFF + 27*8) +#define LINUX_SC_R28_OFF (LINUX_SC_R0_OFF + 28*8) +#define LINUX_SC_R29_OFF (LINUX_SC_R0_OFF + 29*8) +#define LINUX_SC_R30_OFF (LINUX_SC_R0_OFF + 30*8) +#define LINUX_SC_R31_OFF (LINUX_SC_R0_OFF + 31*8) + +#define LINUX_SC_SP_OFF LINUX_SC_R3_OFF +#define LINUX_SC_PC_OFF (LINUX_UC_MCONTEXT_PC - LINUX_UC_MCONTEXT_OFF)
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/regname.c
Added
@@ -0,0 +1,50 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + Copyright (C) 2021 Loongson Technology Corporation Limited + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include "unwind_i.h" + +static const char *regname = + { + /* 0. */ + "zero", "ra", "tp", "sp", "a0(v0)", "a1(v1)", "a2", "a3", + /* 8. */ + "a4", "a5", "a6", "a7", "t0", "t1", "t2", "t3", + /* 16. */ + "t4", "t5", "t6", "t7", "t8", "reserve", "fp", "s0", + /* 24. */ + "s1", "s2", "s3", "s4", "s5", "s6", "s7", "s8", + + /* pc */ + "pc" + }; + +const char * +unw_regname (unw_regnum_t reg) +{ + if (reg < (unw_regnum_t) ARRAY_SIZE (regname)) + return regnamereg; + else + return "???"; +}
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/siglongjmp.S
Added
@@ -0,0 +1,8 @@ + /* Dummy implementation for now. */ + + .globl _UI_siglongjmp_cont + .globl _UI_longjmp_cont + +_UI_siglongjmp_cont: +_UI_longjmp_cont: + jirl $r0, $r1, 0
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/loongarch64/unwind_i.h
Added
@@ -0,0 +1,43 @@ +/* libunwind - a platform-independent unwind library + Copyright (C) 2008 CodeSourcery + +This file is part of libunwind. + +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#ifndef unwind_i_h +#define unwind_i_h + +#include <stdint.h> + +#include <libunwind-loongarch64.h> + +#include "libunwind_i.h" + +#define loongarch64_lock UNW_OBJ(lock) +#define loongarch64_local_resume UNW_OBJ(local_resume) +#define loongarch64_local_addr_space_init UNW_OBJ(local_addr_space_init) + +extern int loongarch64_local_resume (unw_addr_space_t as, unw_cursor_t *cursor, + void *arg); + +extern void loongarch64_local_addr_space_init (void); + +#endif /* unwind_i_h */
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/mi/Gget_proc_info_in_range.c
Added
@@ -0,0 +1,111 @@ +/* Copyright (C) 2022 Hewlett-Packard Co. + Contributed by David Mosberger-Tang <davidm@hpl.hp.com>. +This file is part of libunwind. +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 AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ + +#include <stddef.h> +#include "libunwind_i.h" +#include "dwarf-eh.h" +#include "dwarf_i.h" + +int +unw_get_proc_info_in_range (unw_word_t start_ip, unw_word_t end_ip, + unw_word_t eh_frame_table, unw_word_t eh_frame_table_len, + unw_word_t exidx_frame_table, unw_word_t exidx_frame_table_len, + unw_addr_space_t as, unw_word_t ip, + unw_proc_info_t *pi, int need_unwind_info, + void *arg) +{ + int ret = 0; + + unw_dyn_info_t di; + memset(&di, 0, sizeof(di)); + + di.start_ip = start_ip; + di.end_ip = end_ip; + di.gp = pi->gp; + di.u.rti.name_ptr = 0; + +#if UNW_TARGET_ARM + if (exidx_frame_table != 0) { + di.format = UNW_INFO_FORMAT_ARM_EXIDX; + di.u.rti.table_data = exidx_frame_table; + di.u.rti.table_len = exidx_frame_table_len; + di.u.rti.segbase = 0; + } + else +#endif + if (eh_frame_table != 0) { + unw_accessors_t *a = unw_get_accessors_int (as); + + unw_word_t hdr; + if ((*a->access_mem)(as, eh_frame_table, &hdr, 0, arg) < 0) { + return -UNW_EINVAL; + } + struct dwarf_eh_frame_hdr* exhdr = (struct dwarf_eh_frame_hdr*)&hdr; + + if (exhdr->version != DW_EH_VERSION) { + Debug (1, "Unexpected version %d\n", exhdr->version); + return -UNW_EBADVERSION; + } + unw_word_t addr = eh_frame_table + offsetof(struct dwarf_eh_frame_hdr, eh_frame); + unw_word_t eh_frame_start; + unw_word_t fde_count; + + /* read eh_frame_ptr */ + if ((ret = dwarf_read_encoded_pointer(as, a, &addr, exhdr->eh_frame_ptr_enc, pi, &eh_frame_start, arg)) < 0) { + return ret; + } + + /* read fde_count */ + if ((ret = dwarf_read_encoded_pointer(as, a, &addr, exhdr->fde_count_enc, pi, &fde_count, arg)) < 0) { + return ret; + } + + // If there are no frame table entries + if (fde_count == 0) { + Debug(1, "No frame table entries\n"); + return -UNW_ENOINFO; + } + + if (exhdr->table_enc != (DW_EH_PE_datarel | DW_EH_PE_sdata4)) { + Debug (1, "Table encoding not supported %x\n", exhdr->table_enc); + return -UNW_EINVAL; + } + + di.format = UNW_INFO_FORMAT_REMOTE_TABLE; + di.u.rti.table_data = addr; + di.u.rti.table_len = (fde_count * 8) / sizeof (unw_word_t); + di.u.rti.segbase = eh_frame_table; + } + else { + Debug (1, "No frame table data\n"); + return -UNW_ENOINFO; + } + + ret = tdep_search_unwind_table(as, ip, &di, pi, need_unwind_info, arg); + if (ret < 0) { + return ret; + } + + if (ip < pi->start_ip || ip >= pi->end_ip) { + Debug (1, "ip %p not in range start_ip %p end_ip %p\n", ip, pi->start_ip, pi->end_ip); + return -UNW_ENOINFO; + } + return UNW_ESUCCESS; +}
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/mi/Gget_proc_name.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/mi/Gget_proc_name.c
Changed
@@ -45,9 +45,10 @@ return -UNW_ENOMEM; } -static inline int -get_proc_name (unw_addr_space_t as, unw_word_t ip, - char *buf, size_t buf_len, unw_word_t *offp, void *arg) +int +unw_get_proc_name_by_ip (unw_addr_space_t as, unw_word_t ip, + char *buf, size_t buf_len, unw_word_t *offp, + void *arg) { unw_accessors_t *a = unw_get_accessors_int (as); unw_proc_info_t pi; @@ -116,8 +117,8 @@ #endif - error = get_proc_name (tdep_get_as (c), ip, buf, buf_len, offp, - tdep_get_as_arg (c)); + error = unw_get_proc_name_by_ip (tdep_get_as (c), ip, buf, buf_len, offp, + tdep_get_as_arg (c)); #if !defined(__ia64__) if (c->dwarf.use_prev_instr && offp != NULL && error == 0) *offp += 1;
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/src/mi/Lget_proc_info_in_range.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if defined(UNW_LOCAL_ONLY) && !defined(UNW_REMOTE_ONLY) +#include "Gget_proc_info_in_range.c" +#endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/mi/backtrace.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/mi/backtrace.c
Changed
@@ -33,15 +33,16 @@ /* See glibc manual for a description of this function. */ static ALWAYS_INLINE int -slow_backtrace (void **buffer, int size, unw_context_t *uc) +slow_backtrace (void **buffer, int size, unw_context_t *uc, int flag) { unw_cursor_t cursor; unw_word_t ip; int n = 0; - if (unlikely (unw_init_local (&cursor, uc) < 0)) + if (unlikely (unw_init_local2 (&cursor, uc, flag) < 0)) return 0; + while (unw_step (&cursor) > 0) { if (n >= size) @@ -69,12 +70,52 @@ if (unlikely (tdep_trace (&cursor, buffer, &n) < 0)) { unw_getcontext (&uc); - return slow_backtrace (buffer, size, &uc); + return slow_backtrace (buffer, size, &uc, 0); } return n; } +int +unw_backtrace2 (void **buffer, int size, unw_context_t* uc2, int flag) +{ + if (size == 0) + return 0; + + if (uc2 == NULL) + return unw_backtrace(buffer, size); + + unw_cursor_t cursor; + // need to copy, because the context will be modified by tdep_trace + unw_context_t uc = *(unw_context_t*)uc2; + + if (unlikely (unw_init_local2 (&cursor, &uc, flag) < 0)) + return 0; + + // get the first ip from the context + unw_word_t ip; + + if (unw_get_reg (&cursor, UNW_REG_IP, &ip) < 0) + return 0; + + buffer0 = (void *) (uintptr_t)ip; + + // update buffer info to collect the rest of the IPs + buffer = buffer+1; + int remaining_size = size-1; + + int n = remaining_size; + + // returns the number of frames collected by tdep_trace or slow_backtrace + // and add 1 to it (the one we retrieved above) + if (unlikely (tdep_trace (&cursor, buffer, &n) < 0)) + { + return slow_backtrace (buffer, remaining_size, &uc, flag) + 1; + } + + return n + 1; +} + #ifdef CONFIG_WEAK_BACKTRACE extern int backtrace (void **buffer, int size) WEAK ALIAS(unw_backtrace);
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/mi/init.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/mi/init.c
Changed
@@ -39,6 +39,30 @@ long unwi_debug_level; #endif /* UNW_DEBUG */ +long unw_page_size; +static void +unw_init_page_size (void) +{ + errno = 0; + long result = sysconf (_SC_PAGESIZE); + if (result == -1) + { + if (errno != 0) + { + print_error ("Failed to get _SC_PAGESIZE: "); + print_error (strerror(errno)); + print_error ("\n"); + } + else + print_error ("Failed to get _SC_PAGESIZE, errno was not set.\n"); + + unw_page_size = 4096; + } + else + { + unw_page_size = result; + } +} HIDDEN void mi_init (void) @@ -55,6 +79,6 @@ setbuf (stderr, NULL); } #endif - - assert (sizeof (struct cursor) <= sizeof (unw_cursor_t)); + unw_init_page_size(); + assert(sizeof(struct cursor) <= sizeof(unw_cursor_t)); }
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/mips/Gstep.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/mips/Gstep.c
Changed
@@ -32,7 +32,7 @@ struct cursor *c = (struct cursor *) cursor; unw_word_t sc_addr, sp_addr = c->dwarf.cfa; unw_word_t ra, fp; - int ret; + int i, ret; switch (unw_is_signal_frame (cursor)) { case 1: @@ -51,6 +51,9 @@ c->sigcontext_addr = sc_addr; + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + /* Update the dwarf cursor. */ c->dwarf.locUNW_MIPS_R0 = DWARF_LOC (sc_addr + LINUX_SC_R0_OFF, 0); c->dwarf.locUNW_MIPS_R1 = DWARF_LOC (sc_addr + LINUX_SC_R1_OFF, 0);
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/os-linux.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/os-linux.c
Changed
@@ -26,10 +26,15 @@ #include <limits.h> #include <stdio.h> #include <sys/stat.h> +#include <string.h> +#include <stdlib.h> +#include <assert.h> #include "libunwind_i.h" #include "os-linux.h" +#define FULL_PATH_BUFF_SZ 1024 + int tdep_get_elf_image (struct elf_image *ei, pid_t pid, unw_word_t ip, unsigned long *segbase, unsigned long *mapoff, @@ -41,7 +46,7 @@ char rootsizeof ("/proc/0123456789/root"), *cp; char *full_path; struct stat st; - + char full_path_buffFULL_PATH_BUFF_SZ; if (maps_init (&mi, pid) < 0) return -1; @@ -69,7 +74,16 @@ if (!stat(root, &st) && S_ISDIR(st.st_mode)) { - full_path = (char*) malloc (strlen (root) + strlen (mi.path) + 1); + unsigned long _len = strlen(root) + strlen(mi.path) + 1; + if(_len >= FULL_PATH_BUFF_SZ) + { + full_path = (char*) malloc(_len); + } + else + { + snprintf(full_path_buff, FULL_PATH_BUFF_SZ, "%s%s", root, mi.path); + full_path = &full_path_buff0; + } if (!full_path) full_path = mi.path; else @@ -85,7 +99,7 @@ } rc = elf_map_image (ei, full_path); - if (full_path && full_path != mi.path) + if (full_path && full_path != mi.path && full_path != &full_path_buff0) free (full_path); maps_close (&mi);
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/ppc32/Ginit.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/ppc32/Ginit.c
Changed
@@ -48,12 +48,20 @@ void *addr; if ((unsigned) (reg - UNW_PPC32_R0) < 32) +#if defined(__linux__) addr = &uc->uc_mcontext.uc_regs->gregsreg - UNW_PPC32_R0; +#elif defined(__FreeBSD__) + addr = &uc->uc_mcontext.mc_gprreg - UNW_PPC32_R0; +#endif else if ( ((unsigned) (reg - UNW_PPC32_F0) < 32) && ((unsigned) (reg - UNW_PPC32_F0) >= 0) ) +#if defined(__linux__) addr = &uc->uc_mcontext.uc_regs->fpregs.fpregsreg - UNW_PPC32_F0; + #elif defined(__FreeBSD__) + addr = &uc->uc_mcontext.mc_fpregreg - UNW_PPC32_F0; +#endif else { @@ -76,7 +84,11 @@ default: return NULL; } +#if defined(__linux__) addr = &uc->uc_mcontext.uc_regs->gregsgregs_idx; +#elif defined(__FreeBSD__) + addr = &uc->uc_mcontext.mc_gprgregs_idx; +#endif } return addr; }
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/ppc32/init.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/ppc32/init.h
Changed
@@ -27,7 +27,7 @@ #include "unwind_i.h" -/* Here is the "common" init, for remote and local debuging" */ +/* Here is the "common" init, for remote and local debugging" */ static inline int common_init_ppc32 (struct cursor *c, unsigned use_prev_instr)
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/ppc32/ucontext_i.h -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/ppc32/ucontext_i.h
Changed
@@ -29,6 +29,8 @@ #include "compiler.h" #include <ucontext.h> +#if defined(__linux__) + /* These values were derived by reading /usr/src/linux-2.6.18-1.8/arch/um/include/sysdep-ppc/ptrace.h and /usr/src/linux-2.6.18-1.8/arch/powerpc/kernel/ppc32.h @@ -42,87 +44,127 @@ //#define MQ_IDX 36 #define LINK_IDX 36 +#define _UC_MCONTEXT_GPR(x) ( (void *)&dmy_ctxt.uc_mcontext.gregsx - (void *)&dmy_ctxt) ) +#define _UC_MCONTEXT_FPR(x) ( ((void *)&dmy_ctxt.uc_mcontext.fpregsx - (void *)&dmy_ctxt) ) + /* These are dummy structures used only for obtaining the offsets of the various structure members. */ static ucontext_t dmy_ctxt UNUSED; -#define UC_MCONTEXT_GREGS_R0 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs0 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R1 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs1 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R2 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs2 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R3 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs3 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R4 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs4 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R5 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs5 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R6 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs6 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R7 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs7 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R8 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs8 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R9 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs9 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R10 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs10 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R11 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs11 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R12 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs12 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R13 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs13 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R14 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs14 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R15 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs15 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R16 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs16 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R17 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs17 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R18 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs18 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R19 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs19 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R20 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs20 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R21 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs21 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R22 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs22 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R23 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs23 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R24 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs24 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R25 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs25 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R26 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs26 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R27 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs27 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R28 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs28 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R29 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs29 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R30 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs30 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_R31 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregs31 - (void *)&dmy_ctxt) - -#define UC_MCONTEXT_GREGS_MSR ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregsMSR_IDX - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_ORIG_GPR3 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregsORIG_GPR3_IDX - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_CTR ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregsCTR_IDX - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_LINK ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregsLINK_IDX - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_XER ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregsXER_IDX - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_CCR ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregsCCR_IDX - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_SOFTE ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregsSOFTE_IDX - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_TRAP ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregsTRAP_IDX - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_DAR ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregsDAR_IDX - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_DSISR ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregsDSISR_IDX - (void *)&dmy_ctxt) -#define UC_MCONTEXT_GREGS_RESULT ((void *)&dmy_ctxt.uc_mcontext.uc_regs->gregsRESULT_IDX - (void *)&dmy_ctxt) - -#define UC_MCONTEXT_FREGS_R0 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs0 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R1 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs1 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R2 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs2 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R3 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs3 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R4 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs4 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R5 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs5 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R6 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs6 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R7 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs7 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R8 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs8 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R9 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs9 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R10 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs10 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R11 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs11 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R12 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs12 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R13 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs13 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R14 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs14 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R15 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs15 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R16 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs16 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R17 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs17 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R18 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs18 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R19 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs19 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R20 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs20 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R21 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs21 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R22 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs22 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R23 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs23 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R24 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs24 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R25 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs25 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R26 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs26 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R27 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs27 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R28 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs28 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R29 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs29 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R30 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs30 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_R31 ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs31 - (void *)&dmy_ctxt) -#define UC_MCONTEXT_FREGS_FPSCR ((void *)&dmy_ctxt.uc_mcontext.uc_regs->fpregs.fpregs32 - (void *)&dmy_ctxt) +#elif defined(__FreeBSD__) + /* See /usr/src/sys/powerpc/include/ucontext.h. + FreeBSD uses a different structure than Linux. +*/ + +#define NIP_IDX 36 +#define MSR_IDX 37 +//#define ORIG_GPR3_IDX +#define CTR_IDX 35 +#define LINK_IDX 32 +#define XER_IDX 34 +#define CCR_IDX 33 +//#define SOFTE_IDX +//#define TRAP_IDX +#define DAR_IDX 39 +#define DSISR_IDX 40 +//#define RESULT_IDX + +#define _UC_MCONTEXT_GPR(_x) ( ((void *)&dmy_ctxt.mc_gpr_x - (void *)&dmy_ctxt) ) +#define _UC_MCONTEXT_FPR(_x) ( ((void *)&dmy_ctxt.mc_fpreg_x - (void *)&dmy_ctxt) ) + +/* These are dummy structures used only for obtaining the offsets of the + various structure members. */ +static struct __mcontext dmy_ctxt; + +#else +#error "Not implemented!" +#endif + +#define UC_MCONTEXT_GREGS_R0 _UC_MCONTEXT_GPR(0) +#define UC_MCONTEXT_GREGS_R1 _UC_MCONTEXT_GPR(1) +#define UC_MCONTEXT_GREGS_R2 _UC_MCONTEXT_GPR(2) +#define UC_MCONTEXT_GREGS_R3 _UC_MCONTEXT_GPR(3) +#define UC_MCONTEXT_GREGS_R4 _UC_MCONTEXT_GPR(4) +#define UC_MCONTEXT_GREGS_R5 _UC_MCONTEXT_GPR(5) +#define UC_MCONTEXT_GREGS_R6 _UC_MCONTEXT_GPR(6) +#define UC_MCONTEXT_GREGS_R7 _UC_MCONTEXT_GPR(7) +#define UC_MCONTEXT_GREGS_R8 _UC_MCONTEXT_GPR(8) +#define UC_MCONTEXT_GREGS_R9 _UC_MCONTEXT_GPR(9) +#define UC_MCONTEXT_GREGS_R10 _UC_MCONTEXT_GPR(10) +#define UC_MCONTEXT_GREGS_R11 _UC_MCONTEXT_GPR(11) +#define UC_MCONTEXT_GREGS_R12 _UC_MCONTEXT_GPR(12) +#define UC_MCONTEXT_GREGS_R13 _UC_MCONTEXT_GPR(13) +#define UC_MCONTEXT_GREGS_R14 _UC_MCONTEXT_GPR(14) +#define UC_MCONTEXT_GREGS_R15 _UC_MCONTEXT_GPR(15) +#define UC_MCONTEXT_GREGS_R16 _UC_MCONTEXT_GPR(16) +#define UC_MCONTEXT_GREGS_R17 _UC_MCONTEXT_GPR(17) +#define UC_MCONTEXT_GREGS_R18 _UC_MCONTEXT_GPR(18) +#define UC_MCONTEXT_GREGS_R19 _UC_MCONTEXT_GPR(19) +#define UC_MCONTEXT_GREGS_R20 _UC_MCONTEXT_GPR(20) +#define UC_MCONTEXT_GREGS_R21 _UC_MCONTEXT_GPR(21) +#define UC_MCONTEXT_GREGS_R22 _UC_MCONTEXT_GPR(22) +#define UC_MCONTEXT_GREGS_R23 _UC_MCONTEXT_GPR(23) +#define UC_MCONTEXT_GREGS_R24 _UC_MCONTEXT_GPR(24) +#define UC_MCONTEXT_GREGS_R25 _UC_MCONTEXT_GPR(25) +#define UC_MCONTEXT_GREGS_R26 _UC_MCONTEXT_GPR(26) +#define UC_MCONTEXT_GREGS_R27 _UC_MCONTEXT_GPR(27) +#define UC_MCONTEXT_GREGS_R28 _UC_MCONTEXT_GPR(28) +#define UC_MCONTEXT_GREGS_R29 _UC_MCONTEXT_GPR(29) +#define UC_MCONTEXT_GREGS_R30 _UC_MCONTEXT_GPR(30) +#define UC_MCONTEXT_GREGS_R31 _UC_MCONTEXT_GPR(31) +#define UC_MCONTEXT_GREGS_NIP _UC_MCONTEXT_GPR(NIP_IDX) +#define UC_MCONTEXT_GREGS_MSR _UC_MCONTEXT_GPR(MSR_IDX) +#ifdef ORIG_GPR3_IDX +#define UC_MCONTEXT_GREGS_ORIG_GPR3 _UC_MCONTEXT_GPR(ORIG_GPR3_IDX) +#endif +#define UC_MCONTEXT_GREGS_CTR _UC_MCONTEXT_GPR(CTR_IDX) +#define UC_MCONTEXT_GREGS_LINK _UC_MCONTEXT_GPR(LINK_IDX) +#define UC_MCONTEXT_GREGS_XER _UC_MCONTEXT_GPR(XER_IDX) +#define UC_MCONTEXT_GREGS_CCR _UC_MCONTEXT_GPR(CCR_IDX) +#ifdef SOFTE_IDX +#define UC_MCONTEXT_GREGS_SOFTE _UC_MCONTEXT_GPR(SOFTE_IDX) +#endif +#ifdef TRAP_IDX +#define UC_MCONTEXT_GREGS_TRAP _UC_MCONTEXT_GPR(TRAP_IDX) +#endif +#define UC_MCONTEXT_GREGS_DAR _UC_MCONTEXT_GPR(DAR_IDX) +#define UC_MCONTEXT_GREGS_DSISR _UC_MCONTEXT_GPR(DSISR_IDX) +#ifdef RESULT_IDX +#define UC_MCONTEXT_GREGS_RESULT _UC_MCONTEXT_GPR(RESULT_IDX) +#endif + +#define UC_MCONTEXT_FREGS_R0 _UC_MCONTEXT_FPR(0) +#define UC_MCONTEXT_FREGS_R1 _UC_MCONTEXT_FPR(1) +#define UC_MCONTEXT_FREGS_R2 _UC_MCONTEXT_FPR(2) +#define UC_MCONTEXT_FREGS_R3 _UC_MCONTEXT_FPR(3) +#define UC_MCONTEXT_FREGS_R4 _UC_MCONTEXT_FPR(4) +#define UC_MCONTEXT_FREGS_R5 _UC_MCONTEXT_FPR(5) +#define UC_MCONTEXT_FREGS_R6 _UC_MCONTEXT_FPR(6) +#define UC_MCONTEXT_FREGS_R7 _UC_MCONTEXT_FPR(7) +#define UC_MCONTEXT_FREGS_R8 _UC_MCONTEXT_FPR(8) +#define UC_MCONTEXT_FREGS_R9 _UC_MCONTEXT_FPR(9) +#define UC_MCONTEXT_FREGS_R10 _UC_MCONTEXT_FPR(10) +#define UC_MCONTEXT_FREGS_R11 _UC_MCONTEXT_FPR(11) +#define UC_MCONTEXT_FREGS_R12 _UC_MCONTEXT_FPR(12) +#define UC_MCONTEXT_FREGS_R13 _UC_MCONTEXT_FPR(13) +#define UC_MCONTEXT_FREGS_R14 _UC_MCONTEXT_FPR(14) +#define UC_MCONTEXT_FREGS_R15 _UC_MCONTEXT_FPR(15) +#define UC_MCONTEXT_FREGS_R16 _UC_MCONTEXT_FPR(16) +#define UC_MCONTEXT_FREGS_R17 _UC_MCONTEXT_FPR(17) +#define UC_MCONTEXT_FREGS_R18 _UC_MCONTEXT_FPR(18) +#define UC_MCONTEXT_FREGS_R19 _UC_MCONTEXT_FPR(19) +#define UC_MCONTEXT_FREGS_R20 _UC_MCONTEXT_FPR(20) +#define UC_MCONTEXT_FREGS_R21 _UC_MCONTEXT_FPR(21) +#define UC_MCONTEXT_FREGS_R22 _UC_MCONTEXT_FPR(22) +#define UC_MCONTEXT_FREGS_R23 _UC_MCONTEXT_FPR(23) +#define UC_MCONTEXT_FREGS_R24 _UC_MCONTEXT_FPR(24) +#define UC_MCONTEXT_FREGS_R25 _UC_MCONTEXT_FPR(25) +#define UC_MCONTEXT_FREGS_R26 _UC_MCONTEXT_FPR(26) +#define UC_MCONTEXT_FREGS_R27 _UC_MCONTEXT_FPR(27) +#define UC_MCONTEXT_FREGS_R28 _UC_MCONTEXT_FPR(28) +#define UC_MCONTEXT_FREGS_R29 _UC_MCONTEXT_FPR(29) +#define UC_MCONTEXT_FREGS_R30 _UC_MCONTEXT_FPR(30) +#define UC_MCONTEXT_FREGS_R31 _UC_MCONTEXT_FPR(31) +#define UC_MCONTEXT_FREGS_FPSCR _UC_MCONTEXT_FPR(32) #endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/ptrace/_UPT_access_fpreg.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/ptrace/_UPT_access_fpreg.c
Changed
@@ -26,7 +26,7 @@ #include "_UPT_internal.h" -#if HAVE_DECL_PTRACE_POKEUSER || HAVE_TTRACE +#if HAVE_DECL_PTRACE_POKEUSER || defined(HAVE_TTRACE) int _UPT_access_fpreg (unw_addr_space_t as, unw_regnum_t reg, unw_fpreg_t *val, int write, void *arg) @@ -90,6 +90,9 @@ #elif defined(__powerpc64__) if ((unsigned) reg < UNW_PPC64_F0 || (unsigned) reg > UNW_PPC64_F31) return -UNW_EBADREG; +#elif defined(__powerpc__) + if ((unsigned) reg < UNW_PPC32_F0 || (unsigned) reg > UNW_PPC32_F31) + return -UNW_EBADREG; #else #error Fix me #endif @@ -107,7 +110,7 @@ memcpy(&fpreg.fprreg, val, sizeof(unw_fpreg_t)); #elif defined(__aarch64__) memcpy(&fpreg.fp_qreg, val, sizeof(unw_fpreg_t)); -#elif defined(__powerpc64__) +#elif defined(__powerpc__) memcpy(&fpreg.fpregreg, val, sizeof(unw_fpreg_t)); #else #error Fix me @@ -123,7 +126,7 @@ memcpy(val, &fpreg.fprreg, sizeof(unw_fpreg_t)); #elif defined(__aarch64__) memcpy(val, &fpreg.fp_qreg, sizeof(unw_fpreg_t)); -#elif defined(__powerpc64__) +#elif defined(__powerpc__) memcpy(val, &fpreg.fpregreg, sizeof(unw_fpreg_t)); #else #error Fix me
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/ptrace/_UPT_access_mem.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/ptrace/_UPT_access_mem.c
Changed
@@ -26,7 +26,7 @@ #include "_UPT_internal.h" -#if HAVE_DECL_PTRACE_POKEDATA || HAVE_TTRACE +#if HAVE_DECL_PTRACE_POKEDATA || defined(HAVE_TTRACE) int _UPT_access_mem (unw_addr_space_t as, unw_word_t addr, unw_word_t *val, int write, void *arg)
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/ptrace/_UPT_access_reg.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/ptrace/_UPT_access_reg.c
Changed
@@ -77,7 +77,7 @@ Debug (1, "bad register %s %u (error: %s)\n", unw_regname(reg), reg, strerror (errno)); return -UNW_EBADREG; } -#elif HAVE_DECL_PTRACE_POKEUSER || HAVE_TTRACE +#elif HAVE_DECL_PTRACE_POKEUSER || defined(HAVE_TTRACE) int _UPT_access_reg (unw_addr_space_t as, unw_regnum_t reg, unw_word_t *val, int write, void *arg)
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/ptrace/_UPT_reg_offset.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/ptrace/_UPT_reg_offset.c
Changed
@@ -36,7 +36,7 @@ # include <asm/ptrace_offsets.h> #endif -#if defined(__powerpc64__) && defined(__FreeBSD__) +#if defined(__powerpc__) && defined(__FreeBSD__) #define PT_R0 0 #define PT_R1 1 #define PT_R2 2 @@ -70,10 +70,12 @@ #define PT_R30 30 #define PT_R31 31 #define PT_NIP 32 +#define PT_CCR 33 #define PT_CTR 35 #define PT_LNK 36 #define PT_XER 37 #define PT_FPR0 48 +#define PT_FPSCR (PT_FPR0 + 2*32 + 1) #define PT_VR0 82 #define PT_VSCR (PT_VR0 + 32*2 + 1) #define PT_VRSAVE (PT_VR0 + 33*2) @@ -754,6 +756,42 @@ UNW_RISCV_X29 = RISCV_REG_OFFSET(29), UNW_RISCV_X30 = RISCV_REG_OFFSET(30), UNW_RISCV_X31 = RISCV_REG_OFFSET(31), +#elif defined(UNW_TARGET_LOONGARCH64) +# include <asm/reg.h> + + UNW_LOONGARCH64_R0 = LOONGARCH_EF_R0, + UNW_LOONGARCH64_R1 = LOONGARCH_EF_R1, + UNW_LOONGARCH64_R2 = LOONGARCH_EF_R2, + UNW_LOONGARCH64_R3 = LOONGARCH_EF_R3, + UNW_LOONGARCH64_R4 = LOONGARCH_EF_R4, + UNW_LOONGARCH64_R5 = LOONGARCH_EF_R5, + UNW_LOONGARCH64_R6 = LOONGARCH_EF_R6, + UNW_LOONGARCH64_R7 = LOONGARCH_EF_R7, + UNW_LOONGARCH64_R8 = LOONGARCH_EF_R8, + UNW_LOONGARCH64_R9 = LOONGARCH_EF_R9, + UNW_LOONGARCH64_R10 = LOONGARCH_EF_R10, + UNW_LOONGARCH64_R11 = LOONGARCH_EF_R11, + UNW_LOONGARCH64_R12 = LOONGARCH_EF_R12, + UNW_LOONGARCH64_R13 = LOONGARCH_EF_R13, + UNW_LOONGARCH64_R14 = LOONGARCH_EF_R14, + UNW_LOONGARCH64_R15 = LOONGARCH_EF_R15, + UNW_LOONGARCH64_R16 = LOONGARCH_EF_R16, + UNW_LOONGARCH64_R17 = LOONGARCH_EF_R17, + UNW_LOONGARCH64_R18 = LOONGARCH_EF_R18, + UNW_LOONGARCH64_R19 = LOONGARCH_EF_R19, + UNW_LOONGARCH64_R20 = LOONGARCH_EF_R20, + UNW_LOONGARCH64_R21 = LOONGARCH_EF_R21, + UNW_LOONGARCH64_R22 = LOONGARCH_EF_R22, + UNW_LOONGARCH64_R23 = LOONGARCH_EF_R23, + UNW_LOONGARCH64_R24 = LOONGARCH_EF_R24, + UNW_LOONGARCH64_R25 = LOONGARCH_EF_R25, + UNW_LOONGARCH64_R26 = LOONGARCH_EF_R26, + UNW_LOONGARCH64_R27 = LOONGARCH_EF_R27, + UNW_LOONGARCH64_R28 = LOONGARCH_EF_R28, + UNW_LOONGARCH64_R29 = LOONGARCH_EF_R29, + UNW_LOONGARCH64_R30 = LOONGARCH_EF_R30, + UNW_LOONGARCH64_R31 = LOONGARCH_EF_R31, + UNW_LOONGARCH64_PC = LOONGARCH_EF_CSR_ERA #else # error Fix me. #endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/riscv/Gglobal.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/riscv/Gglobal.c
Changed
@@ -115,9 +115,10 @@ mi_init (); dwarf_init (); - tdep_init_mem_validate (); #ifndef UNW_REMOTE_ONLY + tdep_init_mem_validate (); + riscv_local_addr_space_init (); #endif atomic_store(&tdep_init_done, 1); /* signal that we're initialized... */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/riscv/Ginit.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/riscv/Ginit.c
Changed
@@ -97,9 +97,6 @@ // Memory validation routines are from aarch64 -#define PAGE_SIZE 4096 -#define PAGE_START(a) ((a) & ~(PAGE_SIZE-1)) - static int mem_validate_pipe2 = {-1, -1}; #ifdef HAVE_PIPE2 @@ -210,11 +207,14 @@ #ifdef HAVE_MINCORE unsigned char present = 1; - unw_word_t addr = PAGE_START((unw_word_t)&present); + size_t len = unw_page_size; + unw_word_t addr = uwn_page_start((unw_word_t)&present); unsigned char mvec1; int ret; - while ((ret = mincore ((void*)addr, PAGE_SIZE, (unsigned char *)mvec)) == -1 && - errno == EAGAIN) {} + while ((ret = mincore((void *)addr, len, (unsigned char *)mvec)) == -1 && + errno == EAGAIN) + { + } if (ret == 0) { Debug(1, "using mincore to validate memory\n"); @@ -306,14 +306,8 @@ static int validate_mem (unw_word_t addr) { - size_t len; - - if (PAGE_START(addr + sizeof (unw_word_t) - 1) == PAGE_START(addr)) - len = PAGE_SIZE; - else - len = PAGE_SIZE * 2; - - addr = PAGE_START(addr); + size_t len = unw_page_size; + addr = uwn_page_start(addr); if (addr == 0) return -1;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/riscv/Gstep.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/riscv/Gstep.c
Changed
@@ -53,6 +53,9 @@ return -UNW_EUNSPEC; #endif + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + /* Update the dwarf cursor. Set the location of the registers to the corresponding addresses of the uc_mcontext / sigcontext structure contents. */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/s390x/Gglobal.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/s390x/Gglobal.c
Changed
@@ -89,9 +89,9 @@ dwarf_init (); +#ifndef UNW_REMOTE_ONLY tdep_init_mem_validate (); -#ifndef UNW_REMOTE_ONLY s390x_local_addr_space_init (); #endif atomic_store(&tdep_init_done, 1); /* signal that we're initialized... */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/s390x/Ginit.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/s390x/Ginit.c
Changed
@@ -27,6 +27,7 @@ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ +#include "libunwind_i.h" #ifdef HAVE_CONFIG_H #include <config.h> #endif @@ -93,9 +94,6 @@ return 0; } -#define PAGE_SIZE 4096 -#define PAGE_START(a) ((a) & ~(PAGE_SIZE-1)) - static int mem_validate_pipe2 = {-1, -1}; static inline void @@ -163,7 +161,7 @@ return -1; } - for (i = 0; i < (len + PAGE_SIZE - 1) / PAGE_SIZE; i++) + for (i = 0; i < (len + unw_page_size - 1) / unw_page_size; i++) { if (!(mveci & 1)) return -1; } @@ -183,11 +181,14 @@ #ifdef HAVE_MINCORE unsigned char present = 1; - unw_word_t addr = PAGE_START((unw_word_t)&present); + size_t len = unw_page_size; + unw_word_t addr = uwn_page_start((unw_word_t)&present); unsigned char mvec1; int ret; - while ((ret = mincore ((void*)addr, PAGE_SIZE, mvec)) == -1 && - errno == EAGAIN) {} + while ((ret = mincore((void *)addr, len, mvec)) == -1 && + errno == EAGAIN) + { + } if (ret == 0 && (mvec0 & 1)) { Debug(1, "using mincore to validate memory\n"); @@ -210,14 +211,8 @@ validate_mem (unw_word_t addr) { int i, victim; - size_t len; - - if (PAGE_START(addr + sizeof (unw_word_t) - 1) == PAGE_START(addr)) - len = PAGE_SIZE; - else - len = PAGE_SIZE * 2; - - addr = PAGE_START(addr); + size_t len = unw_page_size; + addr = uwn_page_start(addr); if (addr == 0) return -1;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/s390x/Gstep.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/s390x/Gstep.c
Changed
@@ -64,6 +64,9 @@ c->sigcontext_addr = sc_addr; + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + /* Update the dwarf cursor. Set the location of the registers to the corresponding addresses of the uc_mcontext / sigcontext structure contents. */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/sh/Gstep.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/sh/Gstep.c
Changed
@@ -31,7 +31,7 @@ sh_handle_signal_frame (unw_cursor_t *cursor) { struct cursor *c = (struct cursor *) cursor; - int ret; + int i, ret; unw_word_t sc_addr, sp, sp_addr = c->dwarf.cfa; struct dwarf_loc sp_loc = DWARF_LOC (sp_addr, 0); @@ -63,6 +63,9 @@ c->sigcontext_addr = sc_addr; + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + /* Update the dwarf cursor. Set the location of the registers to the corresponding addresses of the uc_mcontext / sigcontext structure contents. */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/tilegx/Gis_signal_frame.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/tilegx/Gis_signal_frame.c
Changed
@@ -96,6 +96,9 @@ C_ABI_SAVE_AREA_SIZE; sc_addr = c->sigcontext_addr + LINUX_UC_MCONTEXT_OFF; + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + /* Update the dwarf cursor. Set the location of the registers to the corresponding addresses of the uc_mcontext / sigcontext structure contents. */
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/tilegx/Gstep.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/tilegx/Gstep.c
Changed
@@ -35,7 +35,7 @@ Debug (1, "(cursor=%p, ip=0x%016lx, sp=0x%016lx)\n", c, c->dwarf.ip, c->dwarf.cfa); - /* Special handling the singal frame. */ + /* Special handling the signal frame. */ if (unw_is_signal_frame (cursor) > 0) return tilegx_handle_signal_frame (cursor);
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/x86/Ginit.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/x86/Ginit.c
Changed
@@ -74,9 +74,6 @@ return 0; } -#define PAGE_SIZE 4096 -#define PAGE_START(a) ((a) & ~(PAGE_SIZE-1)) - /* Cache of already validated addresses */ #define NLGA 4 static unw_word_t last_good_addrNLGA; @@ -89,14 +86,8 @@ #ifdef HAVE_MINCORE unsigned char mvec2; /* Unaligned access may cross page boundary */ #endif - size_t len; - - if (PAGE_START(addr + sizeof (unw_word_t) - 1) == PAGE_START(addr)) - len = PAGE_SIZE; - else - len = PAGE_SIZE * 2; - - addr = PAGE_START(addr); + size_t len = unw_page_size; + addr = uwn_page_start(addr); if (addr == 0) return -1;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/x86/Gos-freebsd.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/x86/Gos-freebsd.c
Changed
@@ -124,6 +124,9 @@ return 0; } + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + c->dwarf.locEIP = DWARF_LOC (uc_addr + FREEBSD_UC_MCONTEXT_EIP_OFF, 0); c->dwarf.locESP = DWARF_LOC (uc_addr + FREEBSD_UC_MCONTEXT_ESP_OFF, 0); c->dwarf.locEAX = DWARF_LOC (uc_addr + FREEBSD_UC_MCONTEXT_EAX_OFF, 0); @@ -138,6 +141,7 @@ c->dwarf.locST0 = DWARF_NULL_LOC; } else if (c->sigcontext_format == X86_SCF_FREEBSD_SYSCALL) { c->dwarf.locEIP = DWARF_LOC (c->dwarf.cfa, 0); + c->dwarf.locESP = DWARF_VAL_LOC (c, c->dwarf.cfa + 4); c->dwarf.locEAX = DWARF_NULL_LOC; c->dwarf.cfa += 4; c->dwarf.use_prev_instr = 1;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/x86/Gos-linux.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/x86/Gos-linux.c
Changed
@@ -73,7 +73,7 @@ x86_handle_signal_frame (unw_cursor_t *cursor) { struct cursor *c = (struct cursor *) cursor; - int ret; + int i, ret; /* c->esp points at the arguments to the handler. Without SA_SIGINFO, the arguments consist of a signal number @@ -123,6 +123,9 @@ return 0; } + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + c->dwarf.locEAX = DWARF_LOC (sc_addr + LINUX_SC_EAX_OFF, 0); c->dwarf.locECX = DWARF_LOC (sc_addr + LINUX_SC_ECX_OFF, 0); c->dwarf.locEDX = DWARF_LOC (sc_addr + LINUX_SC_EDX_OFF, 0); @@ -130,9 +133,6 @@ c->dwarf.locEBP = DWARF_LOC (sc_addr + LINUX_SC_EBP_OFF, 0); c->dwarf.locESI = DWARF_LOC (sc_addr + LINUX_SC_ESI_OFF, 0); c->dwarf.locEDI = DWARF_LOC (sc_addr + LINUX_SC_EDI_OFF, 0); - c->dwarf.locEFLAGS = DWARF_NULL_LOC; - c->dwarf.locTRAPNO = DWARF_NULL_LOC; - c->dwarf.locST0 = DWARF_NULL_LOC; c->dwarf.locEIP = DWARF_LOC (sc_addr + LINUX_SC_EIP_OFF, 0); c->dwarf.locESP = DWARF_LOC (sc_addr + LINUX_SC_ESP_OFF, 0);
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/x86/Gregs.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/x86/Gregs.c
Changed
@@ -53,7 +53,6 @@ break; case UNW_X86_CFA: - case UNW_X86_ESP: if (write) return -UNW_EREADONLYREG; *valp = c->dwarf.cfa; @@ -81,6 +80,7 @@ case UNW_X86_ECX: loc = c->dwarf.locECX; break; case UNW_X86_EBX: loc = c->dwarf.locEBX; break; + case UNW_X86_ESP: loc = c->dwarf.locESP; break; case UNW_X86_EBP: loc = c->dwarf.locEBP; break; case UNW_X86_ESI: loc = c->dwarf.locESI; break; case UNW_X86_EDI: loc = c->dwarf.locEDI; break;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/x86/Gstep.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/x86/Gstep.c
Changed
@@ -47,7 +47,7 @@ { /* DWARF failed, let's see if we can follow the frame-chain or skip over the signal trampoline. */ - struct dwarf_loc ebp_loc, eip_loc; + struct dwarf_loc ebp_loc, eip_loc, esp_loc; /* We could get here because of missing/bad unwind information. Validate all addresses before dereferencing. */ @@ -77,6 +77,7 @@ c->dwarf.cfa); ebp_loc = DWARF_LOC (c->dwarf.cfa, 0); + esp_loc = DWARF_VAL_LOC (c, c->dwarf.cfa + 8); eip_loc = DWARF_LOC (c->dwarf.cfa + 4, 0); c->dwarf.cfa += 8; @@ -87,6 +88,7 @@ c->dwarf.loci = DWARF_NULL_LOC; c->dwarf.locEBP = ebp_loc; + c->dwarf.locESP = esp_loc; c->dwarf.locEIP = eip_loc; c->dwarf.use_prev_instr = 1; }
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/x86_64/Ginit.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/x86_64/Ginit.c
Changed
@@ -73,16 +73,13 @@ return 0; } -#define PAGE_SIZE 4096 -#define PAGE_START(a) ((a) & ~(PAGE_SIZE-1)) - static int mem_validate_pipe2 = {-1, -1}; #ifdef HAVE_PIPE2 static inline void do_pipe2 (int pipefd2) { - pipe2 (pipefd, O_CLOEXEC | O_NONBLOCK); + int result UNUSED = pipe2 (pipefd, O_CLOEXEC | O_NONBLOCK); } #else static inline void @@ -191,10 +188,11 @@ #ifdef HAVE_MINCORE unsigned char present = 1; - unw_word_t addr = PAGE_START((unw_word_t)&present); + size_t len = unw_page_size; + unw_word_t addr = uwn_page_start((unw_word_t)&present); unsigned char mvec1; int ret; - while ((ret = mincore ((void*)addr, PAGE_SIZE, (unsigned char *)mvec)) == -1 && + while ((ret = mincore ((void*)addr, len, (unsigned char *)mvec)) == -1 && errno == EAGAIN) {} if (ret == 0) { @@ -287,14 +285,8 @@ static int validate_mem (unw_word_t addr) { - size_t len; - - if (PAGE_START(addr + sizeof (unw_word_t) - 1) == PAGE_START(addr)) - len = PAGE_SIZE; - else - len = PAGE_SIZE * 2; - - addr = PAGE_START(addr); + size_t len = unw_page_size; + addr = uwn_page_start(addr); if (addr == 0) return -1;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/x86_64/Gos-freebsd.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/x86_64/Gos-freebsd.c
Changed
@@ -92,7 +92,7 @@ { struct cursor *c = (struct cursor *) cursor; unw_word_t ucontext; - int ret; + int i, ret; if (c->sigcontext_format == X86_64_SCF_FREEBSD_SIGFRAME) { @@ -108,6 +108,9 @@ return ret; } + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + c->dwarf.locRAX = DWARF_LOC (ucontext + UC_MCONTEXT_GREGS_RAX, 0); c->dwarf.locRDX = DWARF_LOC (ucontext + UC_MCONTEXT_GREGS_RDX, 0); c->dwarf.locRCX = DWARF_LOC (ucontext + UC_MCONTEXT_GREGS_RCX, 0); @@ -133,6 +136,7 @@ c->dwarf.locRCX = c->dwarf.locR10; /* rsp_loc = DWARF_LOC(c->dwarf.cfa - 8, 0); */ /* rbp_loc = c->dwarf.locRBP; */ + c->dwarf.locRSP = DWARF_VAL_LOC (c, c->dwarf.cfa + 8); c->dwarf.locRIP = DWARF_LOC (c->dwarf.cfa, 0); ret = dwarf_get (&c->dwarf, c->dwarf.locRIP, &c->dwarf.ip); Debug (1, "Frame Chain RIP=0x%Lx = 0x%Lx\n",
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/x86_64/Gos-solaris.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/x86_64/Gos-solaris.c
Changed
@@ -51,6 +51,7 @@ { struct cursor *c = (struct cursor *) cursor; unw_word_t ucontext = c->dwarf.cfa + sizeof (struct sigframe); + int i; if (c->sigcontext_format != X86_64_SCF_SOLARIS_SIGFRAME) return -UNW_EBADFRAME; @@ -69,6 +70,9 @@ return ret; } + for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) + c->dwarf.loci = DWARF_NULL_LOC; + c->dwarf.locRAX = DWARF_LOC (ucontext + UC_MCONTEXT_GREGS_RAX, 0); c->dwarf.locRDX = DWARF_LOC (ucontext + UC_MCONTEXT_GREGS_RDX, 0); c->dwarf.locRCX = DWARF_LOC (ucontext + UC_MCONTEXT_GREGS_RCX, 0);
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/x86_64/Gregs.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/x86_64/Gregs.c
Changed
@@ -79,7 +79,6 @@ break; case UNW_X86_64_CFA: - case UNW_X86_64_RSP: if (write) return -UNW_EREADONLYREG; *valp = c->dwarf.cfa; @@ -107,6 +106,7 @@ case UNW_X86_64_RCX: loc = c->dwarf.locRCX; break; case UNW_X86_64_RBX: loc = c->dwarf.locRBX; break; + case UNW_X86_64_RSP: loc = c->dwarf.locRSP; break; case UNW_X86_64_RBP: loc = c->dwarf.locRBP; break; case UNW_X86_64_RSI: loc = c->dwarf.locRSI; break; case UNW_X86_64_RDI: loc = c->dwarf.locRDI; break;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/x86_64/Gstash_frame.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/x86_64/Gstash_frame.c
Changed
@@ -45,7 +45,7 @@ rs->reg.whereRBP == DWARF_WHERE_EXPR) { /* Check for GCC generated alignment frame for rsp. A simple * def_cfa_expr that loads a constant offset from rbp, where the - * addres of the rip was pushed on the stack */ + * address of the rip was pushed on the stack */ unw_word_t cfa_addr = rs->reg.valDWARF_CFA_REG_COLUMN; unw_word_t rbp_addr = rs->reg.valRBP; unw_word_t cfa_offset; @@ -71,11 +71,13 @@ && DWARF_GET_LOC(d->locrs->ret_addr_column) == d->cfa-8 && (rs->reg.whereRBP == DWARF_WHERE_UNDEF || rs->reg.whereRBP == DWARF_WHERE_SAME + || rs->reg.whereRBP == DWARF_WHERE_CFA || (rs->reg.whereRBP == DWARF_WHERE_CFAREL && labs((long) rs->reg.valRBP) < (1 << 14) && rs->reg.valRBP+1 != 0)) && (rs->reg.whereRSP == DWARF_WHERE_UNDEF || rs->reg.whereRSP == DWARF_WHERE_SAME + || rs->reg.whereRSP == DWARF_WHERE_CFA || (rs->reg.whereRSP == DWARF_WHERE_CFAREL && labs((long) rs->reg.valRSP) < (1 << 14) && rs->reg.valRSP+1 != 0))) @@ -88,6 +90,10 @@ f->rbp_cfa_offset = rs->reg.valRBP; if (rs->reg.whereRSP == DWARF_WHERE_CFAREL) f->rsp_cfa_offset = rs->reg.valRSP; + if (rs->reg.whereRBP == DWARF_WHERE_CFA) + f->rbp_cfa_offset = 0; + if (rs->reg.whereRSP == DWARF_WHERE_CFA) + f->rsp_cfa_offset = 0; Debug (4, " standard frame\n"); }
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/x86_64/Gstep.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/x86_64/Gstep.c
Changed
@@ -25,6 +25,10 @@ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ +#ifdef HAVE_ASM_VSYSCALL_H +#include <asm/vsyscall.h> +#endif + #include "libunwind_i.h" #include "unwind_i.h" #include <signal.h> @@ -53,6 +57,20 @@ return ret; } +static int +is_vsyscall (struct dwarf_cursor *c) +{ +#if defined(VSYSCALL_START) && defined(VSYSCALL_END) + return c->ip >= VSYSCALL_START && c->ip < VSYSCALL_END; +#elif defined(VSYSCALL_ADDR) + /* Linux 3.16 removes `VSYSCALL_START` and `VSYSCALL_END`. Assume + a single page is mapped for vsyscalls. */ + return c->ip >= VSYSCALL_ADDR && c->ip < VSYSCALL_ADDR + sysconf(_SC_PAGESIZE); +#else + return 0; +#endif +} + int unw_step (unw_cursor_t *cursor) { @@ -112,7 +130,7 @@ unw_word_t invalid_prev_rip = 0; unw_word_t prev_ip = c->dwarf.ip, prev_cfa = c->dwarf.cfa; - struct dwarf_loc rbp_loc, rsp_loc, rip_loc; + struct dwarf_loc rbp_loc = DWARF_NULL_LOC, rsp_loc = DWARF_NULL_LOC, rip_loc = DWARF_NULL_LOC; /* We could get here because of missing/bad unwind information. Validate all addresses before dereferencing. */ @@ -141,6 +159,15 @@ c->dwarf.locRIP = DWARF_LOC (c->dwarf.cfa, 0); c->dwarf.cfa += 8; } + else if (is_vsyscall (&c->dwarf)) + { + Debug (2, "in vsyscall region\n"); + c->frame_info.cfa_reg_offset = 8; + c->frame_info.cfa_reg_rsp = -1; + c->frame_info.frame_type = UNW_X86_64_FRAME_GUESSED; + c->dwarf.locRIP = DWARF_LOC (c->dwarf.cfa, 0); + c->dwarf.cfa += 8; + } else if (DWARF_IS_NULL_LOC (c->dwarf.locRBP)) { for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) @@ -223,7 +250,7 @@ Debug (2, "RIP fixup didn't work, falling back\n"); unw_word_t rbp1 = 0; rbp_loc = DWARF_LOC(rbp, 0); - rsp_loc = DWARF_NULL_LOC; + rsp_loc = DWARF_VAL_LOC(c, rbp + 16); rip_loc = DWARF_LOC (rbp + 8, 0); ret = dwarf_get (&c->dwarf, rbp_loc, &rbp1); Debug (1, "RBP=0x%lx = 0x%lx (cfa = 0x%lx) -> 0x%lx\n", @@ -253,7 +280,7 @@ } /* Mark all registers unsaved */ for (i = 0; i < DWARF_NUM_PRESERVED_REGS; ++i) - c->dwarf.loci = DWARF_NULL_LOC; + c->dwarf.loci = DWARF_NULL_LOC; c->dwarf.locRBP = rbp_loc; c->dwarf.locRSP = rsp_loc;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/src/x86_64/Gtrace.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/src/x86_64/Gtrace.c
Changed
@@ -404,7 +404,7 @@ int maxdepth = 0; int depth = 0; int ret; - int validate = 0; + int validate UNUSED = 0; /* Check input parametres. */ if (unlikely(! cursor || ! buffer || ! size || (maxdepth = *size) <= 0))
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/tests/Garm64-test-sve-signal.c
Added
@@ -0,0 +1,121 @@ +/* + * Verify that unwinding from a signal handler works when variable width + * SVE registers are pushed onto the stack + */ + +#if defined(__ARM_FEATURE_SVE) && defined(__ARM_FEATURE_SVE_VECTOR_OPERATORS) + +#include <arm_sve.h> +#include <libunwind.h> +#include <signal.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <time.h> +#include <unistd.h> + +int64_t z100; + +void signal_handler(int signum) +{ + unw_cursor_t cursor; + unw_context_t context; + + const char* expected = { + "signal_frame", + "kill", + "sum", + "square", + "main", + }; + + unw_getcontext(&context); + unw_init_local(&cursor, &context); + + for (unsigned int depth = 0; depth < sizeof(expected) / sizeof(expected0); ++depth) + { + unw_word_t offset, pc; + int unw_rc = unw_step(&cursor); + if (unw_rc <= 0) { + printf("Frame: %d unw_step error: %d\n", depth, unw_rc); + exit(-1); + } + + unw_rc = unw_get_reg(&cursor, UNW_REG_IP, &pc); + if (pc == 0 || unw_rc != 0) { + printf("Frame: %d unw_get_reg error: %d\n", depth, unw_rc); + exit(-1); + } + + char sym256; + unw_rc = unw_is_signal_frame(&cursor); + if (unw_rc > 0) + { + strcpy(sym, "signal_frame"); + } + else if (unw_rc < 0) + { + printf("Frame: %d unw_is_signal_frame error: %d\n", depth, unw_rc); + exit(-1); + } + else + { + unw_rc = unw_get_proc_name(&cursor, sym, sizeof(sym), &offset); + if (unw_rc) + { + printf("Frame: %d unw_get_proc_name error: %d\n", depth, unw_rc); + exit(-1); + } + } + + if (strcmp(sym, expecteddepth) != 0) + { + printf("Frame: %d expected %s but found %s\n", depth, expecteddepth, sym); + exit(-1); + } + } + + exit(0); /* PASS */ +} + +int64_t sum(svint64_t z0) +{ + int64_t ret = svaddv_s64(svptrue_b64(), z0); + kill (getpid (), SIGUSR1); + return ret; +} + +int64_t square(svint64_t z0) +{ + int64_t res = 0; + for (int i = 0; i < 100; ++i) + { + z0 = svmul_s64_z(svptrue_b64(), z0, z0); + res += sum(z0); + } + return res; +} + +int main() +{ + signal(SIGUSR1, signal_handler); + for (unsigned int i = 0; i < sizeof(z) / sizeof(z0); ++i) + zi = rand(); + + svint64_t z0 = svld1(svptrue_b64(), &z0); + square(z0); + + /* + * Shouldn't get here, exit is called from signal handler + */ + printf("Signal handler wasn't called\n"); + return -1; +} + +#else /* !__ARM_FEATURE_SVE */ +int +main () +{ + return 77; /* SKIP */ +} +#endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/tests/Gia64-test-nat.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/tests/Gia64-test-nat.c
Changed
@@ -26,6 +26,7 @@ /* This file tests corner-cases of NaT-bit handling. */ #include <errno.h> +#include <signal.h> #include <stdio.h> #include <stdlib.h> #include <string.h>
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/tests/Gtest-bt.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/tests/Gtest-bt.c
Changed
@@ -1,6 +1,7 @@ /* libunwind - a platform-independent unwind library Copyright (C) 2001-2004 Hewlett-Packard Co Contributed by David Mosberger-Tang <davidm@hpl.hp.com> + Copyright 2022 Blackberry Limited. Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the @@ -189,17 +190,21 @@ } # endif #elif UNW_TARGET_X86 -#if defined __linux__ || defined __sun +# if defined __linux__ || defined __sun printf (" @ %lx", (unsigned long) uc->uc_mcontext.gregsREG_EIP); -#elif defined __FreeBSD__ +# elif defined __FreeBSD__ printf (" @ %lx", (unsigned long) uc->uc_mcontext.mc_eip); -#endif +# endif #elif UNW_TARGET_X86_64 -#if defined __linux__ || defined __sun +# if defined __linux__ || defined __sun printf (" @ %lx", (unsigned long) uc->uc_mcontext.gregsREG_RIP); -#elif defined __FreeBSD__ +# elif defined __FreeBSD__ printf (" @ %lx", (unsigned long) uc->uc_mcontext.mc_rip); -#endif +# endif +#elif UNW_TARGET_AARCH64 +# if defined(__QNXNTO__) + fprintf (stderr, " @ %#010lx", (unsigned long) uc->uc_mcontext.cpu.elr); +# endif /* defined(__QNXNTO__) */ #endif printf ("\n"); } @@ -210,7 +215,9 @@ main (int argc, char **argv UNUSED) { struct sigaction act; +#ifdef HAVE_SIGALTSTACK stack_t stk; +#endif /* HAVE_SIGALTSTACK */ verbose = (argc > 1); @@ -229,6 +236,7 @@ printf ("\nBacktrace across signal handler:\n"); kill (getpid (), SIGTERM); +#ifdef HAVE_SIGALTSTACK if (verbose) printf ("\nBacktrace across signal handler on alternate stack:\n"); stk.ss_sp = malloc (SIG_STACK_SIZE); @@ -245,6 +253,7 @@ if (sigaction (SIGTERM, &act, NULL) < 0) panic ("sigaction: %s\n", strerror (errno)); kill (getpid (), SIGTERM); +#endif /* HAVE_SIGALTSTACK */ if (num_errors > 0) { @@ -255,9 +264,11 @@ printf ("SUCCESS.\n"); signal (SIGTERM, SIG_DFL); +#ifdef HAVE_SIGALTSTACK stk.ss_flags = SS_DISABLE; sigaltstack (&stk, NULL); free (stk.ss_sp); +#endif /* HAVE_SIGALTSTACK */ return 0; }
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/tests/Gtest-trace.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/tests/Gtest-trace.c
Changed
@@ -140,6 +140,64 @@ } void +do_backtrace_with_context(void *context) +{ + unw_word_t ip; + int ret = -UNW_ENOINFO; + int depth = 0; + int i, m; + + if (verbose) + printf ("\tnormal trace:\n"); + + if (unw_init_local2 (&cursor, (unw_context_t*)context, UNW_INIT_SIGNAL_FRAME) < 0) + panic ("unw_init_local2 failed!\n"); + + do + { + unw_get_reg (&cursor, UNW_REG_IP, &ip); + addresses0depth = (void *) ip; + } + while ((ret = unw_step (&cursor)) > 0 && ++depth < 128); + + if (ret < 0) + { + unw_get_reg (&cursor, UNW_REG_IP, &ip); + printf ("FAILURE: unw_step() returned %d for ip=%lx\n", ret, (long) ip); + ++num_errors; + } + + if (verbose) + for (i = 0; i < depth; ++i) + printf ("\t #%-3d ip=%p\n", i, addresses0i); + + if (verbose) + printf ("\n\tvia unw_backtrace2():\n"); + + m = unw_backtrace2 (addresses1, 128, (unw_context_t*)context, UNW_INIT_SIGNAL_FRAME); + + if (verbose) + for (i = 0; i < m; ++i) + printf ("\t #%-3d ip=%p\n", i, addresses1i); + + if (m != depth+1) + { + printf ("FAILURE: unw_step() loop and unw_backtrace2() depths differ: %d vs. %d\n", depth, m); + ++num_errors; + } + + if (m == depth + 1) + for (i = 0; i < depth; ++i) + /* Allow one in difference in comparison, trace returns adjusted addresses. */ + if (labs((unw_word_t) addresses0i - (unw_word_t) addresses1i) > 1) + { + printf ("FAILURE: unw_step() loop and uwn_backtrace2() addresses differ at %d: %p vs. %p\n", + i, addresses0i, addresses1i); + ++num_errors; + } +} + +void foo (long val UNUSED) { do_backtrace (); @@ -222,13 +280,16 @@ printf ("\n"); } do_backtrace(); + do_backtrace_with_context(context); } int main (int argc, char **argv UNUSED) { struct sigaction act; +#ifdef HAVE_SIGALTSTACK stack_t stk; +#endif /* HAVE_SIGALTSTACK */ verbose = (argc > 1); @@ -247,6 +308,7 @@ printf ("\nBacktrace across signal handler:\n"); kill (getpid (), SIGTERM); +#ifdef HAVE_SIGALTSTACK if (verbose) printf ("\nBacktrace across signal handler on alternate stack:\n"); stk.ss_sp = malloc (SIG_STACK_SIZE); @@ -263,6 +325,7 @@ if (sigaction (SIGTERM, &act, NULL) < 0) panic ("sigaction: %s\n", strerror (errno)); kill (getpid (), SIGTERM); +#endif /* HAVE_SIGALTSTACK */ if (num_errors > 0) { @@ -274,9 +337,11 @@ printf ("SUCCESS.\n"); signal (SIGTERM, SIG_DFL); +#ifdef HAVE_SIGALTSTACK stk.ss_flags = SS_DISABLE; sigaltstack (&stk, NULL); free (stk.ss_sp); +#endif /* HAVE_SIGALTSTACK */ return 0; }
View file
_service:tar_scm:libunwind-1.7.2.tar.gz/tests/Larm64-test-sve-signal.c
Added
@@ -0,0 +1,5 @@ +#define UNW_LOCAL_ONLY +#include <libunwind.h> +#if !defined(UNW_REMOTE_ONLY) +#include "Garm64-test-sve-signal.c" +#endif
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/tests/Makefile.am -> _service:tar_scm:libunwind-1.7.2.tar.gz/tests/Makefile.am
Changed
@@ -1,6 +1,8 @@ AM_CPPFLAGS = -I$(top_srcdir)/include AM_CFLAGS = -fno-optimize-sibling-calls +LOG_DRIVER = $(SHELL) $(UNW_TESTDRIVER) + EXTRA_DIST = run-ia64-test-dyn1 run-ptrace-mapper run-ptrace-misc \ run-check-namespace run-coredump-unwind \ run-coredump-unwind-mdi check-namespace.sh.in \ @@ -44,13 +46,17 @@ endif #ARCH X86_64 endif #!ARCH_PPC64 endif #!ARCH_IA64 + +if ARCH_AARCH64 + check_PROGRAMS_arch += Garm64-test-sve-signal Larm64-test-sve-signal +endif + check_PROGRAMS_cdep += Gtest-bt Ltest-bt Gtest-exc Ltest-exc \ Gtest-init Ltest-init \ Gtest-concurrent Ltest-concurrent \ Gtest-resume-sig Ltest-resume-sig \ Gtest-resume-sig-rt Ltest-resume-sig-rt \ Gtest-trace Ltest-trace \ - Ltest-init-local-signal \ Ltest-mem-validate \ test-async-sig test-flush-cache test-init-remote \ test-mem test-reg-state Ltest-varargs \ @@ -58,6 +64,11 @@ noinst_PROGRAMS_cdep += forker Gperf-simple Lperf-simple \ Gperf-trace Lperf-trace +# unw_init_local2() is not implemented on ia64 +if !ARCH_IA64 + check_PROGRAMS_cdep += Ltest-init-local-signal +endif + if BUILD_PTRACE check_SCRIPTS_cdep += run-ptrace-mapper run-ptrace-misc check_PROGRAMS_cdep += test-ptrace @@ -125,6 +136,10 @@ XFAIL_TESTS += $(XFAIL_TESTS_PTRACE_SINGLESTEP) endif +if ARCH_LOONGARCH64 +XFAIL_TESTS += $(XFAIL_TESTS_PTRACE_SINGLESTEP) +endif + # This is meant for multilib binaries, -m32. # ptrace gives EBADREG when testing, # but generally everything else works. @@ -155,6 +170,10 @@ Lx64_test_dwarf_expressions_SOURCES = Lx64-test-dwarf-expressions.c \ x64-test-dwarf-expressions.S +Garm64_test_sve_signal_SOURCES = Garm64-test-sve-signal.c +Larm64_test_sve_signal_SOURCES = Larm64-test-sve-signal.c +Garm64_test_sve_signal_CFLAGS = -fno-inline -march=native +Larm64_test_sve_signal_CFLAGS = -fno-inline -march=native Gtest_init_SOURCES = Gtest-init.cxx Ltest_init_SOURCES = Ltest-init.cxx @@ -255,3 +274,6 @@ Gx64_test_dwarf_expressions_LDADD = $(LIBUNWIND) $(LIBUNWIND_local) Lx64_test_dwarf_expressions_LDADD = $(LIBUNWIND_local) + +Garm64_test_sve_signal_LDADD = $(LIBUNWIND) $(LIBUNWIND_local) +Larm64_test_sve_signal_LDADD = $(LIBUNWIND_local)
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/tests/Makefile.in -> _service:tar_scm:libunwind-1.7.2.tar.gz/tests/Makefile.in
Changed
@@ -1,7 +1,7 @@ -# Makefile.in generated by automake 1.16.4 from Makefile.am. +# Makefile.in generated by automake 1.15 from Makefile.am. # @configure_input@ -# Copyright (C) 1994-2021 Free Software Foundation, Inc. +# 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, @@ -99,47 +99,53 @@ @ARCH_IA64_FALSE@@ARCH_PPC64_TRUE@@REMOTE_ONLY_FALSE@@USE_ALTIVEC_TRUE@am__append_4 = ppc64-test-altivec @ARCH_IA64_FALSE@@ARCH_PPC64_FALSE@@ARCH_X86_64_TRUE@@REMOTE_ONLY_FALSE@am__append_5 = Gx64-test-dwarf-expressions Lx64-test-dwarf-expressions x64-unwind-badjmp-signal-frame -@REMOTE_ONLY_FALSE@am__append_6 = Gtest-bt Ltest-bt Gtest-exc Ltest-exc \ +@ARCH_AARCH64_TRUE@@REMOTE_ONLY_FALSE@am__append_6 = Garm64-test-sve-signal Larm64-test-sve-signal +@REMOTE_ONLY_FALSE@am__append_7 = Gtest-bt Ltest-bt Gtest-exc Ltest-exc \ @REMOTE_ONLY_FALSE@ Gtest-init Ltest-init \ @REMOTE_ONLY_FALSE@ Gtest-concurrent Ltest-concurrent \ @REMOTE_ONLY_FALSE@ Gtest-resume-sig Ltest-resume-sig \ @REMOTE_ONLY_FALSE@ Gtest-resume-sig-rt Ltest-resume-sig-rt \ @REMOTE_ONLY_FALSE@ Gtest-trace Ltest-trace \ -@REMOTE_ONLY_FALSE@ Ltest-init-local-signal \ @REMOTE_ONLY_FALSE@ Ltest-mem-validate \ @REMOTE_ONLY_FALSE@ test-async-sig test-flush-cache test-init-remote \ @REMOTE_ONLY_FALSE@ test-mem test-reg-state Ltest-varargs \ @REMOTE_ONLY_FALSE@ Ltest-nomalloc Ltest-nocalloc Lrs-race -@REMOTE_ONLY_FALSE@am__append_7 = forker Gperf-simple Lperf-simple \ +@REMOTE_ONLY_FALSE@am__append_8 = forker Gperf-simple Lperf-simple \ @REMOTE_ONLY_FALSE@ Gperf-trace Lperf-trace -@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@am__append_8 = run-ptrace-mapper run-ptrace-misc -@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@am__append_9 = test-ptrace -@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@am__append_10 = mapper test-ptrace-misc -@BUILD_SETJMP_TRUE@@REMOTE_ONLY_FALSE@am__append_11 = test-setjmp -@REMOTE_ONLY_FALSE@@SUPPORT_CXX_EXCEPTIONS_TRUE@am__append_12 = Ltest-cxx-exceptions -@BUILD_COREDUMP_TRUE@@OS_LINUX_TRUE@@REMOTE_ONLY_FALSE@am__append_13 = run-coredump-unwind -@BUILD_COREDUMP_TRUE@@OS_LINUX_TRUE@@REMOTE_ONLY_FALSE@am__append_14 = crasher test-coredump-unwind -@BUILD_COREDUMP_TRUE@@HAVE_LZMA_TRUE@@OS_LINUX_TRUE@@REMOTE_ONLY_FALSE@am__append_15 = run-coredump-unwind-mdi -check_PROGRAMS = $(am__EXEEXT_1) $(am__EXEEXT_7) $(am__EXEEXT_10) -XFAIL_TESTS = $(am__append_17) $(am__append_18) $(am__append_19) \ - $(am__EXEEXT_19) -@ARCH_IA64_TRUE@am__append_16 = Gtest-dyn1 Ltest-dyn1 -@ARCH_MIPS_TRUE@am__append_17 = $(XFAIL_TESTS_PTRACE_SINGLESTEP) -@ARCH_RISCV_TRUE@am__append_18 = $(XFAIL_TESTS_PTRACE_SINGLESTEP) + +# unw_init_local2() is not implemented on ia64 +@ARCH_IA64_FALSE@@REMOTE_ONLY_FALSE@am__append_9 = Ltest-init-local-signal +@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@am__append_10 = run-ptrace-mapper run-ptrace-misc +@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@am__append_11 = test-ptrace +@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@am__append_12 = mapper test-ptrace-misc +@BUILD_SETJMP_TRUE@@REMOTE_ONLY_FALSE@am__append_13 = test-setjmp +@REMOTE_ONLY_FALSE@@SUPPORT_CXX_EXCEPTIONS_TRUE@am__append_14 = Ltest-cxx-exceptions +@BUILD_COREDUMP_TRUE@@OS_LINUX_TRUE@@REMOTE_ONLY_FALSE@am__append_15 = run-coredump-unwind +@BUILD_COREDUMP_TRUE@@OS_LINUX_TRUE@@REMOTE_ONLY_FALSE@am__append_16 = crasher test-coredump-unwind +@BUILD_COREDUMP_TRUE@@HAVE_LZMA_TRUE@@OS_LINUX_TRUE@@REMOTE_ONLY_FALSE@am__append_17 = run-coredump-unwind-mdi +check_PROGRAMS = $(am__EXEEXT_1) $(am__EXEEXT_8) $(am__EXEEXT_12) +XFAIL_TESTS = $(am__append_19) $(am__append_20) $(am__append_21) \ + $(am__append_22) $(am__EXEEXT_21) +@ARCH_IA64_TRUE@am__append_18 = Gtest-dyn1 Ltest-dyn1 +@ARCH_MIPS_TRUE@am__append_19 = $(XFAIL_TESTS_PTRACE_SINGLESTEP) +@ARCH_RISCV_TRUE@am__append_20 = $(XFAIL_TESTS_PTRACE_SINGLESTEP) # ARM Linux kernel >=2.6.39 removed PTRACE_SINGLESTEP emulation -@ARCH_ARM_TRUE@am__append_19 = $(XFAIL_TESTS_PTRACE_SINGLESTEP) +@ARCH_ARM_TRUE@am__append_21 = $(XFAIL_TESTS_PTRACE_SINGLESTEP) +@ARCH_LOONGARCH64_TRUE@am__append_22 = $(XFAIL_TESTS_PTRACE_SINGLESTEP) # This is meant for multilib binaries, -m32. # ptrace gives EBADREG when testing, # but generally everything else works. -@NO_PTRACE_TEST_TRUE@am__append_20 = run-ptrace-mapper test-ptrace Ltest-init-local-signal -noinst_PROGRAMS = $(am__EXEEXT_11) $(am__EXEEXT_15) $(am__EXEEXT_18) +@NO_PTRACE_TEST_TRUE@am__append_23 = run-ptrace-mapper test-ptrace Ltest-init-local-signal +noinst_PROGRAMS = $(am__EXEEXT_13) $(am__EXEEXT_17) $(am__EXEEXT_20) subdir = tests ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/acinclude.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)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) @@ -160,7 +166,6 @@ @REMOTE_ONLY_FALSE@ Gtest-resume-sig-rt$(EXEEXT) \ @REMOTE_ONLY_FALSE@ Ltest-resume-sig-rt$(EXEEXT) \ @REMOTE_ONLY_FALSE@ Gtest-trace$(EXEEXT) Ltest-trace$(EXEEXT) \ -@REMOTE_ONLY_FALSE@ Ltest-init-local-signal$(EXEEXT) \ @REMOTE_ONLY_FALSE@ Ltest-mem-validate$(EXEEXT) \ @REMOTE_ONLY_FALSE@ test-async-sig$(EXEEXT) \ @REMOTE_ONLY_FALSE@ test-flush-cache$(EXEEXT) \ @@ -169,15 +174,16 @@ @REMOTE_ONLY_FALSE@ Ltest-varargs$(EXEEXT) \ @REMOTE_ONLY_FALSE@ Ltest-nomalloc$(EXEEXT) \ @REMOTE_ONLY_FALSE@ Ltest-nocalloc$(EXEEXT) Lrs-race$(EXEEXT) -@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_3 = \ +@ARCH_IA64_FALSE@@REMOTE_ONLY_FALSE@am__EXEEXT_3 = Ltest-init-local-signal$(EXEEXT) +@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_4 = \ @BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@ test-ptrace$(EXEEXT) -@BUILD_SETJMP_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_4 = \ +@BUILD_SETJMP_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_5 = \ @BUILD_SETJMP_TRUE@@REMOTE_ONLY_FALSE@ test-setjmp$(EXEEXT) -@REMOTE_ONLY_FALSE@@SUPPORT_CXX_EXCEPTIONS_TRUE@am__EXEEXT_5 = Ltest-cxx-exceptions$(EXEEXT) -@ARCH_IA64_TRUE@am__EXEEXT_6 = Gtest-dyn1$(EXEEXT) Ltest-dyn1$(EXEEXT) -am__EXEEXT_7 = $(am__EXEEXT_2) $(am__EXEEXT_3) $(am__EXEEXT_4) \ - $(am__EXEEXT_5) $(am__EXEEXT_6) -@ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_8 = \ +@REMOTE_ONLY_FALSE@@SUPPORT_CXX_EXCEPTIONS_TRUE@am__EXEEXT_6 = Ltest-cxx-exceptions$(EXEEXT) +@ARCH_IA64_TRUE@am__EXEEXT_7 = Gtest-dyn1$(EXEEXT) Ltest-dyn1$(EXEEXT) +am__EXEEXT_8 = $(am__EXEEXT_2) $(am__EXEEXT_3) $(am__EXEEXT_4) \ + $(am__EXEEXT_5) $(am__EXEEXT_6) $(am__EXEEXT_7) +@ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_9 = \ @ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@ Gia64-test-stack$(EXEEXT) \ @ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@ Lia64-test-stack$(EXEEXT) \ @ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@ Gia64-test-nat$(EXEEXT) \ @@ -188,32 +194,42 @@ @ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@ Lia64-test-readonly$(EXEEXT) \ @ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@ ia64-test-setjmp$(EXEEXT) \ @ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@ ia64-test-sig$(EXEEXT) -@ARCH_IA64_FALSE@@ARCH_PPC64_FALSE@@ARCH_X86_64_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_9 = Gx64-test-dwarf-expressions$(EXEEXT) \ +@ARCH_IA64_FALSE@@ARCH_PPC64_FALSE@@ARCH_X86_64_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_10 = Gx64-test-dwarf-expressions$(EXEEXT) \ @ARCH_IA64_FALSE@@ARCH_PPC64_FALSE@@ARCH_X86_64_TRUE@@REMOTE_ONLY_FALSE@ Lx64-test-dwarf-expressions$(EXEEXT) \ @ARCH_IA64_FALSE@@ARCH_PPC64_FALSE@@ARCH_X86_64_TRUE@@REMOTE_ONLY_FALSE@ x64-unwind-badjmp-signal-frame$(EXEEXT) -am__EXEEXT_10 = $(am__EXEEXT_8) $(am__EXEEXT_9) -am__EXEEXT_11 = -@REMOTE_ONLY_FALSE@am__EXEEXT_12 = forker$(EXEEXT) \ +@ARCH_AARCH64_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_11 = Garm64-test-sve-signal$(EXEEXT) \ +@ARCH_AARCH64_TRUE@@REMOTE_ONLY_FALSE@ Larm64-test-sve-signal$(EXEEXT) +am__EXEEXT_12 = $(am__EXEEXT_9) $(am__EXEEXT_10) $(am__EXEEXT_11) +am__EXEEXT_13 = +@REMOTE_ONLY_FALSE@am__EXEEXT_14 = forker$(EXEEXT) \ @REMOTE_ONLY_FALSE@ Gperf-simple$(EXEEXT) Lperf-simple$(EXEEXT) \ @REMOTE_ONLY_FALSE@ Gperf-trace$(EXEEXT) Lperf-trace$(EXEEXT) -@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_13 = mapper$(EXEEXT) \ +@BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_15 = mapper$(EXEEXT) \ @BUILD_PTRACE_TRUE@@REMOTE_ONLY_FALSE@ test-ptrace-misc$(EXEEXT) -@BUILD_COREDUMP_TRUE@@OS_LINUX_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_14 = crasher$(EXEEXT) \ +@BUILD_COREDUMP_TRUE@@OS_LINUX_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_16 = crasher$(EXEEXT) \ @BUILD_COREDUMP_TRUE@@OS_LINUX_TRUE@@REMOTE_ONLY_FALSE@ test-coredump-unwind$(EXEEXT) -am__EXEEXT_15 = $(am__EXEEXT_12) $(am__EXEEXT_13) $(am__EXEEXT_14) -@ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_16 = \ +am__EXEEXT_17 = $(am__EXEEXT_14) $(am__EXEEXT_15) $(am__EXEEXT_16) +@ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@am__EXEEXT_18 = \ @ARCH_IA64_TRUE@@REMOTE_ONLY_FALSE@ ia64-test-dyn1$(EXEEXT) -@ARCH_IA64_FALSE@@ARCH_PPC64_TRUE@@REMOTE_ONLY_FALSE@@USE_ALTIVEC_TRUE@am__EXEEXT_17 = ppc64-test-altivec$(EXEEXT) -am__EXEEXT_18 = $(am__EXEEXT_16) $(am__EXEEXT_17) +@ARCH_IA64_FALSE@@ARCH_PPC64_TRUE@@REMOTE_ONLY_FALSE@@USE_ALTIVEC_TRUE@am__EXEEXT_19 = ppc64-test-altivec$(EXEEXT) +am__EXEEXT_20 = $(am__EXEEXT_18) $(am__EXEEXT_19) PROGRAMS = $(noinst_PROGRAMS) -am_Gia64_test_nat_OBJECTS = Gia64-test-nat.$(OBJEXT) \ - ia64-test-nat-asm.$(OBJEXT) -Gia64_test_nat_OBJECTS = $(am_Gia64_test_nat_OBJECTS) -Gia64_test_nat_DEPENDENCIES = $(LIBUNWIND) $(LIBUNWIND_local) +am_Garm64_test_sve_signal_OBJECTS = \ + Garm64_test_sve_signal-Garm64-test-sve-signal.$(OBJEXT) +Garm64_test_sve_signal_OBJECTS = $(am_Garm64_test_sve_signal_OBJECTS) +Garm64_test_sve_signal_DEPENDENCIES = $(LIBUNWIND) $(LIBUNWIND_local) 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 = +Garm64_test_sve_signal_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ + $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ + $(Garm64_test_sve_signal_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) \ + $(LDFLAGS) -o $@ +am_Gia64_test_nat_OBJECTS = Gia64-test-nat.$(OBJEXT) \ + ia64-test-nat-asm.$(OBJEXT) +Gia64_test_nat_OBJECTS = $(am_Gia64_test_nat_OBJECTS) +Gia64_test_nat_DEPENDENCIES = $(LIBUNWIND) $(LIBUNWIND_local) am_Gia64_test_rbs_OBJECTS = Gia64-test-rbs.$(OBJEXT) \ ia64-test-rbs-asm.$(OBJEXT) Gia64_test_rbs_OBJECTS = $(am_Gia64_test_rbs_OBJECTS) @@ -263,6 +279,14 @@ $(am_Gx64_test_dwarf_expressions_OBJECTS) Gx64_test_dwarf_expressions_DEPENDENCIES = $(LIBUNWIND) \ $(LIBUNWIND_local) +am_Larm64_test_sve_signal_OBJECTS = \ + Larm64_test_sve_signal-Larm64-test-sve-signal.$(OBJEXT) +Larm64_test_sve_signal_OBJECTS = $(am_Larm64_test_sve_signal_OBJECTS) +Larm64_test_sve_signal_DEPENDENCIES = $(LIBUNWIND_local) +Larm64_test_sve_signal_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ + $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ + $(Larm64_test_sve_signal_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) \ + $(LDFLAGS) -o $@ am_Lia64_test_nat_OBJECTS = Lia64-test-nat.$(OBJEXT) \ ia64-test-nat-asm.$(OBJEXT) Lia64_test_nat_OBJECTS = $(am_Lia64_test_nat_OBJECTS) @@ -428,56 +452,11 @@ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)/include depcomp = $(SHELL) $(top_srcdir)/config/depcomp -am__maybe_remake_depfiles = depfiles -am__depfiles_remade = ./$(DEPDIR)/Gia64-test-nat.Po \ - ./$(DEPDIR)/Gia64-test-rbs.Po \ - ./$(DEPDIR)/Gia64-test-readonly.Po \ - ./$(DEPDIR)/Gia64-test-stack.Po ./$(DEPDIR)/Gperf-simple.Po \ - ./$(DEPDIR)/Gperf-trace.Po ./$(DEPDIR)/Gtest-bt.Po \ - ./$(DEPDIR)/Gtest-concurrent.Po ./$(DEPDIR)/Gtest-dyn1.Po \ - ./$(DEPDIR)/Gtest-exc.Po ./$(DEPDIR)/Gtest-init.Po \ - ./$(DEPDIR)/Gtest-resume-sig-rt.Po \ - ./$(DEPDIR)/Gtest-resume-sig.Po ./$(DEPDIR)/Gtest-trace.Po \ - ./$(DEPDIR)/Gx64-test-dwarf-expressions.Po \ - ./$(DEPDIR)/Lia64-test-nat.Po ./$(DEPDIR)/Lia64-test-rbs.Po \ - ./$(DEPDIR)/Lia64-test-readonly.Po \ - ./$(DEPDIR)/Lia64-test-stack.Po ./$(DEPDIR)/Lperf-simple.Po \ - ./$(DEPDIR)/Lperf-trace.Po ./$(DEPDIR)/Lrs-race.Po \ - ./$(DEPDIR)/Ltest-bt.Po ./$(DEPDIR)/Ltest-concurrent.Po \ - ./$(DEPDIR)/Ltest-cxx-exceptions.Po ./$(DEPDIR)/Ltest-dyn1.Po \ - ./$(DEPDIR)/Ltest-exc.Po \ - ./$(DEPDIR)/Ltest-init-local-signal-lib.Po \ - ./$(DEPDIR)/Ltest-init-local-signal.Po \ - ./$(DEPDIR)/Ltest-init.Po ./$(DEPDIR)/Ltest-mem-validate.Po \ - ./$(DEPDIR)/Ltest-nocalloc.Po ./$(DEPDIR)/Ltest-nomalloc.Po \ - ./$(DEPDIR)/Ltest-resume-sig-rt.Po \ - ./$(DEPDIR)/Ltest-resume-sig.Po ./$(DEPDIR)/Ltest-trace.Po \ - ./$(DEPDIR)/Ltest-varargs.Po \ - ./$(DEPDIR)/Lx64-test-dwarf-expressions.Po \ - ./$(DEPDIR)/crasher.Po ./$(DEPDIR)/flush-cache.Po \ - ./$(DEPDIR)/forker.Po ./$(DEPDIR)/ia64-dyn-asm.Po \ - ./$(DEPDIR)/ia64-test-dyn1.Po ./$(DEPDIR)/ia64-test-nat-asm.Po \ - ./$(DEPDIR)/ia64-test-rbs-asm.Po \ - ./$(DEPDIR)/ia64-test-readonly-asm.Po \ - ./$(DEPDIR)/ia64-test-setjmp.Po ./$(DEPDIR)/ia64-test-sig.Po \ - ./$(DEPDIR)/ia64-test-stack-asm.Po ./$(DEPDIR)/ident.Po \ - ./$(DEPDIR)/mapper.Po ./$(DEPDIR)/ppc64-test-altivec-utils.Po \ - ./$(DEPDIR)/ppc64-test-altivec.Po \ - ./$(DEPDIR)/test-async-sig.Po \ - ./$(DEPDIR)/test-coredump-unwind.Po \ - ./$(DEPDIR)/test-flush-cache.Po \ - ./$(DEPDIR)/test-init-remote.Po ./$(DEPDIR)/test-mem.Po \ - ./$(DEPDIR)/test-proc-info.Po ./$(DEPDIR)/test-ptrace-misc.Po \ - ./$(DEPDIR)/test-ptrace.Po ./$(DEPDIR)/test-reg-state.Po \ - ./$(DEPDIR)/test-setjmp.Po ./$(DEPDIR)/test-static-link-gen.Po \ - ./$(DEPDIR)/test-static-link-loc.Po \ - ./$(DEPDIR)/test-strerror.Po \ - ./$(DEPDIR)/x64-test-dwarf-expressions.Po \ - ./$(DEPDIR)/x64-unwind-badjmp-signal-frame.Po +am__depfiles_maybe = depfiles am__mv = mv -f CPPASCOMPILE = $(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CCASFLAGS) $(CCASFLAGS) -LTCPPASCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ +LTCPPASCOMPILE = $(LIBTOOL) $(AM_V_lt) $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CCAS) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CCASFLAGS) $(CCASFLAGS) @@ -521,17 +500,19 @@ am__v_CXXLD_ = $(am__v_CXXLD_@AM_DEFAULT_V@) am__v_CXXLD_0 = @echo " CXXLD " $@; am__v_CXXLD_1 = -SOURCES = $(Gia64_test_nat_SOURCES) $(Gia64_test_rbs_SOURCES) \ - $(Gia64_test_readonly_SOURCES) $(Gia64_test_stack_SOURCES) \ - Gperf-simple.c Gperf-trace.c $(Gtest_bt_SOURCES) \ - Gtest-concurrent.c $(Gtest_dyn1_SOURCES) Gtest-exc.c \ - $(Gtest_init_SOURCES) Gtest-resume-sig.c Gtest-resume-sig-rt.c \ - $(Gtest_trace_SOURCES) $(Gx64_test_dwarf_expressions_SOURCES) \ - $(Lia64_test_nat_SOURCES) $(Lia64_test_rbs_SOURCES) \ - $(Lia64_test_readonly_SOURCES) $(Lia64_test_stack_SOURCES) \ - Lperf-simple.c Lperf-trace.c Lrs-race.c $(Ltest_bt_SOURCES) \ - Ltest-concurrent.c $(Ltest_cxx_exceptions_SOURCES) \ - $(Ltest_dyn1_SOURCES) Ltest-exc.c $(Ltest_init_SOURCES) \ +SOURCES = $(Garm64_test_sve_signal_SOURCES) $(Gia64_test_nat_SOURCES) \ + $(Gia64_test_rbs_SOURCES) $(Gia64_test_readonly_SOURCES) \ + $(Gia64_test_stack_SOURCES) Gperf-simple.c Gperf-trace.c \ + $(Gtest_bt_SOURCES) Gtest-concurrent.c $(Gtest_dyn1_SOURCES) \ + Gtest-exc.c $(Gtest_init_SOURCES) Gtest-resume-sig.c \ + Gtest-resume-sig-rt.c $(Gtest_trace_SOURCES) \ + $(Gx64_test_dwarf_expressions_SOURCES) \ + $(Larm64_test_sve_signal_SOURCES) $(Lia64_test_nat_SOURCES) \ + $(Lia64_test_rbs_SOURCES) $(Lia64_test_readonly_SOURCES) \ + $(Lia64_test_stack_SOURCES) Lperf-simple.c Lperf-trace.c \ + Lrs-race.c $(Ltest_bt_SOURCES) Ltest-concurrent.c \ + $(Ltest_cxx_exceptions_SOURCES) $(Ltest_dyn1_SOURCES) \ + Ltest-exc.c $(Ltest_init_SOURCES) \ $(Ltest_init_local_signal_SOURCES) \ $(Ltest_mem_validate_SOURCES) $(Ltest_nocalloc_SOURCES) \ $(Ltest_nomalloc_SOURCES) Ltest-resume-sig.c \ @@ -544,17 +525,19 @@ $(test_ptrace_misc_SOURCES) test-reg-state.c test-setjmp.c \ $(test_static_link_SOURCES) test-strerror.c \ $(x64_unwind_badjmp_signal_frame_SOURCES) -DIST_SOURCES = $(Gia64_test_nat_SOURCES) $(Gia64_test_rbs_SOURCES) \ +DIST_SOURCES = $(Garm64_test_sve_signal_SOURCES) \ + $(Gia64_test_nat_SOURCES) $(Gia64_test_rbs_SOURCES) \ $(Gia64_test_readonly_SOURCES) $(Gia64_test_stack_SOURCES) \ Gperf-simple.c Gperf-trace.c $(Gtest_bt_SOURCES) \ Gtest-concurrent.c $(Gtest_dyn1_SOURCES) Gtest-exc.c \ $(Gtest_init_SOURCES) Gtest-resume-sig.c Gtest-resume-sig-rt.c \ $(Gtest_trace_SOURCES) $(Gx64_test_dwarf_expressions_SOURCES) \ - $(Lia64_test_nat_SOURCES) $(Lia64_test_rbs_SOURCES) \ - $(Lia64_test_readonly_SOURCES) $(Lia64_test_stack_SOURCES) \ - Lperf-simple.c Lperf-trace.c Lrs-race.c $(Ltest_bt_SOURCES) \ - Ltest-concurrent.c $(Ltest_cxx_exceptions_SOURCES) \ - $(Ltest_dyn1_SOURCES) Ltest-exc.c $(Ltest_init_SOURCES) \ + $(Larm64_test_sve_signal_SOURCES) $(Lia64_test_nat_SOURCES) \ + $(Lia64_test_rbs_SOURCES) $(Lia64_test_readonly_SOURCES) \ + $(Lia64_test_stack_SOURCES) Lperf-simple.c Lperf-trace.c \ + Lrs-race.c $(Ltest_bt_SOURCES) Ltest-concurrent.c \ + $(Ltest_cxx_exceptions_SOURCES) $(Ltest_dyn1_SOURCES) \ + Ltest-exc.c $(Ltest_init_SOURCES) \ $(Ltest_init_local_signal_SOURCES) \ $(Ltest_mem_validate_SOURCES) $(Ltest_nocalloc_SOURCES) \ $(Ltest_nomalloc_SOURCES) Ltest-resume-sig.c \ @@ -589,6 +572,8 @@ 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 @@ -771,15 +756,13 @@ bases='$(TEST_LOGS)'; \ bases=`for i in $$bases; do echo $$i; done | sed 's/\.log$$//'`; \ bases=`echo $$bases` -AM_TESTSUITE_SUMMARY_HEADER = ' for $(PACKAGE_STRING)' RECHECK_LOGS = $(TEST_LOGS) AM_RECURSIVE_TARGETS = check recheck -@NO_PTRACE_TEST_TRUE@am__EXEEXT_19 = run-ptrace-mapper \ +@NO_PTRACE_TEST_TRUE@am__EXEEXT_21 = run-ptrace-mapper \ @NO_PTRACE_TEST_TRUE@ test-ptrace$(EXEEXT) \ @NO_PTRACE_TEST_TRUE@ Ltest-init-local-signal$(EXEEXT) TEST_SUITE_LOG = test-suite.log TEST_EXTENSIONS = @EXEEXT@ .test -LOG_DRIVER = $(SHELL) $(top_srcdir)/config/test-driver LOG_COMPILE = $(LOG_COMPILER) $(AM_LOG_FLAGS) $(LOG_FLAGS) am__set_b = \ case '$@' in \ @@ -819,8 +802,6 @@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ -CSCOPE = @CSCOPE@ -CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ @@ -836,7 +817,6 @@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ -ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ @@ -887,6 +867,7 @@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ +UNW_TESTDRIVER = @UNW_TESTDRIVER@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ @@ -952,6 +933,7 @@ top_srcdir = @top_srcdir@ AM_CPPFLAGS = -I$(top_srcdir)/include AM_CFLAGS = -fno-optimize-sibling-calls +LOG_DRIVER = $(SHELL) $(UNW_TESTDRIVER) EXTRA_DIST = run-ia64-test-dyn1 run-ptrace-mapper run-ptrace-misc \ run-check-namespace run-coredump-unwind \ run-coredump-unwind-mdi check-namespace.sh.in \ @@ -959,17 +941,18 @@ MAINTAINERCLEANFILES = Makefile.in noinst_PROGRAMS_arch = $(am__append_1) $(am__append_4) -noinst_PROGRAMS_cdep = $(am__append_7) $(am__append_10) \ - $(am__append_14) +noinst_PROGRAMS_cdep = $(am__append_8) $(am__append_12) \ + $(am__append_16) noinst_PROGRAMS_common = -check_PROGRAMS_arch = $(am__append_3) $(am__append_5) -check_PROGRAMS_cdep = $(am__append_6) $(am__append_9) $(am__append_11) \ - $(am__append_12) $(am__append_16) +check_PROGRAMS_arch = $(am__append_3) $(am__append_5) $(am__append_6) +check_PROGRAMS_cdep = $(am__append_7) $(am__append_9) $(am__append_11) \ + $(am__append_13) $(am__append_14) $(am__append_18) check_PROGRAMS_common = test-proc-info test-static-link \ test-strerror check_SCRIPTS_arch = $(am__append_2) -check_SCRIPTS_cdep = $(am__append_8) $(am__append_13) $(am__append_15) +check_SCRIPTS_cdep = $(am__append_10) $(am__append_15) \ + $(am__append_17) check_SCRIPTS_common = run-check-namespace @REMOTE_ONLY_FALSE@LIBUNWIND_local = $(top_builddir)/src/libunwind.la check_SCRIPTS = $(check_SCRIPTS_common) $(check_SCRIPTS_cdep) \ @@ -1002,6 +985,10 @@ Lx64_test_dwarf_expressions_SOURCES = Lx64-test-dwarf-expressions.c \ x64-test-dwarf-expressions.S +Garm64_test_sve_signal_SOURCES = Garm64-test-sve-signal.c +Larm64_test_sve_signal_SOURCES = Larm64-test-sve-signal.c +Garm64_test_sve_signal_CFLAGS = -fno-inline -march=native +Larm64_test_sve_signal_CFLAGS = -fno-inline -march=native Gtest_init_SOURCES = Gtest-init.cxx Ltest_init_SOURCES = Ltest-init.cxx Ltest_cxx_exceptions_SOURCES = Ltest-cxx-exceptions.cxx @@ -1082,6 +1069,8 @@ ppc64_test_altivec_LDADD = $(LIBUNWIND) Gx64_test_dwarf_expressions_LDADD = $(LIBUNWIND) $(LIBUNWIND_local) Lx64_test_dwarf_expressions_LDADD = $(LIBUNWIND_local) +Garm64_test_sve_signal_LDADD = $(LIBUNWIND) $(LIBUNWIND_local) +Larm64_test_sve_signal_LDADD = $(LIBUNWIND_local) all: all-am .SUFFIXES: @@ -1103,8 +1092,8 @@ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ + 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) @@ -1136,6 +1125,10 @@ echo " rm -f" $$list; \ rm -f $$list +Garm64-test-sve-signal$(EXEEXT): $(Garm64_test_sve_signal_OBJECTS) $(Garm64_test_sve_signal_DEPENDENCIES) $(EXTRA_Garm64_test_sve_signal_DEPENDENCIES) + @rm -f Garm64-test-sve-signal$(EXEEXT) + $(AM_V_CCLD)$(Garm64_test_sve_signal_LINK) $(Garm64_test_sve_signal_OBJECTS) $(Garm64_test_sve_signal_LDADD) $(LIBS) + Gia64-test-nat$(EXEEXT): $(Gia64_test_nat_OBJECTS) $(Gia64_test_nat_DEPENDENCIES) $(EXTRA_Gia64_test_nat_DEPENDENCIES) @rm -f Gia64-test-nat$(EXEEXT) $(AM_V_CCLD)$(LINK) $(Gia64_test_nat_OBJECTS) $(Gia64_test_nat_LDADD) $(LIBS) @@ -1196,6 +1189,10 @@ @rm -f Gx64-test-dwarf-expressions$(EXEEXT) $(AM_V_CCLD)$(LINK) $(Gx64_test_dwarf_expressions_OBJECTS) $(Gx64_test_dwarf_expressions_LDADD) $(LIBS) +Larm64-test-sve-signal$(EXEEXT): $(Larm64_test_sve_signal_OBJECTS) $(Larm64_test_sve_signal_DEPENDENCIES) $(EXTRA_Larm64_test_sve_signal_DEPENDENCIES) + @rm -f Larm64-test-sve-signal$(EXEEXT) + $(AM_V_CCLD)$(Larm64_test_sve_signal_LINK) $(Larm64_test_sve_signal_OBJECTS) $(Larm64_test_sve_signal_LDADD) $(LIBS) + Lia64-test-nat$(EXEEXT): $(Lia64_test_nat_OBJECTS) $(Lia64_test_nat_DEPENDENCIES) $(EXTRA_Lia64_test_nat_DEPENDENCIES) @rm -f Lia64-test-nat$(EXEEXT) $(AM_V_CCLD)$(LINK) $(Lia64_test_nat_OBJECTS) $(Lia64_test_nat_LDADD) $(LIBS) @@ -1370,80 +1367,76 @@ distclean-compile: -rm -f *.tab.c -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gia64-test-nat.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gia64-test-rbs.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gia64-test-readonly.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gia64-test-stack.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gperf-simple.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gperf-trace.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-bt.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-concurrent.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-dyn1.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-exc.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-init.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-resume-sig-rt.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-resume-sig.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-trace.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gx64-test-dwarf-expressions.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lia64-test-nat.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lia64-test-rbs.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lia64-test-readonly.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lia64-test-stack.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lperf-simple.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lperf-trace.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lrs-race.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-bt.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-concurrent.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-cxx-exceptions.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-dyn1.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-exc.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-init-local-signal-lib.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-init-local-signal.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-init.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-mem-validate.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-nocalloc.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-nomalloc.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-resume-sig-rt.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-resume-sig.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-trace.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-varargs.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lx64-test-dwarf-expressions.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/crasher.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flush-cache.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/forker.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-dyn-asm.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-dyn1.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-nat-asm.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-rbs-asm.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-readonly-asm.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-setjmp.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-sig.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-stack-asm.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ident.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mapper.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ppc64-test-altivec-utils.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ppc64-test-altivec.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-async-sig.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-coredump-unwind.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-flush-cache.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-init-remote.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-mem.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-proc-info.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-ptrace-misc.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-ptrace.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-reg-state.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-setjmp.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-static-link-gen.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-static-link-loc.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-strerror.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/x64-test-dwarf-expressions.Po@am__quote@ # am--include-marker -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/x64-unwind-badjmp-signal-frame.Po@am__quote@ # am--include-marker - -$(am__depfiles_remade): - @$(MKDIR_P) $(@D) - @echo '# dummy' >$@-t && $(am__mv) $@-t $@ - -am--depfiles: $(am__depfiles_remade) +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Garm64_test_sve_signal-Garm64-test-sve-signal.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gia64-test-nat.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gia64-test-rbs.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gia64-test-readonly.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gia64-test-stack.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gperf-simple.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gperf-trace.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-bt.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-concurrent.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-dyn1.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-exc.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-init.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-resume-sig-rt.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-resume-sig.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gtest-trace.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Gx64-test-dwarf-expressions.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Larm64_test_sve_signal-Larm64-test-sve-signal.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lia64-test-nat.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lia64-test-rbs.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lia64-test-readonly.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lia64-test-stack.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lperf-simple.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lperf-trace.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lrs-race.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-bt.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-concurrent.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-cxx-exceptions.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-dyn1.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-exc.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-init-local-signal-lib.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-init-local-signal.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-init.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-mem-validate.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-nocalloc.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-nomalloc.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-resume-sig-rt.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-resume-sig.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-trace.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Ltest-varargs.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Lx64-test-dwarf-expressions.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/crasher.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flush-cache.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/forker.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-dyn-asm.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-dyn1.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-nat-asm.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-rbs-asm.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-readonly-asm.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-setjmp.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-sig.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-test-stack-asm.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ident.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mapper.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ppc64-test-altivec-utils.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ppc64-test-altivec.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-async-sig.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-coredump-unwind.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-flush-cache.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-init-remote.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-mem.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-proc-info.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-ptrace-misc.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-ptrace.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-reg-state.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-setjmp.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-static-link-gen.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-static-link-loc.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/test-strerror.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/x64-test-dwarf-expressions.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/x64-unwind-badjmp-signal-frame.Po@am__quote@ .S.o: @am__fastdepCCAS_TRUE@ $(AM_V_CPPAS)depbase=`echo $@ | sed 's|^/*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @@ -1493,6 +1486,34 @@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< +Garm64_test_sve_signal-Garm64-test-sve-signal.o: Garm64-test-sve-signal.c +@am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(Garm64_test_sve_signal_CFLAGS) $(CFLAGS) -MT Garm64_test_sve_signal-Garm64-test-sve-signal.o -MD -MP -MF $(DEPDIR)/Garm64_test_sve_signal-Garm64-test-sve-signal.Tpo -c -o Garm64_test_sve_signal-Garm64-test-sve-signal.o `test -f 'Garm64-test-sve-signal.c' || echo '$(srcdir)/'`Garm64-test-sve-signal.c +@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/Garm64_test_sve_signal-Garm64-test-sve-signal.Tpo $(DEPDIR)/Garm64_test_sve_signal-Garm64-test-sve-signal.Po +@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='Garm64-test-sve-signal.c' object='Garm64_test_sve_signal-Garm64-test-sve-signal.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) $(AM_CPPFLAGS) $(CPPFLAGS) $(Garm64_test_sve_signal_CFLAGS) $(CFLAGS) -c -o Garm64_test_sve_signal-Garm64-test-sve-signal.o `test -f 'Garm64-test-sve-signal.c' || echo '$(srcdir)/'`Garm64-test-sve-signal.c + +Garm64_test_sve_signal-Garm64-test-sve-signal.obj: Garm64-test-sve-signal.c +@am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(Garm64_test_sve_signal_CFLAGS) $(CFLAGS) -MT Garm64_test_sve_signal-Garm64-test-sve-signal.obj -MD -MP -MF $(DEPDIR)/Garm64_test_sve_signal-Garm64-test-sve-signal.Tpo -c -o Garm64_test_sve_signal-Garm64-test-sve-signal.obj `if test -f 'Garm64-test-sve-signal.c'; then $(CYGPATH_W) 'Garm64-test-sve-signal.c'; else $(CYGPATH_W) '$(srcdir)/Garm64-test-sve-signal.c'; fi` +@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/Garm64_test_sve_signal-Garm64-test-sve-signal.Tpo $(DEPDIR)/Garm64_test_sve_signal-Garm64-test-sve-signal.Po +@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='Garm64-test-sve-signal.c' object='Garm64_test_sve_signal-Garm64-test-sve-signal.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) $(AM_CPPFLAGS) $(CPPFLAGS) $(Garm64_test_sve_signal_CFLAGS) $(CFLAGS) -c -o Garm64_test_sve_signal-Garm64-test-sve-signal.obj `if test -f 'Garm64-test-sve-signal.c'; then $(CYGPATH_W) 'Garm64-test-sve-signal.c'; else $(CYGPATH_W) '$(srcdir)/Garm64-test-sve-signal.c'; fi` + +Larm64_test_sve_signal-Larm64-test-sve-signal.o: Larm64-test-sve-signal.c +@am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(Larm64_test_sve_signal_CFLAGS) $(CFLAGS) -MT Larm64_test_sve_signal-Larm64-test-sve-signal.o -MD -MP -MF $(DEPDIR)/Larm64_test_sve_signal-Larm64-test-sve-signal.Tpo -c -o Larm64_test_sve_signal-Larm64-test-sve-signal.o `test -f 'Larm64-test-sve-signal.c' || echo '$(srcdir)/'`Larm64-test-sve-signal.c +@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/Larm64_test_sve_signal-Larm64-test-sve-signal.Tpo $(DEPDIR)/Larm64_test_sve_signal-Larm64-test-sve-signal.Po +@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='Larm64-test-sve-signal.c' object='Larm64_test_sve_signal-Larm64-test-sve-signal.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) $(AM_CPPFLAGS) $(CPPFLAGS) $(Larm64_test_sve_signal_CFLAGS) $(CFLAGS) -c -o Larm64_test_sve_signal-Larm64-test-sve-signal.o `test -f 'Larm64-test-sve-signal.c' || echo '$(srcdir)/'`Larm64-test-sve-signal.c + +Larm64_test_sve_signal-Larm64-test-sve-signal.obj: Larm64-test-sve-signal.c +@am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(Larm64_test_sve_signal_CFLAGS) $(CFLAGS) -MT Larm64_test_sve_signal-Larm64-test-sve-signal.obj -MD -MP -MF $(DEPDIR)/Larm64_test_sve_signal-Larm64-test-sve-signal.Tpo -c -o Larm64_test_sve_signal-Larm64-test-sve-signal.obj `if test -f 'Larm64-test-sve-signal.c'; then $(CYGPATH_W) 'Larm64-test-sve-signal.c'; else $(CYGPATH_W) '$(srcdir)/Larm64-test-sve-signal.c'; fi` +@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/Larm64_test_sve_signal-Larm64-test-sve-signal.Tpo $(DEPDIR)/Larm64_test_sve_signal-Larm64-test-sve-signal.Po +@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='Larm64-test-sve-signal.c' object='Larm64_test_sve_signal-Larm64-test-sve-signal.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) $(AM_CPPFLAGS) $(CPPFLAGS) $(Larm64_test_sve_signal_CFLAGS) $(CFLAGS) -c -o Larm64_test_sve_signal-Larm64-test-sve-signal.obj `if test -f 'Larm64-test-sve-signal.c'; then $(CYGPATH_W) 'Larm64-test-sve-signal.c'; else $(CYGPATH_W) '$(srcdir)/Larm64-test-sve-signal.c'; fi` + .cxx.o: @am__fastdepCXX_TRUE@ $(AM_V_CXX)depbase=`echo $@ | sed 's|^/*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ @am__fastdepCXX_TRUE@ $(CXXCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ @@ -1682,7 +1703,7 @@ test x"$$VERBOSE" = x || cat $(TEST_SUITE_LOG); \ fi; \ echo "$${col}$$br$${std}"; \ - echo "$${col}Testsuite summary"$(AM_TESTSUITE_SUMMARY_HEADER)"$${std}"; \ + echo "$${col}Testsuite summary for $(PACKAGE_STRING)$${std}"; \ echo "$${col}$$br$${std}"; \ create_testsuite_report --maybe-color; \ echo "$$col$$br$$std"; \ @@ -1695,7 +1716,7 @@ fi; \ $$success || exit 1 -check-TESTS: $(check_PROGRAMS) $(check_SCRIPTS) +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) @@ -1835,13 +1856,6 @@ --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) -Ltest-init-local-signal.log: Ltest-init-local-signal$(EXEEXT) - @p='Ltest-init-local-signal$(EXEEXT)'; \ - b='Ltest-init-local-signal'; \ - $(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) Ltest-mem-validate.log: Ltest-mem-validate$(EXEEXT) @p='Ltest-mem-validate$(EXEEXT)'; \ b='Ltest-mem-validate'; \ @@ -1912,6 +1926,13 @@ --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) +Ltest-init-local-signal.log: Ltest-init-local-signal$(EXEEXT) + @p='Ltest-init-local-signal$(EXEEXT)'; \ + b='Ltest-init-local-signal'; \ + $(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-ptrace.log: test-ptrace$(EXEEXT) @p='test-ptrace$(EXEEXT)'; \ b='test-ptrace'; \ @@ -2038,6 +2059,20 @@ --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) +Garm64-test-sve-signal.log: Garm64-test-sve-signal$(EXEEXT) + @p='Garm64-test-sve-signal$(EXEEXT)'; \ + b='Garm64-test-sve-signal'; \ + $(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) +Larm64-test-sve-signal.log: Larm64-test-sve-signal$(EXEEXT) + @p='Larm64-test-sve-signal$(EXEEXT)'; \ + b='Larm64-test-sve-signal'; \ + $(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) run-check-namespace.log: run-check-namespace @p='run-check-namespace'; \ b='run-check-namespace'; \ @@ -2094,10 +2129,8 @@ @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: $(BUILT_SOURCES) - $(MAKE) $(AM_MAKEFLAGS) distdir-am -distdir-am: $(DISTFILES) +distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/.^$$\\*/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/.^$$\\*/\\\\&/g'`; \ list='$(DISTFILES)'; \ @@ -2173,74 +2206,7 @@ clean-noinstPROGRAMS mostlyclean-am distclean: distclean-am - -rm -f ./$(DEPDIR)/Gia64-test-nat.Po - -rm -f ./$(DEPDIR)/Gia64-test-rbs.Po - -rm -f ./$(DEPDIR)/Gia64-test-readonly.Po - -rm -f ./$(DEPDIR)/Gia64-test-stack.Po - -rm -f ./$(DEPDIR)/Gperf-simple.Po - -rm -f ./$(DEPDIR)/Gperf-trace.Po - -rm -f ./$(DEPDIR)/Gtest-bt.Po - -rm -f ./$(DEPDIR)/Gtest-concurrent.Po - -rm -f ./$(DEPDIR)/Gtest-dyn1.Po - -rm -f ./$(DEPDIR)/Gtest-exc.Po - -rm -f ./$(DEPDIR)/Gtest-init.Po - -rm -f ./$(DEPDIR)/Gtest-resume-sig-rt.Po - -rm -f ./$(DEPDIR)/Gtest-resume-sig.Po - -rm -f ./$(DEPDIR)/Gtest-trace.Po - -rm -f ./$(DEPDIR)/Gx64-test-dwarf-expressions.Po - -rm -f ./$(DEPDIR)/Lia64-test-nat.Po - -rm -f ./$(DEPDIR)/Lia64-test-rbs.Po - -rm -f ./$(DEPDIR)/Lia64-test-readonly.Po - -rm -f ./$(DEPDIR)/Lia64-test-stack.Po - -rm -f ./$(DEPDIR)/Lperf-simple.Po - -rm -f ./$(DEPDIR)/Lperf-trace.Po - -rm -f ./$(DEPDIR)/Lrs-race.Po - -rm -f ./$(DEPDIR)/Ltest-bt.Po - -rm -f ./$(DEPDIR)/Ltest-concurrent.Po - -rm -f ./$(DEPDIR)/Ltest-cxx-exceptions.Po - -rm -f ./$(DEPDIR)/Ltest-dyn1.Po - -rm -f ./$(DEPDIR)/Ltest-exc.Po - -rm -f ./$(DEPDIR)/Ltest-init-local-signal-lib.Po - -rm -f ./$(DEPDIR)/Ltest-init-local-signal.Po - -rm -f ./$(DEPDIR)/Ltest-init.Po - -rm -f ./$(DEPDIR)/Ltest-mem-validate.Po - -rm -f ./$(DEPDIR)/Ltest-nocalloc.Po - -rm -f ./$(DEPDIR)/Ltest-nomalloc.Po - -rm -f ./$(DEPDIR)/Ltest-resume-sig-rt.Po - -rm -f ./$(DEPDIR)/Ltest-resume-sig.Po - -rm -f ./$(DEPDIR)/Ltest-trace.Po - -rm -f ./$(DEPDIR)/Ltest-varargs.Po - -rm -f ./$(DEPDIR)/Lx64-test-dwarf-expressions.Po - -rm -f ./$(DEPDIR)/crasher.Po - -rm -f ./$(DEPDIR)/flush-cache.Po - -rm -f ./$(DEPDIR)/forker.Po - -rm -f ./$(DEPDIR)/ia64-dyn-asm.Po - -rm -f ./$(DEPDIR)/ia64-test-dyn1.Po - -rm -f ./$(DEPDIR)/ia64-test-nat-asm.Po - -rm -f ./$(DEPDIR)/ia64-test-rbs-asm.Po - -rm -f ./$(DEPDIR)/ia64-test-readonly-asm.Po - -rm -f ./$(DEPDIR)/ia64-test-setjmp.Po - -rm -f ./$(DEPDIR)/ia64-test-sig.Po - -rm -f ./$(DEPDIR)/ia64-test-stack-asm.Po - -rm -f ./$(DEPDIR)/ident.Po - -rm -f ./$(DEPDIR)/mapper.Po - -rm -f ./$(DEPDIR)/ppc64-test-altivec-utils.Po - -rm -f ./$(DEPDIR)/ppc64-test-altivec.Po - -rm -f ./$(DEPDIR)/test-async-sig.Po - -rm -f ./$(DEPDIR)/test-coredump-unwind.Po - -rm -f ./$(DEPDIR)/test-flush-cache.Po - -rm -f ./$(DEPDIR)/test-init-remote.Po - -rm -f ./$(DEPDIR)/test-mem.Po - -rm -f ./$(DEPDIR)/test-proc-info.Po - -rm -f ./$(DEPDIR)/test-ptrace-misc.Po - -rm -f ./$(DEPDIR)/test-ptrace.Po - -rm -f ./$(DEPDIR)/test-reg-state.Po - -rm -f ./$(DEPDIR)/test-setjmp.Po - -rm -f ./$(DEPDIR)/test-static-link-gen.Po - -rm -f ./$(DEPDIR)/test-static-link-loc.Po - -rm -f ./$(DEPDIR)/test-strerror.Po - -rm -f ./$(DEPDIR)/x64-test-dwarf-expressions.Po - -rm -f ./$(DEPDIR)/x64-unwind-badjmp-signal-frame.Po + -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags @@ -2286,74 +2252,7 @@ installcheck-am: maintainer-clean: maintainer-clean-am - -rm -f ./$(DEPDIR)/Gia64-test-nat.Po - -rm -f ./$(DEPDIR)/Gia64-test-rbs.Po - -rm -f ./$(DEPDIR)/Gia64-test-readonly.Po - -rm -f ./$(DEPDIR)/Gia64-test-stack.Po - -rm -f ./$(DEPDIR)/Gperf-simple.Po - -rm -f ./$(DEPDIR)/Gperf-trace.Po - -rm -f ./$(DEPDIR)/Gtest-bt.Po - -rm -f ./$(DEPDIR)/Gtest-concurrent.Po - -rm -f ./$(DEPDIR)/Gtest-dyn1.Po - -rm -f ./$(DEPDIR)/Gtest-exc.Po - -rm -f ./$(DEPDIR)/Gtest-init.Po - -rm -f ./$(DEPDIR)/Gtest-resume-sig-rt.Po - -rm -f ./$(DEPDIR)/Gtest-resume-sig.Po - -rm -f ./$(DEPDIR)/Gtest-trace.Po - -rm -f ./$(DEPDIR)/Gx64-test-dwarf-expressions.Po - -rm -f ./$(DEPDIR)/Lia64-test-nat.Po - -rm -f ./$(DEPDIR)/Lia64-test-rbs.Po - -rm -f ./$(DEPDIR)/Lia64-test-readonly.Po - -rm -f ./$(DEPDIR)/Lia64-test-stack.Po - -rm -f ./$(DEPDIR)/Lperf-simple.Po - -rm -f ./$(DEPDIR)/Lperf-trace.Po - -rm -f ./$(DEPDIR)/Lrs-race.Po - -rm -f ./$(DEPDIR)/Ltest-bt.Po - -rm -f ./$(DEPDIR)/Ltest-concurrent.Po - -rm -f ./$(DEPDIR)/Ltest-cxx-exceptions.Po - -rm -f ./$(DEPDIR)/Ltest-dyn1.Po - -rm -f ./$(DEPDIR)/Ltest-exc.Po - -rm -f ./$(DEPDIR)/Ltest-init-local-signal-lib.Po - -rm -f ./$(DEPDIR)/Ltest-init-local-signal.Po - -rm -f ./$(DEPDIR)/Ltest-init.Po - -rm -f ./$(DEPDIR)/Ltest-mem-validate.Po - -rm -f ./$(DEPDIR)/Ltest-nocalloc.Po - -rm -f ./$(DEPDIR)/Ltest-nomalloc.Po - -rm -f ./$(DEPDIR)/Ltest-resume-sig-rt.Po - -rm -f ./$(DEPDIR)/Ltest-resume-sig.Po - -rm -f ./$(DEPDIR)/Ltest-trace.Po - -rm -f ./$(DEPDIR)/Ltest-varargs.Po - -rm -f ./$(DEPDIR)/Lx64-test-dwarf-expressions.Po - -rm -f ./$(DEPDIR)/crasher.Po - -rm -f ./$(DEPDIR)/flush-cache.Po - -rm -f ./$(DEPDIR)/forker.Po - -rm -f ./$(DEPDIR)/ia64-dyn-asm.Po - -rm -f ./$(DEPDIR)/ia64-test-dyn1.Po - -rm -f ./$(DEPDIR)/ia64-test-nat-asm.Po - -rm -f ./$(DEPDIR)/ia64-test-rbs-asm.Po - -rm -f ./$(DEPDIR)/ia64-test-readonly-asm.Po - -rm -f ./$(DEPDIR)/ia64-test-setjmp.Po - -rm -f ./$(DEPDIR)/ia64-test-sig.Po - -rm -f ./$(DEPDIR)/ia64-test-stack-asm.Po - -rm -f ./$(DEPDIR)/ident.Po - -rm -f ./$(DEPDIR)/mapper.Po - -rm -f ./$(DEPDIR)/ppc64-test-altivec-utils.Po - -rm -f ./$(DEPDIR)/ppc64-test-altivec.Po - -rm -f ./$(DEPDIR)/test-async-sig.Po - -rm -f ./$(DEPDIR)/test-coredump-unwind.Po - -rm -f ./$(DEPDIR)/test-flush-cache.Po - -rm -f ./$(DEPDIR)/test-init-remote.Po - -rm -f ./$(DEPDIR)/test-mem.Po - -rm -f ./$(DEPDIR)/test-proc-info.Po - -rm -f ./$(DEPDIR)/test-ptrace-misc.Po - -rm -f ./$(DEPDIR)/test-ptrace.Po - -rm -f ./$(DEPDIR)/test-reg-state.Po - -rm -f ./$(DEPDIR)/test-setjmp.Po - -rm -f ./$(DEPDIR)/test-static-link-gen.Po - -rm -f ./$(DEPDIR)/test-static-link-loc.Po - -rm -f ./$(DEPDIR)/test-strerror.Po - -rm -f ./$(DEPDIR)/x64-test-dwarf-expressions.Po - -rm -f ./$(DEPDIR)/x64-unwind-badjmp-signal-frame.Po + -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic @@ -2374,8 +2273,8 @@ .MAKE: check-am install-am install-strip -.PHONY: CTAGS GTAGS TAGS all all-am am--depfiles check check-TESTS \ - check-am clean clean-checkPROGRAMS clean-generic clean-libtool \ +.PHONY: CTAGS GTAGS TAGS all all-am check check-TESTS check-am clean \ + clean-checkPROGRAMS clean-generic clean-libtool \ clean-noinstPROGRAMS cscopelist-am ctags ctags-am distclean \ distclean-compile distclean-generic distclean-libtool \ distclean-tags distdir dvi dvi-am html html-am info info-am \
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/tests/check-namespace.sh.in -> _service:tar_scm:libunwind-1.7.2.tar.gz/tests/check-namespace.sh.in
Changed
@@ -86,7 +86,14 @@ ignore _gp fi - if ${os} == "solaris2.11" ; then + if ${plat} = "loongarch64" ; then + ignore _fbss + ignore _fdata + ignore _ftext + ignore _gp + fi + + if ${os} = "solaris2.11" ; then ignore _PROCEDURE_LINKAGE_TABLE_ ignore _etext fi @@ -100,7 +107,9 @@ match _UL${plat}_get_fpreg match _UL${plat}_get_proc_info match _UL${plat}_get_proc_info_by_ip + match _UL${plat}_get_proc_info_in_range match _UL${plat}_get_proc_name + match _UL${plat}_get_proc_name_by_ip match _UL${plat}_get_reg match _UL${plat}_get_save_loc match _UL${plat}_init_local @@ -117,7 +126,8 @@ match _U${plat}_flush_cache match _U${plat}_get_accessors - match _U${plat}_getcontext + match _U${plat}_get_elf_image + match _U${plat}_get_exe_image_path match _U${plat}_regname match _U${plat}_strerror @@ -127,77 +137,74 @@ match unw_backtrace @CONFIG_WEAK_BACKTRACE_TRUE@match backtrace + match unw_backtrace2 case ${plat} in arm) - match _U${plat}_get_elf_image - match _U${plat}_get_exe_image_path + match _U${plat}_getcontext match _U${plat}_is_fpreg match _UL${plat}_search_unwind_table match _UL${plat}_dwarf_search_unwind_table match _UL${plat}_dwarf_find_unwind_table ;; hppa) + match _U${plat}_getcontext match _UL${plat}_dwarf_search_unwind_table match _UL${plat}_dwarf_find_unwind_table - match _U${plat}_get_elf_image - match _U${plat}_get_exe_image_path match _U${plat}_setcontext ;; ia64) + match _U${plat}_getcontext match _UL${plat}_search_unwind_table - match _U${plat}_get_elf_image - match _U${plat}_get_exe_image_path ;; x86) - match _U${plat}_get_elf_image - match _U${plat}_get_exe_image_path + match _U${plat}_getcontext match _U${plat}_is_fpreg match _UL${plat}_dwarf_search_unwind_table match _UL${plat}_dwarf_find_unwind_table ;; x86_64) - match _U${plat}_get_elf_image - match _U${plat}_get_exe_image_path + match _U${plat}_getcontext match _U${plat}_is_fpreg match _UL${plat}_dwarf_search_unwind_table match _UL${plat}_dwarf_find_unwind_table match _U${plat}_setcontext ;; ppc*) + match _U${plat}_getcontext match _U${plat}_get_func_addr - match _U${plat}_get_elf_image - match _U${plat}_get_exe_image_path match _U${plat}_is_fpreg match _UL${plat}_dwarf_search_unwind_table match _UL${plat}_dwarf_find_unwind_table ;; - tilegx) - match _U${plat}_is_fpreg + tilegx) + match _U${plat}_getcontext + match _U${plat}_is_fpreg match _UL${plat}_dwarf_search_unwind_table match _UL${plat}_dwarf_find_unwind_table - match _UL${plat}_local_addr_space_init - match _U${plat}_get_elf_image - match _U${plat}_get_exe_image_path - match ${plat}_lock - ;; + match _UL${plat}_local_addr_space_init + match ${plat}_lock + ;; s390x) - match _U${plat}_get_elf_image - match _U${plat}_get_exe_image_path + match _U${plat}_getcontext match _U${plat}_is_fpreg match _UL${plat}_dwarf_search_unwind_table match _UL${plat}_dwarf_find_unwind_table match _U${plat}_setcontext ;; riscv) - match _U${plat}_get_elf_image - match _U${plat}_get_exe_image_path + match _U${plat}_getcontext match _U${plat}_is_fpreg match _UL${plat}_dwarf_search_unwind_table match _UL${plat}_dwarf_find_unwind_table match _U${plat}_setcontext ;; - + loongarch64) + match _U${plat}_getcontext + match _U${plat}_is_fpreg + match _UL${plat}_dwarf_search_unwind_table + match _UL${plat}_dwarf_find_unwind_table + ;; *) match _U${plat}_is_fpreg match _UL${plat}_dwarf_search_unwind_table @@ -221,7 +228,9 @@ match _U${plat}_get_fpreg match _U${plat}_get_proc_info match _U${plat}_get_proc_info_by_ip + match _U${plat}_get_proc_info_in_range match _U${plat}_get_proc_name + match _U${plat}_get_proc_name_by_ip match _U${plat}_get_reg match _U${plat}_get_save_loc match _U${plat}_init_local @@ -288,15 +297,15 @@ match _U${plat}_dwarf_search_unwind_table match _U${plat}_dwarf_find_unwind_table ;; - tilegx) - match _U${plat}_dwarf_search_unwind_table + tilegx) + match _U${plat}_dwarf_search_unwind_table match _U${plat}_dwarf_find_unwind_table - match _U${plat}_get_elf_image + match _U${plat}_get_elf_image match _U${plat}_get_exe_image_path - match _U${plat}_is_fpreg - match _U${plat}_local_addr_space_init - match ${plat}_lock - ;; + match _U${plat}_is_fpreg + match _U${plat}_local_addr_space_init + match ${plat}_lock + ;; s390x) match _U${plat}_is_fpreg match _U${plat}_get_elf_image @@ -311,10 +320,19 @@ match _U${plat}_dwarf_search_unwind_table match _U${plat}_dwarf_find_unwind_table ;; + loongarch64) + match _U${plat}_get_elf_image + match _U${plat}_get_exe_image_path + match _U${plat}_is_fpreg + match _U${plat}_dwarf_search_unwind_table + match _U${plat}_dwarf_find_unwind_table + ;; *) match _U${plat}_is_fpreg match _U${plat}_dwarf_search_unwind_table match _U${plat}_dwarf_find_unwind_table + match _U${plat}_get_elf_image + match _U${plat}_get_exe_image_path ;; esac
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/tests/crasher.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/tests/crasher.c
Changed
@@ -88,7 +88,7 @@ #ifdef __GNUC__ #ifndef __clang__ -// Gcc >= 8 became too good at inlining aliase c into b when using -O2 or -O3, +// Gcc >= 8 became too good at inlining alias c into b when using -O2 or -O3, // so force -O1 in all cases, otherwise a frame will be missing in the tests. #pragma GCC optimize "-O1" #endif @@ -110,7 +110,7 @@ int r; compiler_barrier(); - + if (x) r = a(); else
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/tests/run-coredump-unwind -> _service:tar_scm:libunwind-1.7.2.tar.gz/tests/run-coredump-unwind
Changed
@@ -22,6 +22,7 @@ comm -13 "$dynsyms" "$funcsyms" > "$keep_symbols" # Copy the full debuginfo, keeping only a minumal set of symbols and removing some unnecessary sections objcopy -S --remove-section .gdb_index --remove-section .comment --keep-symbols="$keep_symbols" "$debuginfo" "$mini_debuginfo" &> /dev/null + wait #Inject the compressed data into the .gnu_debugdata section of the original binary xz "$mini_debuginfo" mini_debuginfo="${mini_debuginfo}.xz" @@ -48,6 +49,10 @@ ./crasher backing_files ) 2>/dev/null COREFILE=$TEMPDIR/core* +if ! test -f "$COREFILE"; then + echo "crasher process did not produce coredump, test skipped" + exit 77 +fi # magic option -testcase enables checking for the specific contents of the stack ./test-coredump-unwind $COREFILE -testcase `cat $TEMPDIR/backing_files`
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/tests/test-coredump-unwind.c -> _service:tar_scm:libunwind-1.7.2.tar.gz/tests/test-coredump-unwind.c
Changed
@@ -141,7 +141,7 @@ if (flags & LOGMODE_STDIO) { fflush(stdout); - write(STDERR_FILENO, msg, used + msgeol_len); + ssize_t written UNUSED = write(STDERR_FILENO, msg, used + msgeol_len); } msgused = '\0'; /* remove msg_eol (usually "\n") */ if (flags & LOGMODE_SYSLOG) @@ -244,8 +244,7 @@ { /* glibc extension */ void *array50; - int size; - size = backtrace(array, 50); + int size UNUSED = backtrace(array, 50); #if defined __linux__ && HAVE_EXECINFO_H backtrace_symbols_fd(array, size, 2); #endif @@ -315,17 +314,6 @@ argv++; } - while (*argv) - { - char *colon; - unsigned long vaddr = strtoul(*argv, &colon, 16); - if (*colon != ':') - error_msg_and_die("Bad format: '%s'", *argv); - if (_UCD_add_backing_file_at_vaddr(ui, vaddr, colon + 1) < 0) - error_msg("Can't add backing file '%s'", colon + 1); - argv++; - } - for (;;) { unw_word_t ip;
View file
_service:tar_scm:libunwind-1.6.2.tar.gz/tests/x64-test-dwarf-expressions.S -> _service:tar_scm:libunwind-1.7.2.tar.gz/tests/x64-test-dwarf-expressions.S
Changed
@@ -64,7 +64,7 @@ # DW_CFA_expression(0x10), r12(0x0c), Length(0x02), (preamble) # DW_OP_lit16(0x40), DW_OP_minus(0x1c) (instructions) # Parsing starts with the CFA on the stack, then pushes 16, then does a minus - # which is eqivalent to a=pop(), b=pop(), push(b-a), leaving us with a value + # which is equivalent to a=pop(), b=pop(), push(b-a), leaving us with a value # of cfa-16 (cfa points at old rsp, cfa-8 is our rip, so we stored r12 at # cfa-16). xor %r12, %r12 # Trash r12
Locations
Projects
Search
Status Monitor
Help
Open Build Service
OBS Manuals
API Documentation
OBS Portal
Reporting a Bug
Contact
Mailing List
Forums
Chat (IRC)
Twitter
Open Build Service (OBS)
is an
openSUSE project
.
浙ICP备2022010568号-2