diff options
author | Kito Cheng <kito.cheng@sifive.com> | 2025-06-10 11:17:45 +0800 |
---|---|---|
committer | Kito Cheng <kito.cheng@sifive.com> | 2025-06-13 09:27:40 +0800 |
commit | 59fbc99f8ee35fc1a7bcae4bed3e7bfaec38b538 (patch) | |
tree | ce95a83831c74ec0efeca89b055e62c2d64d2709 | |
parent | 11059b4a4e8d4a19e7b554817f7cf0f68e3d54bb (diff) | |
download | gcc-59fbc99f8ee35fc1a7bcae4bed3e7bfaec38b538.zip gcc-59fbc99f8ee35fc1a7bcae4bed3e7bfaec38b538.tar.gz gcc-59fbc99f8ee35fc1a7bcae4bed3e7bfaec38b538.tar.bz2 |
driver: Try to read spec from gcc_exec_prefix if possible
GCC will try to read the spec file from the directory where it is
installed, but it should try to read from gcc_exec_prefix rather than
standard_exec_prefix, because the latter is not the right one if
compiler has been relocated into other places other than the path
specfied at configuration time.
gcc/ChangeLog:
* gcc.cc (driver::set_up_specs): Use gcc_exec_prefix to
read the spec file rather than standard_exec_prefix.
-rw-r--r-- | gcc/gcc.cc | 8 |
1 files changed, 5 insertions, 3 deletions
@@ -8506,11 +8506,13 @@ driver::set_up_specs () const spec_machine_suffix = just_machine_suffix; #endif + const char *exec_prefix + = gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix; /* We need to check standard_exec_prefix/spec_machine_suffix/specs for any override of as, ld and libraries. */ - specs_file = (char *) alloca (strlen (standard_exec_prefix) - + strlen (spec_machine_suffix) + sizeof ("specs")); - strcpy (specs_file, standard_exec_prefix); + specs_file = (char *) alloca ( + strlen (exec_prefix) + strlen (spec_machine_suffix) + sizeof ("specs")); + strcpy (specs_file, exec_prefix); strcat (specs_file, spec_machine_suffix); strcat (specs_file, "specs"); if (access (specs_file, R_OK) == 0) |