annotate gcc/gcc-ar.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children 84e7813d76e9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Wrapper for ar/ranlib/nm to pass the LTO plugin.
kono
parents:
diff changeset
2 Copyright (C) 2011-2017 Free Software Foundation, Inc.
kono
parents:
diff changeset
3 Contributed by Andi Kleen.
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 This file is part of GCC.
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 GCC is free software; you can redistribute it and/or modify it under
kono
parents:
diff changeset
8 the terms of the GNU General Public License as published by the Free
kono
parents:
diff changeset
9 Software Foundation; either version 3, or (at your option) any later
kono
parents:
diff changeset
10 version.
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
kono
parents:
diff changeset
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
kono
parents:
diff changeset
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
kono
parents:
diff changeset
15 for more details.
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
18 along with GCC; see the file COPYING3. If not see
kono
parents:
diff changeset
19 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 #include "config.h"
kono
parents:
diff changeset
22 #include "system.h"
kono
parents:
diff changeset
23 #include "libiberty.h"
kono
parents:
diff changeset
24 #include "file-find.h"
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 #ifndef PERSONALITY
kono
parents:
diff changeset
27 #error "Please set personality"
kono
parents:
diff changeset
28 #endif
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 /* The exec prefix as derived at compile-time from --prefix. */
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 static const char standard_exec_prefix[] = STANDARD_EXEC_PREFIX;
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 /* The libexec prefix as derived at compile-time from --prefix. */
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 static const char standard_libexec_prefix[] = STANDARD_LIBEXEC_PREFIX;
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 /* The bindir prefix as derived at compile-time from --prefix. */
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 static const char standard_bin_prefix[] = STANDARD_BINDIR_PREFIX;
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 /* A relative path to be used in finding the location of tools
kono
parents:
diff changeset
43 relative to this program. */
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 /* The exec prefix as relocated from the location of this program. */
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 static const char *self_exec_prefix;
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 /* The libexec prefix as relocated from the location of this program. */
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 static const char *self_libexec_prefix;
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 /* The tools prefix as relocated from the location of this program. */
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 static const char *self_tooldir_prefix;
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 /* The name of the machine that is being targeted. */
kono
parents:
diff changeset
60
kono
parents:
diff changeset
61 static const char *const target_machine = DEFAULT_TARGET_MACHINE;
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 /* The target version. */
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65 static const char *const target_version = DEFAULT_TARGET_VERSION;
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 /* The collection of target specific path prefixes. */
kono
parents:
diff changeset
68
kono
parents:
diff changeset
69 static struct path_prefix target_path;
kono
parents:
diff changeset
70
kono
parents:
diff changeset
71 /* The collection path prefixes. */
kono
parents:
diff changeset
72
kono
parents:
diff changeset
73 static struct path_prefix path;
kono
parents:
diff changeset
74
kono
parents:
diff changeset
75 /* The directory separator. */
kono
parents:
diff changeset
76
kono
parents:
diff changeset
77 static const char dir_separator[] = { DIR_SEPARATOR, 0 };
kono
parents:
diff changeset
78
kono
parents:
diff changeset
79 static void
kono
parents:
diff changeset
80 setup_prefixes (const char *exec_path)
kono
parents:
diff changeset
81 {
kono
parents:
diff changeset
82 const char *self;
kono
parents:
diff changeset
83
kono
parents:
diff changeset
84 self = getenv ("GCC_EXEC_PREFIX");
kono
parents:
diff changeset
85 if (!self)
kono
parents:
diff changeset
86 self = exec_path;
kono
parents:
diff changeset
87 else
kono
parents:
diff changeset
88 self = concat (self, "gcc-" PERSONALITY, NULL);
kono
parents:
diff changeset
89
kono
parents:
diff changeset
90 /* Relocate the exec prefix. */
kono
parents:
diff changeset
91 self_exec_prefix = make_relative_prefix (self,
kono
parents:
diff changeset
92 standard_bin_prefix,
kono
parents:
diff changeset
93 standard_exec_prefix);
kono
parents:
diff changeset
94 if (self_exec_prefix == NULL)
kono
parents:
diff changeset
95 self_exec_prefix = standard_exec_prefix;
kono
parents:
diff changeset
96
kono
parents:
diff changeset
97 /* Relocate libexec prefix. */
kono
parents:
diff changeset
98 self_libexec_prefix = make_relative_prefix (self,
kono
parents:
diff changeset
99 standard_bin_prefix,
kono
parents:
diff changeset
100 standard_libexec_prefix);
kono
parents:
diff changeset
101 if (self_libexec_prefix == NULL)
kono
parents:
diff changeset
102 self_libexec_prefix = standard_libexec_prefix;
kono
parents:
diff changeset
103
kono
parents:
diff changeset
104
kono
parents:
diff changeset
105 /* Build the relative path to the target-specific tool directory. */
kono
parents:
diff changeset
106 self_tooldir_prefix = concat (tooldir_base_prefix, target_machine,
kono
parents:
diff changeset
107 dir_separator, NULL);
kono
parents:
diff changeset
108 self_tooldir_prefix = concat (self_exec_prefix, target_machine,
kono
parents:
diff changeset
109 dir_separator, target_version, dir_separator,
kono
parents:
diff changeset
110 self_tooldir_prefix, NULL);
kono
parents:
diff changeset
111
kono
parents:
diff changeset
112 /* Add the target-specific tool bin prefix. */
kono
parents:
diff changeset
113 prefix_from_string (concat (self_tooldir_prefix, "bin", NULL), &target_path);
kono
parents:
diff changeset
114
kono
parents:
diff changeset
115 /* Add the target-specific libexec prefix. */
kono
parents:
diff changeset
116 self_libexec_prefix = concat (self_libexec_prefix, target_machine,
kono
parents:
diff changeset
117 dir_separator, target_version,
kono
parents:
diff changeset
118 dir_separator, NULL);
kono
parents:
diff changeset
119 prefix_from_string (self_libexec_prefix, &target_path);
kono
parents:
diff changeset
120
kono
parents:
diff changeset
121 /* Add path as a last resort. */
kono
parents:
diff changeset
122 prefix_from_env ("PATH", &path);
kono
parents:
diff changeset
123 }
kono
parents:
diff changeset
124
kono
parents:
diff changeset
125 int
kono
parents:
diff changeset
126 main (int ac, char **av)
kono
parents:
diff changeset
127 {
kono
parents:
diff changeset
128 const char *exe_name;
kono
parents:
diff changeset
129 char *plugin;
kono
parents:
diff changeset
130 int k, status, err;
kono
parents:
diff changeset
131 const char *err_msg;
kono
parents:
diff changeset
132 const char **nargv;
kono
parents:
diff changeset
133 bool is_ar = !strcmp (PERSONALITY, "ar");
kono
parents:
diff changeset
134 int exit_code = FATAL_EXIT_CODE;
kono
parents:
diff changeset
135 int i;
kono
parents:
diff changeset
136
kono
parents:
diff changeset
137 setup_prefixes (av[0]);
kono
parents:
diff changeset
138
kono
parents:
diff changeset
139 /* Not using getopt for now. */
kono
parents:
diff changeset
140 for (i = 0; i < ac; i++)
kono
parents:
diff changeset
141 if (!strncmp (av[i], "-B", 2))
kono
parents:
diff changeset
142 {
kono
parents:
diff changeset
143 const char *arg = av[i] + 2;
kono
parents:
diff changeset
144 const char *end;
kono
parents:
diff changeset
145 size_t len;
kono
parents:
diff changeset
146
kono
parents:
diff changeset
147 memmove (av + i, av + i + 1, sizeof (char *) * ((ac + 1) - i));
kono
parents:
diff changeset
148 ac--;
kono
parents:
diff changeset
149 if (*arg == 0)
kono
parents:
diff changeset
150 {
kono
parents:
diff changeset
151 arg = av[i];
kono
parents:
diff changeset
152 if (!arg)
kono
parents:
diff changeset
153 {
kono
parents:
diff changeset
154 fprintf (stderr, "Usage: gcc-ar [-B prefix] ar arguments ...\n");
kono
parents:
diff changeset
155 exit (EXIT_FAILURE);
kono
parents:
diff changeset
156 }
kono
parents:
diff changeset
157 memmove (av + i, av + i + 1, sizeof (char *) * ((ac + 1) - i));
kono
parents:
diff changeset
158 ac--;
kono
parents:
diff changeset
159 i++;
kono
parents:
diff changeset
160 }
kono
parents:
diff changeset
161 /* else it's a joined argument */
kono
parents:
diff changeset
162
kono
parents:
diff changeset
163 len = strlen (arg);
kono
parents:
diff changeset
164 if (len > 0)
kono
parents:
diff changeset
165 len--;
kono
parents:
diff changeset
166 end = arg + len;
kono
parents:
diff changeset
167
kono
parents:
diff changeset
168 /* Always add a dir separator for the prefix list. */
kono
parents:
diff changeset
169 if (end > arg && !IS_DIR_SEPARATOR (*end))
kono
parents:
diff changeset
170 {
kono
parents:
diff changeset
171 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
kono
parents:
diff changeset
172 arg = concat (arg, dir_separator_str, NULL);
kono
parents:
diff changeset
173 }
kono
parents:
diff changeset
174
kono
parents:
diff changeset
175 add_prefix_begin (&path, arg);
kono
parents:
diff changeset
176 add_prefix_begin (&target_path, arg);
kono
parents:
diff changeset
177 break;
kono
parents:
diff changeset
178 }
kono
parents:
diff changeset
179
kono
parents:
diff changeset
180
kono
parents:
diff changeset
181 /* Find the GCC LTO plugin */
kono
parents:
diff changeset
182 plugin = find_a_file (&target_path, LTOPLUGINSONAME, R_OK);
kono
parents:
diff changeset
183 if (!plugin)
kono
parents:
diff changeset
184 {
kono
parents:
diff changeset
185 fprintf (stderr, "%s: Cannot find plugin '%s'\n", av[0], LTOPLUGINSONAME);
kono
parents:
diff changeset
186 exit (1);
kono
parents:
diff changeset
187 }
kono
parents:
diff changeset
188
kono
parents:
diff changeset
189 /* Find the wrapped binutils program. */
kono
parents:
diff changeset
190 exe_name = find_a_file (&target_path, PERSONALITY, X_OK);
kono
parents:
diff changeset
191 if (!exe_name)
kono
parents:
diff changeset
192 {
kono
parents:
diff changeset
193 const char *real_exe_name = PERSONALITY;
kono
parents:
diff changeset
194 #ifdef CROSS_DIRECTORY_STRUCTURE
kono
parents:
diff changeset
195 real_exe_name = concat (target_machine, "-", PERSONALITY, NULL);
kono
parents:
diff changeset
196 #endif
kono
parents:
diff changeset
197 exe_name = find_a_file (&path, real_exe_name, X_OK);
kono
parents:
diff changeset
198 if (!exe_name)
kono
parents:
diff changeset
199 {
kono
parents:
diff changeset
200 fprintf (stderr, "%s: Cannot find binary '%s'\n", av[0],
kono
parents:
diff changeset
201 real_exe_name);
kono
parents:
diff changeset
202 exit (1);
kono
parents:
diff changeset
203 }
kono
parents:
diff changeset
204 }
kono
parents:
diff changeset
205
kono
parents:
diff changeset
206 /* Create new command line with plugin */
kono
parents:
diff changeset
207 nargv = XCNEWVEC (const char *, ac + 4);
kono
parents:
diff changeset
208 nargv[0] = exe_name;
kono
parents:
diff changeset
209 nargv[1] = "--plugin";
kono
parents:
diff changeset
210 nargv[2] = plugin;
kono
parents:
diff changeset
211 if (is_ar && av[1] && av[1][0] != '-')
kono
parents:
diff changeset
212 av[1] = concat ("-", av[1], NULL);
kono
parents:
diff changeset
213 for (k = 1; k < ac; k++)
kono
parents:
diff changeset
214 nargv[2 + k] = av[k];
kono
parents:
diff changeset
215 nargv[2 + k] = NULL;
kono
parents:
diff changeset
216
kono
parents:
diff changeset
217 /* Run utility */
kono
parents:
diff changeset
218 /* ??? the const is misplaced in pex_one's argv? */
kono
parents:
diff changeset
219 err_msg = pex_one (PEX_LAST|PEX_SEARCH,
kono
parents:
diff changeset
220 exe_name,
kono
parents:
diff changeset
221 CONST_CAST2 (char * const *, const char **, nargv),
kono
parents:
diff changeset
222 concat ("gcc-", exe_name, NULL),
kono
parents:
diff changeset
223 NULL,NULL, &status, &err);
kono
parents:
diff changeset
224 if (err_msg)
kono
parents:
diff changeset
225 fprintf (stderr, "Error running %s: %s\n", exe_name, err_msg);
kono
parents:
diff changeset
226 else if (status)
kono
parents:
diff changeset
227 {
kono
parents:
diff changeset
228 if (WIFSIGNALED (status))
kono
parents:
diff changeset
229 {
kono
parents:
diff changeset
230 int sig = WTERMSIG (status);
kono
parents:
diff changeset
231 fprintf (stderr, "%s terminated with signal %d [%s]%s\n",
kono
parents:
diff changeset
232 exe_name, sig, strsignal (sig),
kono
parents:
diff changeset
233 WCOREDUMP (status) ? ", core dumped" : "");
kono
parents:
diff changeset
234 }
kono
parents:
diff changeset
235 else if (WIFEXITED (status))
kono
parents:
diff changeset
236 exit_code = WEXITSTATUS (status);
kono
parents:
diff changeset
237 }
kono
parents:
diff changeset
238 else
kono
parents:
diff changeset
239 exit_code = SUCCESS_EXIT_CODE;
kono
parents:
diff changeset
240
kono
parents:
diff changeset
241 return exit_code;
kono
parents:
diff changeset
242 }