summaryrefslogtreecommitdiff
path: root/src/sim
diff options
context:
space:
mode:
authorAndreas Hansson <andreas.hansson@arm.com>2014-10-20 18:03:56 -0400
committerAndreas Hansson <andreas.hansson@arm.com>2014-10-20 18:03:56 -0400
commitd6f1c6ce89c16eda7d86c319cc92f551ee352496 (patch)
treed52a9e347638ce933bc7cede46f941de746b9933 /src/sim
parent6290f981940394a4768b566a6d55aa5e5ca5e839 (diff)
downloadgem5-d6f1c6ce89c16eda7d86c319cc92f551ee352496.tar.xz
x86: Fixes to avoid LTO warnings
This patch fixes a few minor issues that caused link-time warnings when using LTO, mainly for x86. The most important change is how the syscall array is created. Previously gcc and clang would complain that the declaration and definition types did not match. The organisation is now changed to match how it is done for ARM, moving the code that was previously in syscalls.cc into process.cc, and having a class variable pointing to the static array. With these changes, there are no longer any warnings using gcc 4.6.3 with LTO.
Diffstat (limited to 'src/sim')
-rw-r--r--src/sim/system.cc9
-rw-r--r--src/sim/system.hh10
2 files changed, 16 insertions, 3 deletions
diff --git a/src/sim/system.cc b/src/sim/system.cc
index 61c6decf7..1f63dbf33 100644
--- a/src/sim/system.cc
+++ b/src/sim/system.cc
@@ -54,7 +54,6 @@
#include "cpu/thread_context.hh"
#include "debug/Loader.hh"
#include "debug/WorkItems.hh"
-#include "kern/kernel_stats.hh"
#include "mem/abstract_mem.hh"
#include "mem/physical.hh"
#include "params/System.hh"
@@ -63,6 +62,14 @@
#include "sim/full_system.hh"
#include "sim/system.hh"
+/**
+ * To avoid linking errors with LTO, only include the header if we
+ * actually have a definition.
+ */
+#if THE_ISA != NULL_ISA
+#include "kern/kernel_stats.hh"
+#endif
+
using namespace std;
using namespace TheISA;
diff --git a/src/sim/system.hh b/src/sim/system.hh
index 595892385..1db28f212 100644
--- a/src/sim/system.hh
+++ b/src/sim/system.hh
@@ -56,15 +56,21 @@
#include "base/misc.hh"
#include "base/statistics.hh"
#include "config/the_isa.hh"
-#include "cpu/pc_event.hh"
#include "enums/MemoryMode.hh"
-#include "kern/system_events.hh"
#include "mem/mem_object.hh"
#include "mem/port.hh"
#include "mem/port_proxy.hh"
#include "mem/physical.hh"
#include "params/System.hh"
+/**
+ * To avoid linking errors with LTO, only include the header if we
+ * actually have the definition.
+ */
+#if THE_ISA != NULL_ISA
+#include "cpu/pc_event.hh"
+#endif
+
class BaseCPU;
class BaseRemoteGDB;
class GDBListener;