summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSam Clegg <sbc@chromium.org>2018-02-20 22:09:59 +0000
committerSam Clegg <sbc@chromium.org>2018-02-20 22:09:59 +0000
commitf187c4d2e578d477c3db8e6998bd91ba622c6530 (patch)
treedeca74d2044dfc9fd149edcbdcf4b5b1eb75a6fa
parentfd0630665b141d83a86b40cfd3e49be1dd80e005 (diff)
downloadbcm5719-llvm-f187c4d2e578d477c3db8e6998bd91ba622c6530.tar.gz
bcm5719-llvm-f187c4d2e578d477c3db8e6998bd91ba622c6530.zip
Consistent use of header file for ICF and MarkLive
Previously wasm used a separate header to declare markLive and ELF used to declare ICF. This change makes each backend consistently declare these in their own headers. Differential Revision: https://reviews.llvm.org/D43529 llvm-svn: 325631
-rw-r--r--lld/COFF/Driver.cpp4
-rw-r--r--lld/COFF/Driver.h6
-rw-r--r--lld/COFF/ICF.cpp1
-rw-r--r--lld/COFF/ICF.h26
-rw-r--r--lld/COFF/MarkLive.h24
-rw-r--r--lld/ELF/Driver.cpp1
-rw-r--r--lld/ELF/ICF.h4
-rw-r--r--lld/ELF/MarkLive.cpp2
-rw-r--r--lld/ELF/MarkLive.h21
-rw-r--r--lld/ELF/Strings.cpp2
-rw-r--r--lld/ELF/Writer.h1
11 files changed, 80 insertions, 12 deletions
diff --git a/lld/COFF/Driver.cpp b/lld/COFF/Driver.cpp
index 9a78987e80c..3abe0249484 100644
--- a/lld/COFF/Driver.cpp
+++ b/lld/COFF/Driver.cpp
@@ -9,7 +9,9 @@
#include "Driver.h"
#include "Config.h"
+#include "ICF.h"
#include "InputFiles.h"
+#include "MarkLive.h"
#include "MinGW.h"
#include "SymbolTable.h"
#include "Symbols.h"
@@ -37,8 +39,8 @@
#include "llvm/Support/raw_ostream.h"
#include "llvm/ToolDrivers/llvm-lib/LibDriver.h"
#include <algorithm>
-#include <memory>
#include <future>
+#include <memory>
using namespace llvm;
using namespace llvm::object;
diff --git a/lld/COFF/Driver.h b/lld/COFF/Driver.h
index 02b24269049..9bd6c0fa2ab 100644
--- a/lld/COFF/Driver.h
+++ b/lld/COFF/Driver.h
@@ -36,12 +36,6 @@ using llvm::COFF::MachineTypes;
using llvm::COFF::WindowsSubsystem;
using llvm::Optional;
-// Implemented in MarkLive.cpp.
-void markLive(ArrayRef<Chunk *> Chunks);
-
-// Implemented in ICF.cpp.
-void doICF(ArrayRef<Chunk *> Chunks);
-
class COFFOptTable : public llvm::opt::OptTable {
public:
COFFOptTable();
diff --git a/lld/COFF/ICF.cpp b/lld/COFF/ICF.cpp
index 2eb11f99192..c063ab28edc 100644
--- a/lld/COFF/ICF.cpp
+++ b/lld/COFF/ICF.cpp
@@ -18,6 +18,7 @@
//
//===----------------------------------------------------------------------===//
+#include "ICF.h"
#include "Chunks.h"
#include "Symbols.h"
#include "lld/Common/ErrorHandler.h"
diff --git a/lld/COFF/ICF.h b/lld/COFF/ICF.h
new file mode 100644
index 00000000000..9c54e0c9ec2
--- /dev/null
+++ b/lld/COFF/ICF.h
@@ -0,0 +1,26 @@
+//===- ICF.h --------------------------------------------------------------===//
+//
+// The LLVM Linker
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef LLD_COFF_ICF_H
+#define LLD_COFF_ICF_H
+
+#include "lld/Common/LLVM.h"
+#include "llvm/ADT/ArrayRef.h"
+
+namespace lld {
+namespace coff {
+
+class Chunk;
+
+void doICF(ArrayRef<Chunk *> Chunks);
+
+} // namespace coff
+} // namespace lld
+
+#endif
diff --git a/lld/COFF/MarkLive.h b/lld/COFF/MarkLive.h
new file mode 100644
index 00000000000..5b652dd4819
--- /dev/null
+++ b/lld/COFF/MarkLive.h
@@ -0,0 +1,24 @@
+//===- MarkLive.h -----------------------------------------------*- C++ -*-===//
+//
+// The LLVM Linker
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef LLD_COFF_MARKLIVE_H
+#define LLD_COFF_MARKLIVE_H
+
+#include "lld/Common/LLVM.h"
+#include "llvm/ADT/ArrayRef.h"
+
+namespace lld {
+namespace coff {
+
+void markLive(ArrayRef<Chunk *> Chunks);
+
+} // namespace coff
+} // namespace lld
+
+#endif // LLD_COFF_MARKLIVE_H
diff --git a/lld/ELF/Driver.cpp b/lld/ELF/Driver.cpp
index 1efd2466cdf..265b3e62918 100644
--- a/lld/ELF/Driver.cpp
+++ b/lld/ELF/Driver.cpp
@@ -30,6 +30,7 @@
#include "InputFiles.h"
#include "InputSection.h"
#include "LinkerScript.h"
+#include "MarkLive.h"
#include "OutputSections.h"
#include "ScriptParser.h"
#include "Strings.h"
diff --git a/lld/ELF/ICF.h b/lld/ELF/ICF.h
index 24219855fc1..a6c8636ead6 100644
--- a/lld/ELF/ICF.h
+++ b/lld/ELF/ICF.h
@@ -12,8 +12,10 @@
namespace lld {
namespace elf {
+
template <class ELFT> void doIcf();
-}
+
+} // namespace elf
} // namespace lld
#endif
diff --git a/lld/ELF/MarkLive.cpp b/lld/ELF/MarkLive.cpp
index 1aa20f797d9..05ab2c89ab4 100644
--- a/lld/ELF/MarkLive.cpp
+++ b/lld/ELF/MarkLive.cpp
@@ -20,6 +20,7 @@
//
//===----------------------------------------------------------------------===//
+#include "MarkLive.h"
#include "InputSection.h"
#include "LinkerScript.h"
#include "OutputSections.h"
@@ -27,7 +28,6 @@
#include "SymbolTable.h"
#include "Symbols.h"
#include "Target.h"
-#include "Writer.h"
#include "lld/Common/Memory.h"
#include "llvm/ADT/STLExtras.h"
#include "llvm/Object/ELF.h"
diff --git a/lld/ELF/MarkLive.h b/lld/ELF/MarkLive.h
new file mode 100644
index 00000000000..c9b99add34d
--- /dev/null
+++ b/lld/ELF/MarkLive.h
@@ -0,0 +1,21 @@
+//===- MarkLive.h -----------------------------------------------*- C++ -*-===//
+//
+// The LLVM Linker
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef LLD_ELF_MARKLIVE_H
+#define LLD_ELF_MARKLIVE_H
+
+namespace lld {
+namespace elf {
+
+template <class ELFT> void markLive();
+
+} // namespace elf
+} // namespace lld
+
+#endif // LLD_ELF_MARKLIVE_H
diff --git a/lld/ELF/Strings.cpp b/lld/ELF/Strings.cpp
index 0ef33a14bc3..ce642cfe7fa 100644
--- a/lld/ELF/Strings.cpp
+++ b/lld/ELF/Strings.cpp
@@ -10,8 +10,6 @@
#include "Strings.h"
#include "Config.h"
#include "lld/Common/ErrorHandler.h"
-#include "llvm/ADT/ArrayRef.h"
-#include "llvm/ADT/StringRef.h"
#include "llvm/ADT/Twine.h"
#include "llvm/Demangle/Demangle.h"
#include <algorithm>
diff --git a/lld/ELF/Writer.h b/lld/ELF/Writer.h
index 9c7fbd4b152..41f1e550eeb 100644
--- a/lld/ELF/Writer.h
+++ b/lld/ELF/Writer.h
@@ -23,7 +23,6 @@ class InputSectionBase;
template <class ELFT> class ObjFile;
class SymbolTable;
template <class ELFT> void writeResult();
-template <class ELFT> void markLive();
// This describes a program header entry.
// Each contains type, access flags and range of output sections that will be
OpenPOWER on IntegriCloud