summaryrefslogtreecommitdiff
path: root/lto-plugin/lto-plugin.c
diff options
context:
space:
mode:
authorespindola <espindola@138bc75d-0d04-0410-961f-82ee72b054a4>2009-11-12 14:01:49 +0000
committerespindola <espindola@138bc75d-0d04-0410-961f-82ee72b054a4>2009-11-12 14:01:49 +0000
commitd405c5a4ca7973b1fef5ce1d15ee058781e684a6 (patch)
tree0bbaf16645e4e8605fd81ea4a413098ba0b198fe /lto-plugin/lto-plugin.c
parent266e3ca1fd604c5a0d8b887849665fcf3dae91fd (diff)
downloadgcc-d405c5a4ca7973b1fef5ce1d15ee058781e684a6.tar.gz
2009-11-12 Rafael Avila de Espindola <espindola@google.com>
* lto-plugin.c (write_resolution): Assume resolution_file is set. Print the symbol name. (all_symbols_read_handler): Create a resolution file. Pass it to gcc. (cleanup_handler): Remove the resolution file. (process_option): Drop the -resolution option. 2009-11-12 Rafael Avila de Espindola <espindola@google.com> * lang.opt (fresolution): Renamed from resolution. * lto-lang.c (lto_handle_option): Handle new option name. * lto.c (lto_resolution_read): Add more checks. Discard rest of line. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@154118 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'lto-plugin/lto-plugin.c')
-rw-r--r--lto-plugin/lto-plugin.c22
1 files changed, 13 insertions, 9 deletions
diff --git a/lto-plugin/lto-plugin.c b/lto-plugin/lto-plugin.c
index e8e88cbb3c7..8cbafbc46cd 100644
--- a/lto-plugin/lto-plugin.c
+++ b/lto-plugin/lto-plugin.c
@@ -310,9 +310,6 @@ write_resolution (void)
unsigned int i;
FILE *f;
- if (!resolution_file)
- return;
-
f = fopen (resolution_file, "w");
check (f, LDPL_FATAL, "could not open file");
@@ -334,7 +331,7 @@ write_resolution (void)
{
uint32_t slot = symtab->slots[j];
unsigned int resolution = syms[j].resolution;
- fprintf (f, "%d %s\n", slot, lto_resolution_str[resolution]);
+ fprintf (f, "%d %s %s\n", slot, lto_resolution_str[resolution], syms[j].name);
}
}
fclose (f);
@@ -452,7 +449,7 @@ static enum ld_plugin_status
all_symbols_read_handler (void)
{
unsigned i;
- unsigned num_lto_args = num_claimed_files + lto_wrapper_num_args + 1;
+ unsigned num_lto_args = num_claimed_files + lto_wrapper_num_args + 2 + 1;
char **lto_argv;
const char **lto_arg_ptr;
if (num_claimed_files == 0)
@@ -468,6 +465,8 @@ all_symbols_read_handler (void)
lto_arg_ptr = (const char **) lto_argv;
assert (lto_wrapper_argv);
+ resolution_file = make_temp_file ("");
+
write_resolution ();
free_1 ();
@@ -475,6 +474,9 @@ all_symbols_read_handler (void)
for (i = 0; i < lto_wrapper_num_args; i++)
*lto_arg_ptr++ = lto_wrapper_argv[i];
+ *lto_arg_ptr++ = "-fresolution";
+ *lto_arg_ptr++ = resolution_file;
+
for (i = 0; i < num_claimed_files; i++)
{
struct plugin_file_info *info = &claimed_files[i];
@@ -522,6 +524,12 @@ cleanup_handler (void)
check (t == 0, LDPL_FATAL, "could not unlink arguments file");
}
+ if (resolution_file)
+ {
+ t = unlink (resolution_file);
+ check (t == 0, LDPL_FATAL, "could not unlink resolution file");
+ }
+
free_2 ();
return LDPS_OK;
}
@@ -613,10 +621,6 @@ process_option (const char *option)
debug = 1;
else if (strcmp (option, "-nop") == 0)
nop = 1;
- else if (!strncmp (option, "-resolution=", strlen("-resolution=")))
- {
- resolution_file = strdup (option + strlen("-resolution="));
- }
else if (!strncmp (option, "-pass-through=", strlen("-pass-through=")))
{
num_pass_through_items++;