diff options
author | Evan Cheng <evan.cheng@apple.com> | 2008-03-25 22:29:46 +0000 |
---|---|---|
committer | Evan Cheng <evan.cheng@apple.com> | 2008-03-25 22:29:46 +0000 |
commit | 2e8d3d4b84a4f26eb57ccd01071e60e50d1311a4 (patch) | |
tree | d05c8aa1c6d3c8cf4cf711ff891ffddc15e771ce /lib/Target | |
parent | 295cc16ea2a4bfd607915550a00b4b4dc864eeaf (diff) | |
download | external_llvm-2e8d3d4b84a4f26eb57ccd01071e60e50d1311a4.zip external_llvm-2e8d3d4b84a4f26eb57ccd01071e60e50d1311a4.tar.gz external_llvm-2e8d3d4b84a4f26eb57ccd01071e60e50d1311a4.tar.bz2 |
Smaller function alignment when optimizing for size.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48805 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target')
-rw-r--r-- | lib/Target/PowerPC/PPCAsmPrinter.cpp | 2 | ||||
-rw-r--r-- | lib/Target/X86/X86ATTAsmPrinter.cpp | 7 | ||||
-rw-r--r-- | lib/Target/X86/X86IntelAsmPrinter.cpp | 5 |
3 files changed, 8 insertions, 6 deletions
diff --git a/lib/Target/PowerPC/PPCAsmPrinter.cpp b/lib/Target/PowerPC/PPCAsmPrinter.cpp index 0711313..2537d67 100644 --- a/lib/Target/PowerPC/PPCAsmPrinter.cpp +++ b/lib/Target/PowerPC/PPCAsmPrinter.cpp @@ -819,7 +819,7 @@ bool DarwinAsmPrinter::runOnMachineFunction(MachineFunction &MF) { if (const char *Directive = TAI->getHiddenDirective()) O << Directive << CurrentFnName << "\n"; - EmitAlignment(4, F); + EmitAlignment(OptimizeForSize ? 2 : 4, F); O << CurrentFnName << ":\n"; // Emit pre-function debug information. diff --git a/lib/Target/X86/X86ATTAsmPrinter.cpp b/lib/Target/X86/X86ATTAsmPrinter.cpp index 37afb46..0679656 100644 --- a/lib/Target/X86/X86ATTAsmPrinter.cpp +++ b/lib/Target/X86/X86ATTAsmPrinter.cpp @@ -98,21 +98,22 @@ bool X86ATTAsmPrinter::runOnMachineFunction(MachineFunction &MF) { SwitchToTextSection(getSectionForFunction(*F).c_str(), F); + unsigned FnAlign = OptimizeForSize ? 1 : 4; switch (F->getLinkage()) { default: assert(0 && "Unknown linkage type!"); case Function::InternalLinkage: // Symbols default to internal. - EmitAlignment(4, F); + EmitAlignment(FnAlign, F); break; case Function::DLLExportLinkage: DLLExportedFns.insert(Mang->makeNameProper(F->getName(), "")); //FALLS THROUGH case Function::ExternalLinkage: - EmitAlignment(4, F); + EmitAlignment(FnAlign, F); O << "\t.globl\t" << CurrentFnName << "\n"; break; case Function::LinkOnceLinkage: case Function::WeakLinkage: - EmitAlignment(4, F); + EmitAlignment(FnAlign, F); if (Subtarget->isTargetDarwin()) { O << "\t.globl\t" << CurrentFnName << "\n"; O << TAI->getWeakDefDirective() << CurrentFnName << "\n"; diff --git a/lib/Target/X86/X86IntelAsmPrinter.cpp b/lib/Target/X86/X86IntelAsmPrinter.cpp index 0caab87..ddd90cd 100644 --- a/lib/Target/X86/X86IntelAsmPrinter.cpp +++ b/lib/Target/X86/X86IntelAsmPrinter.cpp @@ -57,17 +57,18 @@ bool X86IntelAsmPrinter::runOnMachineFunction(MachineFunction &MF) { SwitchToTextSection(getSectionForFunction(*F).c_str(), F); + unsigned FnAlign = OptimizeForSize ? 1 : 4; switch (F->getLinkage()) { default: assert(0 && "Unsupported linkage type!"); case Function::InternalLinkage: - EmitAlignment(4); + EmitAlignment(FnAlign); break; case Function::DLLExportLinkage: DLLExportedFns.insert(CurrentFnName); //FALLS THROUGH case Function::ExternalLinkage: O << "\tpublic " << CurrentFnName << "\n"; - EmitAlignment(4); + EmitAlignment(FnAlign); break; } |