summaryrefslogtreecommitdiff
path: root/lib/Target/Mips/MipsSubtarget.cpp
diff options
context:
space:
mode:
authorBruno Cardoso Lopes <bruno.cardoso@gmail.com>2008-07-21 18:52:34 +0000
committerBruno Cardoso Lopes <bruno.cardoso@gmail.com>2008-07-21 18:52:34 +0000
commit91fd532eb9a18c0fd8d91b975226ef6b41c772ec (patch)
tree5441c955f34bb60888c218900906b1cca1483227 /lib/Target/Mips/MipsSubtarget.cpp
parent6116a73da420d9b414a34ce2599dc7f6476e23fc (diff)
downloadllvm-91fd532eb9a18c0fd8d91b975226ef6b41c772ec.tar.gz
llvm-91fd532eb9a18c0fd8d91b975226ef6b41c772ec.tar.bz2
llvm-91fd532eb9a18c0fd8d91b975226ef6b41c772ec.tar.xz
Added initial support for small sections on Mips.
Added gp_rel relocations to support addressing small section contents. Added command line to specify small section threshold in bytes. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@53869 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/Mips/MipsSubtarget.cpp')
-rw-r--r--lib/Target/Mips/MipsSubtarget.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/lib/Target/Mips/MipsSubtarget.cpp b/lib/Target/Mips/MipsSubtarget.cpp
index 3424388011..bc87e4ba7a 100644
--- a/lib/Target/Mips/MipsSubtarget.cpp
+++ b/lib/Target/Mips/MipsSubtarget.cpp
@@ -22,6 +22,9 @@ cl::opt<bool> NotABICall("disable-mips-abicall", cl::Hidden,
cl::desc("Disable code for SVR4-style dynamic objects"));
cl::opt<bool> AbsoluteCall("enable-mips-absolute-call", cl::Hidden,
cl::desc("Enable absolute call within abicall"));
+cl::opt<unsigned> SSThreshold("mips-ssection-threshold", cl::Hidden,
+ cl::desc("Small data and bss section threshold size (default=8)"),
+ cl::init(8));
MipsSubtarget::MipsSubtarget(const TargetMachine &TM, const Module &M,
const std::string &FS, bool little) :
@@ -35,6 +38,9 @@ MipsSubtarget::MipsSubtarget(const TargetMachine &TM, const Module &M,
ParseSubtargetFeatures(FS, CPU);
const std::string& TT = M.getTargetTriple();
+ // Small section size threshold
+ SSectionThreshold = SSThreshold;
+
// Is the target system Linux ?
if (TT.find("linux") == std::string::npos)
IsLinux = false;