diff options
| author | Evan Cheng <evan.cheng@apple.com> | 2007-07-25 23:36:05 +0000 |
|---|---|---|
| committer | Evan Cheng <evan.cheng@apple.com> | 2007-07-25 23:36:05 +0000 |
| commit | 952aa6988b62349b25325fcdbe02e412bbe4a66b (patch) | |
| tree | b11c47b655b15afdecc836a353a738fa77333453 /llvm/lib/Target/X86/X86ATTAsmPrinter.cpp | |
| parent | 86eb3fd97da16a783c46a3ad0b4f55e2ec3d455a (diff) | |
| download | bcm5719-llvm-952aa6988b62349b25325fcdbe02e412bbe4a66b.tar.gz bcm5719-llvm-952aa6988b62349b25325fcdbe02e412bbe4a66b.zip | |
Mac OS X should use 0x90 to fill in gaps to satisfy function alignment requirements.
llvm-svn: 40501
Diffstat (limited to 'llvm/lib/Target/X86/X86ATTAsmPrinter.cpp')
| -rw-r--r-- | llvm/lib/Target/X86/X86ATTAsmPrinter.cpp | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/llvm/lib/Target/X86/X86ATTAsmPrinter.cpp b/llvm/lib/Target/X86/X86ATTAsmPrinter.cpp index 07670ea62be..4c707df1e39 100644 --- a/llvm/lib/Target/X86/X86ATTAsmPrinter.cpp +++ b/llvm/lib/Target/X86/X86ATTAsmPrinter.cpp @@ -99,19 +99,28 @@ bool X86ATTAsmPrinter::runOnMachineFunction(MachineFunction &MF) { switch (F->getLinkage()) { default: assert(0 && "Unknown linkage type!"); case Function::InternalLinkage: // Symbols default to internal. - EmitAlignment(4, F); // FIXME: This should be parameterized somewhere. + if (Subtarget->isTargetDarwin()) + // FIXME: This should be parameterized somewhere. + EmitAlignment(4, F, 0, true, 0x90); + else + EmitAlignment(4, F); // FIXME: This should be parameterized somewhere. break; case Function::DLLExportLinkage: DLLExportedFns.insert(Mang->makeNameProper(F->getName(), "")); //FALLS THROUGH case Function::ExternalLinkage: - EmitAlignment(4, F); // FIXME: This should be parameterized somewhere. + if (Subtarget->isTargetDarwin()) + // FIXME: This should be parameterized somewhere. + EmitAlignment(4, F, 0, true, 0x90); + else + EmitAlignment(4, F); // FIXME: This should be parameterized somewhere. O << "\t.globl\t" << CurrentFnName << "\n"; break; case Function::LinkOnceLinkage: case Function::WeakLinkage: if (Subtarget->isTargetDarwin()) { - EmitAlignment(4, F); // FIXME: This should be parameterized somewhere. + // FIXME: This should be parameterized somewhere. + EmitAlignment(4, F, 0, true, 0x90); O << "\t.globl\t" << CurrentFnName << "\n"; O << "\t.weak_definition\t" << CurrentFnName << "\n"; } else if (Subtarget->isTargetCygMing()) { |

