Index: COFF/CMakeLists.txt =================================================================== --- COFF/CMakeLists.txt +++ COFF/CMakeLists.txt @@ -40,7 +40,6 @@ LINK_LIBS lldCore - lldSupport ${PTHREAD_LIB} DEPENDS Index: COFF/Driver.cpp =================================================================== --- COFF/Driver.cpp +++ COFF/Driver.cpp @@ -11,11 +11,11 @@ #include "Config.h" #include "Error.h" #include "InputFiles.h" +#include "Memory.h" #include "SymbolTable.h" #include "Symbols.h" #include "Writer.h" #include "lld/Driver/Driver.h" -#include "lld/Support/Memory.h" #include "llvm/ADT/Optional.h" #include "llvm/ADT/StringSwitch.h" #include "llvm/LibDriver/LibDriver.h" @@ -50,6 +50,10 @@ Configuration *Config; LinkerDriver *Driver; +BumpPtrAllocator BAlloc; +StringSaver Saver{BAlloc}; +std::vector SpecificAllocBase::Instances; + bool link(ArrayRef Args) { Config = make(); Driver = make(); Index: COFF/DriverUtils.cpp =================================================================== --- COFF/DriverUtils.cpp +++ COFF/DriverUtils.cpp @@ -16,8 +16,8 @@ #include "Config.h" #include "Driver.h" #include "Error.h" +#include "Memory.h" #include "Symbols.h" -#include "lld/Support/Memory.h" #include "llvm/ADT/Optional.h" #include "llvm/ADT/StringSwitch.h" #include "llvm/Object/COFF.h" Index: COFF/InputFiles.cpp =================================================================== --- COFF/InputFiles.cpp +++ COFF/InputFiles.cpp @@ -7,14 +7,15 @@ // //===----------------------------------------------------------------------===// +#include "InputFiles.h" #include "Chunks.h" #include "Config.h" #include "Driver.h" #include "Error.h" -#include "InputFiles.h" +#include "Memory.h" #include "SymbolTable.h" #include "Symbols.h" -#include "lld/Support/Memory.h" +#include "llvm-c/lto.h" #include "llvm/ADT/SmallVector.h" #include "llvm/ADT/Triple.h" #include "llvm/ADT/Twine.h" @@ -29,7 +30,6 @@ #include "llvm/Support/ErrorOr.h" #include "llvm/Support/FileSystem.h" #include "llvm/Target/TargetOptions.h" -#include "llvm-c/lto.h" #include #include #include Index: COFF/Memory.h =================================================================== --- COFF/Memory.h +++ COFF/Memory.h @@ -7,35 +7,25 @@ // //===----------------------------------------------------------------------===// // -// This file defines arena allocators. -// -// Almost all large objects, such as files, sections or symbols, are -// used for the entire lifetime of the linker once they are created. -// This usage characteristic makes arena allocator an attractive choice -// where the entire linker is one arena. With an arena, newly created -// objects belong to the arena and freed all at once when everything is done. -// Arena allocators are efficient and easy to understand. -// Most objects are allocated using the arena allocators defined by this file. +// See ELF/Memory.h // //===----------------------------------------------------------------------===// -#ifndef LLD_MEMORY_H -#define LLD_MEMORY_H +#ifndef LLD_COFF_MEMORY_H +#define LLD_COFF_MEMORY_H #include "llvm/Support/Allocator.h" #include "llvm/Support/StringSaver.h" #include namespace lld { +namespace coff { -// Use this arena if your object doesn't have a destructor. extern llvm::BumpPtrAllocator BAlloc; extern llvm::StringSaver Saver; -// These two classes are hack to keep track of all -// SpecificBumpPtrAllocator instances. struct SpecificAllocBase { - SpecificAllocBase(); + SpecificAllocBase() { Instances.push_back(this); } virtual ~SpecificAllocBase() = default; virtual void reset() = 0; static std::vector Instances; @@ -46,14 +36,17 @@ llvm::SpecificBumpPtrAllocator Alloc; }; -// Use this arena if your object has a destructor. -// Your destructor will be invoked from freeArena(). -template inline T *make(U &&... Args) { +template T *make(U &&... Args) { static SpecificAlloc Alloc; return new (Alloc.Alloc.Allocate()) T(std::forward(Args)...); } -void freeArena(); +inline void freeArena() { + for (SpecificAllocBase *Alloc : SpecificAllocBase::Instances) + Alloc->reset(); + BAlloc.Reset(); +} +} } #endif Index: COFF/ModuleDef.cpp =================================================================== --- COFF/ModuleDef.cpp +++ COFF/ModuleDef.cpp @@ -18,7 +18,7 @@ #include "Config.h" #include "Error.h" -#include "lld/Support/Memory.h" +#include "Memory.h" #include "llvm/ADT/StringRef.h" #include "llvm/ADT/StringSwitch.h" #include "llvm/Support/StringSaver.h" Index: COFF/SymbolTable.cpp =================================================================== --- COFF/SymbolTable.cpp +++ COFF/SymbolTable.cpp @@ -11,8 +11,8 @@ #include "Config.h" #include "Driver.h" #include "Error.h" +#include "Memory.h" #include "Symbols.h" -#include "lld/Support/Memory.h" #include "llvm/IR/LLVMContext.h" #include "llvm/LTO/legacy/LTOCodeGenerator.h" #include "llvm/Support/Debug.h" Index: COFF/Symbols.h =================================================================== --- COFF/Symbols.h +++ COFF/Symbols.h @@ -12,8 +12,8 @@ #include "Chunks.h" #include "Config.h" +#include "Memory.h" #include "lld/Core/LLVM.h" -#include "lld/Support/Memory.h" #include "llvm/ADT/ArrayRef.h" #include "llvm/Object/Archive.h" #include "llvm/Object/COFF.h" Index: COFF/Symbols.cpp =================================================================== --- COFF/Symbols.cpp +++ COFF/Symbols.cpp @@ -10,8 +10,8 @@ #include "Symbols.h" #include "Error.h" #include "InputFiles.h" +#include "Memory.h" #include "Strings.h" -#include "lld/Support/Memory.h" #include "llvm/ADT/STLExtras.h" #include "llvm/Support/Debug.h" #include "llvm/Support/raw_ostream.h" Index: COFF/Writer.cpp =================================================================== --- COFF/Writer.cpp +++ COFF/Writer.cpp @@ -12,11 +12,11 @@ #include "DLL.h" #include "Error.h" #include "InputFiles.h" +#include "Memory.h" #include "PDB.h" #include "SymbolTable.h" #include "Symbols.h" #include "lld/Core/Parallel.h" -#include "lld/Support/Memory.h" #include "llvm/ADT/DenseMap.h" #include "llvm/ADT/STLExtras.h" #include "llvm/ADT/StringSwitch.h" Index: ELF/CMakeLists.txt =================================================================== --- ELF/CMakeLists.txt +++ ELF/CMakeLists.txt @@ -53,7 +53,6 @@ LINK_LIBS lldConfig lldCore - lldSupport ${PTHREAD_LIB} DEPENDS Index: ELF/Driver.cpp =================================================================== --- ELF/Driver.cpp +++ ELF/Driver.cpp @@ -14,6 +14,7 @@ #include "InputFiles.h" #include "InputSection.h" #include "LinkerScript.h" +#include "Memory.h" #include "Strings.h" #include "SymbolTable.h" #include "Target.h" @@ -21,7 +22,6 @@ #include "Writer.h" #include "lld/Config/Version.h" #include "lld/Driver/Driver.h" -#include "lld/Support/Memory.h" #include "llvm/ADT/StringExtras.h" #include "llvm/ADT/StringSwitch.h" #include "llvm/Support/CommandLine.h" @@ -42,6 +42,10 @@ Configuration *elf::Config; LinkerDriver *elf::Driver; +BumpPtrAllocator elf::BAlloc; +StringSaver elf::Saver{BAlloc}; +std::vector elf::SpecificAllocBase::Instances; + bool elf::link(ArrayRef Args, bool CanExitEarly, raw_ostream &Error) { ErrorCount = 0; Index: ELF/DriverUtils.cpp =================================================================== --- ELF/DriverUtils.cpp +++ ELF/DriverUtils.cpp @@ -15,10 +15,10 @@ #include "Driver.h" #include "Error.h" +#include "Memory.h" #include "ScriptParser.h" #include "lld/Config/Version.h" #include "lld/Core/Reproduce.h" -#include "lld/Support/Memory.h" #include "llvm/ADT/Optional.h" #include "llvm/ADT/STLExtras.h" #include "llvm/ADT/Triple.h" Index: ELF/InputFiles.cpp =================================================================== --- ELF/InputFiles.cpp +++ ELF/InputFiles.cpp @@ -12,10 +12,10 @@ #include "Error.h" #include "InputSection.h" #include "LinkerScript.h" +#include "Memory.h" #include "SymbolTable.h" #include "Symbols.h" #include "SyntheticSections.h" -#include "lld/Support/Memory.h" #include "llvm/ADT/STLExtras.h" #include "llvm/Bitcode/BitcodeReader.h" #include "llvm/CodeGen/Analysis.h" Index: ELF/InputSection.cpp =================================================================== --- ELF/InputSection.cpp +++ ELF/InputSection.cpp @@ -13,12 +13,12 @@ #include "Error.h" #include "InputFiles.h" #include "LinkerScript.h" +#include "Memory.h" #include "OutputSections.h" #include "Relocations.h" #include "SyntheticSections.h" #include "Target.h" #include "Thunks.h" -#include "lld/Support/Memory.h" #include "llvm/Support/Compression.h" #include "llvm/Support/Endian.h" #include Index: ELF/LinkerScript.cpp =================================================================== --- ELF/LinkerScript.cpp +++ ELF/LinkerScript.cpp @@ -15,6 +15,7 @@ #include "Config.h" #include "Driver.h" #include "InputSection.h" +#include "Memory.h" #include "OutputSections.h" #include "ScriptParser.h" #include "Strings.h" @@ -23,7 +24,6 @@ #include "SyntheticSections.h" #include "Target.h" #include "Writer.h" -#include "lld/Support/Memory.h" #include "llvm/ADT/STLExtras.h" #include "llvm/ADT/SmallString.h" #include "llvm/ADT/StringRef.h" Index: ELF/Memory.h =================================================================== --- ELF/Memory.h +++ ELF/Memory.h @@ -19,14 +19,15 @@ // //===----------------------------------------------------------------------===// -#ifndef LLD_MEMORY_H -#define LLD_MEMORY_H +#ifndef LLD_ELF_MEMORY_H +#define LLD_ELF_MEMORY_H #include "llvm/Support/Allocator.h" #include "llvm/Support/StringSaver.h" #include namespace lld { +namespace elf { // Use this arena if your object doesn't have a destructor. extern llvm::BumpPtrAllocator BAlloc; @@ -35,7 +36,7 @@ // These two classes are hack to keep track of all // SpecificBumpPtrAllocator instances. struct SpecificAllocBase { - SpecificAllocBase(); + SpecificAllocBase() { Instances.push_back(this); } virtual ~SpecificAllocBase() = default; virtual void reset() = 0; static std::vector Instances; @@ -48,12 +49,17 @@ // Use this arena if your object has a destructor. // Your destructor will be invoked from freeArena(). -template inline T *make(U &&... Args) { +template T *make(U &&... Args) { static SpecificAlloc Alloc; return new (Alloc.Alloc.Allocate()) T(std::forward(Args)...); } -void freeArena(); +inline void freeArena() { + for (SpecificAllocBase *Alloc : SpecificAllocBase::Instances) + Alloc->reset(); + BAlloc.Reset(); +} +} } #endif Index: ELF/OutputSections.cpp =================================================================== --- ELF/OutputSections.cpp +++ ELF/OutputSections.cpp @@ -11,12 +11,12 @@ #include "Config.h" #include "EhFrame.h" #include "LinkerScript.h" +#include "Memory.h" #include "Strings.h" #include "SymbolTable.h" #include "SyntheticSections.h" #include "Target.h" #include "Threads.h" -#include "lld/Support/Memory.h" #include "llvm/Support/Dwarf.h" #include "llvm/Support/MD5.h" #include "llvm/Support/MathExtras.h" Index: ELF/SymbolTable.cpp =================================================================== --- ELF/SymbolTable.cpp +++ ELF/SymbolTable.cpp @@ -18,8 +18,8 @@ #include "Config.h" #include "Error.h" #include "LinkerScript.h" +#include "Memory.h" #include "Symbols.h" -#include "lld/Support/Memory.h" #include "llvm/ADT/STLExtras.h" using namespace llvm; Index: ELF/SyntheticSections.cpp =================================================================== --- ELF/SyntheticSections.cpp +++ ELF/SyntheticSections.cpp @@ -19,6 +19,7 @@ #include "Error.h" #include "InputFiles.h" #include "LinkerScript.h" +#include "Memory.h" #include "OutputSections.h" #include "Strings.h" #include "SymbolTable.h" @@ -26,7 +27,6 @@ #include "Threads.h" #include "Writer.h" #include "lld/Config/Version.h" -#include "lld/Support/Memory.h" #include "llvm/Support/Dwarf.h" #include "llvm/Support/Endian.h" #include "llvm/Support/MD5.h" Index: ELF/Target.cpp =================================================================== --- ELF/Target.cpp +++ ELF/Target.cpp @@ -27,12 +27,12 @@ #include "Target.h" #include "Error.h" #include "InputFiles.h" +#include "Memory.h" #include "OutputSections.h" #include "Symbols.h" #include "SyntheticSections.h" #include "Thunks.h" #include "Writer.h" -#include "lld/Support/Memory.h" #include "llvm/ADT/ArrayRef.h" #include "llvm/Object/ELF.h" #include "llvm/Support/ELF.h" Index: ELF/Thunks.cpp =================================================================== --- ELF/Thunks.cpp +++ ELF/Thunks.cpp @@ -25,10 +25,10 @@ #include "Config.h" #include "Error.h" #include "InputSection.h" +#include "Memory.h" #include "OutputSections.h" #include "Symbols.h" #include "Target.h" -#include "lld/Support/Memory.h" #include "llvm/Support/Casting.h" #include "llvm/Support/ELF.h" #include "llvm/Support/Endian.h" Index: ELF/Writer.cpp =================================================================== --- ELF/Writer.cpp +++ ELF/Writer.cpp @@ -10,13 +10,13 @@ #include "Writer.h" #include "Config.h" #include "LinkerScript.h" +#include "Memory.h" #include "OutputSections.h" #include "Relocations.h" #include "Strings.h" #include "SymbolTable.h" #include "SyntheticSections.h" #include "Target.h" -#include "lld/Support/Memory.h" #include "llvm/ADT/StringMap.h" #include "llvm/ADT/StringSwitch.h" #include "llvm/Support/FileOutputBuffer.h" Index: include/lld/Support/Memory.h =================================================================== --- include/lld/Support/Memory.h +++ include/lld/Support/Memory.h @@ -35,7 +35,7 @@ // These two classes are hack to keep track of all // SpecificBumpPtrAllocator instances. struct SpecificAllocBase { - SpecificAllocBase(); + SpecificAllocBase() { Instances.push_back(this); } virtual ~SpecificAllocBase() = default; virtual void reset() = 0; static std::vector Instances; @@ -53,7 +53,11 @@ return new (Alloc.Alloc.Allocate()) T(std::forward(Args)...); } -void freeArena(); +inline void freeArena() { + for (SpecificAllocBase *Alloc : SpecificAllocBase::Instances) + Alloc->reset(); + BAlloc.Reset(); +} } #endif Index: lib/CMakeLists.txt =================================================================== --- lib/CMakeLists.txt +++ lib/CMakeLists.txt @@ -2,4 +2,3 @@ add_subdirectory(Core) add_subdirectory(Driver) add_subdirectory(ReaderWriter) -add_subdirectory(Support) Index: lib/Support/CMakeLists.txt =================================================================== --- lib/Support/CMakeLists.txt +++ /dev/null @@ -1,9 +0,0 @@ -add_lld_library(lldSupport - Memory.cpp - - ADDITIONAL_HEADER_DIRS - ${LLD_INCLUDE_DIR}/lld/Support - - LINK_LIBS - LLVMSupport -) Index: lib/Support/Memory.cpp =================================================================== --- lib/Support/Memory.cpp +++ /dev/null @@ -1,27 +0,0 @@ -//===- Memory.cpp -----------------------------------------------*- C++ -*-===// -// -// The LLVM Linker -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// - -#include "lld/Support/Memory.h" - -using namespace llvm; - -namespace lld { -BumpPtrAllocator BAlloc; -StringSaver Saver{BAlloc}; - -SpecificAllocBase::SpecificAllocBase() { Instances.push_back(this); } - -std::vector SpecificAllocBase::Instances; - -void freeArena() { - for (SpecificAllocBase *Alloc : SpecificAllocBase::Instances) - Alloc->reset(); - BAlloc.Reset(); -} -}