sim/ppc: Fix linker error with -fno-common
authorSebastian Huber <sebastian.huber@embedded-brains.de>
Wed, 1 Jul 2020 17:29:55 +0000 (19:29 +0200)
committerSebastian Huber <sebastian.huber@embedded-brains.de>
Fri, 3 Jul 2020 16:47:40 +0000 (18:47 +0200)
GCC 10 enables -fno-common by default.  This resulted in a multiple
definition linker error since global variables were declared and defined
in a header file:

  ld: ld-insn.o:sim/ppc/ld-insn.h:221: multiple definition of
  `max_model_fields_len'; igen.o:sim/ppc/ld-insn.h:221: first defined here

sim/ppc

* ld-insn.h (last_model, last_model_data, last_model_function,
last_model_internal, last_model_macro, last_model_static):
Delete.
(max_model_fields_len, model_data, model_functions,
model_internal, model_macros, model_static, models): Declare, but do not
define.
* ld-insn.c (last_model, last_model_data, last_model_function,
last_model_internal, last_model_macro, last_model_static,
max_model_fields_len, model_data, model_functions,
model_internal, model_macros, model_static, models): Define.

sim/ppc/ChangeLog
sim/ppc/ld-insn.c
sim/ppc/ld-insn.h

index 7c3a634f958d18beda0e89c4713a5c8bf71a3fd8..ef5fa4d5acf94ecd15f1b6d7f623220d8b165898 100644 (file)
@@ -1,3 +1,16 @@
+2020-07-03  Sebastian Huber  <sebastian.huber@embedded-brains.de>
+
+       * ld-insn.h (last_model, last_model_data, last_model_function,
+       last_model_internal, last_model_macro, last_model_static):
+       Delete.
+       (max_model_fields_len, model_data, model_functions,
+       model_internal, model_macros, model_static, models): Declare, but do not
+       define.
+       * ld-insn.c (last_model, last_model_data, last_model_function,
+       last_model_internal, last_model_macro, last_model_static,
+       max_model_fields_len, model_data, model_functions,
+       model_internal, model_macros, model_static, models): Define.
+
 2020-03-12  Kamil Rytarowski  <n54@gmx.com>
 
        * emul_netbsd.c (netbsd_signal_names): Sync with NetBSD 9.99.49.
index e39131ca1334e91cee1ccee44fec6f8f5acd243c..585071a861ff95aaedcce05ad853ca1d50799375 100644 (file)
 
 #include "igen.h"
 
+static model *last_model;
+
+static insn *last_model_macro;
+static insn *last_model_function;
+static insn *last_model_internal;
+static insn *last_model_static;
+static insn *last_model_data;
+
+model *models;
+
+insn *model_macros;
+insn *model_functions;
+insn *model_internal;
+insn *model_static;
+insn *model_data;
+
+int max_model_fields_len;
+
 static void
 update_depth(insn_table *entry,
             lf *file,
index 88318ffa2b34d28888241b029660a5c0df4a8d0a..52baeaa2d846c30e1df1d10138c4b5fc7955ca5a 100644 (file)
@@ -200,25 +200,15 @@ extern insn_table *load_insn_table
  table_include *includes,
  cache_table **cache_rules);
 
-model *models;
-model *last_model;
+extern model *models;
 
-insn *model_macros;
-insn *last_model_macro;
+extern insn *model_macros;
+extern insn *model_functions;
+extern insn *model_internal;
+extern insn *model_static;
+extern insn *model_data;
 
-insn *model_functions;
-insn *last_model_function;
-
-insn *model_internal;
-insn *last_model_internal;
-
-insn *model_static;
-insn *last_model_static;
-
-insn *model_data;
-insn *last_model_data;
-
-int max_model_fields_len;
+extern int max_model_fields_len;
 
 extern void insn_table_insert_insn
 (insn_table *table,