]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR lto/50616 (lto1.exe: internal compiler error: invalid resolution in the resolut...
authorKai Tietz <ktietz@redhat.com>
Wed, 22 Feb 2012 10:19:22 +0000 (11:19 +0100)
committerKai Tietz <ktietz@gcc.gnu.org>
Wed, 22 Feb 2012 10:19:22 +0000 (11:19 +0100)
        PR lto/50616
        * lto-plugin.c (PRI_LL): New macro.
        (dump_symtab): Use PRI_LL instead of ll in print.
        (process_symtab): Use PRI_LL instead of ll in scan.

From-SVN: r184462

lto-plugin/ChangeLog
lto-plugin/lto-plugin.c

index 5db37e791439173b4241b48d6b6607963c9114b7..ad2be69f642fba47db32cd2f74c8aedc3d222233 100644 (file)
@@ -1,3 +1,10 @@
+2012-02-22  Kai Tietz  <ktietz@redhat.com>
+
+       PR lto/50616
+       * lto-plugin.c (PRI_LL): New macro.
+       (dump_symtab): Use PRI_LL instead of ll in print.
+       (process_symtab): Use PRI_LL instead of ll in scan.
+
 2011-12-20  Andreas Schwab  <schwab@linux-m68k.org>
 
        * configure: Regenerate.
index d7a78136827866038d69e9cb154dec7202d87ee3..8d55cb8f49185c5043b6e1bbcda61f3897190f2b 100644 (file)
@@ -62,6 +62,14 @@ along with this program; see the file COPYING3.  If not see
 #include "simple-object.h"
 #include "plugin-api.h"
 
+/* We need to use I64 instead of ll width-specifier on native Windows.
+   The reason for this is that older MS-runtimes don't support the ll.  */
+#ifdef __MINGW32__
+#define PRI_LL "I64"
+#else
+#define PRI_LL "ll"
+#endif
+
 /* Handle opening elf files on hosts, such as Windows, that may use
    text file handling that will break binary access.  */
 #ifndef O_BINARY
@@ -360,7 +368,7 @@ dump_symtab (FILE *f, struct plugin_symtab *symtab)
       
       assert (resolution != LDPR_UNKNOWN);
 
-      fprintf (f, "%u %llx %s %s\n",
+      fprintf (f, "%u %" PRI_LL "x %s %s\n",
                (unsigned int) slot, symtab->aux[j].id,
               lto_resolution_str[resolution], 
               symtab->syms[j].name);
@@ -816,7 +824,7 @@ process_symtab (void *data, const char *name, off_t offset, off_t length)
 
   s = strrchr (name, '.');
   if (s)
-    sscanf (s, ".%llx", &obj->out->id);
+    sscanf (s, ".%" PRI_LL "x", &obj->out->id);
   secdata = xmalloc (length);
   offset += obj->file->offset;
   if (offset != lseek (obj->file->fd, offset, SEEK_SET)